mirror of
https://git.launchpad.net/livecd-rootfs
synced 2025-05-31 12:41:40 +00:00
live-build/functions: avoid losetup -P as it appears to race with udev and do it a bit more by-hand instead. (LP: #2045586)
This commit is contained in:
parent
4d17ae31b3
commit
57592e6dc1
7
debian/changelog
vendored
7
debian/changelog
vendored
@ -1,3 +1,10 @@
|
|||||||
|
livecd-rootfs (24.04.21) UNRELEASED; urgency=medium
|
||||||
|
|
||||||
|
* live-build/functions: avoid losetup -P as it appears to race with udev and
|
||||||
|
do it a bit more by-hand instead. (LP: #2045586)
|
||||||
|
|
||||||
|
-- Michael Hudson-Doyle <michael.hudson@ubuntu.com> Thu, 25 Jan 2024 07:45:58 +1300
|
||||||
|
|
||||||
livecd-rootfs (24.04.20) noble; urgency=medium
|
livecd-rootfs (24.04.20) noble; urgency=medium
|
||||||
|
|
||||||
* fix: Fix for calling unminimize if lxd-installer package
|
* fix: Fix for calling unminimize if lxd-installer package
|
||||||
|
@ -62,13 +62,26 @@ mount_image() {
|
|||||||
trap clean_loops EXIT
|
trap clean_loops EXIT
|
||||||
backing_img="$1"
|
backing_img="$1"
|
||||||
local rootpart="$2"
|
local rootpart="$2"
|
||||||
loop_device=$(losetup --show -f -P -v ${backing_img})
|
|
||||||
|
# As explained in excruciating detail in LP: #2045586, "losetup
|
||||||
|
# -P" (a.k.a. --partscan) appears to race with udev in a way that
|
||||||
|
# prevents the device nodes for the partitions from being
|
||||||
|
# created. So instead we run losetup without -P, wait for udev to
|
||||||
|
# settle, then run partprobe and then settle udev again (which is
|
||||||
|
# probably unnecessary but at this point a bit more superstition
|
||||||
|
# can't hurt)
|
||||||
|
|
||||||
|
loop_device=$(losetup --show -f -v ${backing_img})
|
||||||
|
|
||||||
if [ ! -b ${loop_device} ]; then
|
if [ ! -b ${loop_device} ]; then
|
||||||
echo "unable to find loop device for ${backing_img}"
|
echo "unable to find loop device for ${backing_img}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
udevadm settle
|
||||||
|
partprobe ${loop_device}
|
||||||
|
udevadm settle
|
||||||
|
|
||||||
# Find the rootfs location
|
# Find the rootfs location
|
||||||
rootfs_dev_mapper="${loop_device}p${rootpart}"
|
rootfs_dev_mapper="${loop_device}p${rootpart}"
|
||||||
if [ ! -b "${rootfs_dev_mapper}" ]; then
|
if [ ! -b "${rootfs_dev_mapper}" ]; then
|
||||||
|
Loading…
x
Reference in New Issue
Block a user