Adding function for more resilient detachment of loopback devices.
This commit is contained in:
parent
ebc7a72501
commit
0d2cc22efc
|
@ -7,6 +7,29 @@
|
||||||
## This is free software, and you are welcome to redistribute it
|
## This is free software, and you are welcome to redistribute it
|
||||||
## under certain conditions; see COPYING for details.
|
## under certain conditions; see COPYING for details.
|
||||||
|
|
||||||
|
Lodetach ()
|
||||||
|
{
|
||||||
|
DEVICE="${1}"
|
||||||
|
ATTEMPT="${2:-1}"
|
||||||
|
|
||||||
|
if [ "${ATTEMPT}" -gt 3 ]
|
||||||
|
then
|
||||||
|
Echo_error "Failed to detach loop device '${DEVICE}'."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Changes to block devices result in uevents which trigger rules which in
|
||||||
|
# turn access the loop device (ex. udisks-part-id, blkid) which can cause
|
||||||
|
# a race condition. We call 'udevadm settle' to help avoid this.
|
||||||
|
${LB_ROOT_COMMAND} udevadm settle
|
||||||
|
|
||||||
|
# Loop back devices aren't the most reliable when it comes to writes.
|
||||||
|
# We sleep and sync for good measure - better than build failure.
|
||||||
|
sync
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
${LB_ROOT_COMMAND} ${LB_LOSETUP} -d "${DEVICE}" || Lodetach "${DEVICE}" "$(expr ${ATTEMPT} + 1)"
|
||||||
|
}
|
||||||
|
|
||||||
Losetup ()
|
Losetup ()
|
||||||
{
|
{
|
||||||
|
@ -14,9 +37,9 @@ Losetup ()
|
||||||
FILE="${2}"
|
FILE="${2}"
|
||||||
PARTITION="${3:-1}"
|
PARTITION="${3:-1}"
|
||||||
|
|
||||||
${LB_ROOT_COMMAND} ${LB_LOSETUP} "${DEVICE}" "${FILE}"
|
${LB_ROOT_COMMAND} ${LB_LOSETUP} --read-only "${DEVICE}" "${FILE}"
|
||||||
FDISK_OUT="$(${LB_FDISK} -l -u ${DEVICE} 2>&1)"
|
FDISK_OUT="$(${LB_FDISK} -l -u ${DEVICE} 2>&1)"
|
||||||
${LB_ROOT_COMMAND} ${LB_LOSETUP} -d "${DEVICE}"
|
Lodetach "${DEVICE}"
|
||||||
|
|
||||||
LOOPDEVICE="$(echo ${DEVICE}p${PARTITION})"
|
LOOPDEVICE="$(echo ${DEVICE}p${PARTITION})"
|
||||||
|
|
||||||
|
|
|
@ -164,8 +164,7 @@ case "${LB_BUILD_WITH_CHROOT}" in
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
sleep 1
|
Lodetach ${FREELO}
|
||||||
${LB_LOSETUP} -d ${FREELO}
|
|
||||||
|
|
||||||
FREELO="$(${LB_LOSETUP} -f)"
|
FREELO="$(${LB_LOSETUP} -f)"
|
||||||
Losetup $FREELO chroot/binary.img 1
|
Losetup $FREELO chroot/binary.img 1
|
||||||
|
@ -254,8 +253,7 @@ then
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sleep 1
|
Lodetach ${FREELO}
|
||||||
${LB_LOSETUP} -d ${FREELO}
|
|
||||||
|
|
||||||
echo "!!! The above error/warning messages can be ignored !!!"
|
echo "!!! The above error/warning messages can be ignored !!!"
|
||||||
|
|
||||||
|
@ -274,8 +272,7 @@ case "${LB_BUILD_WITH_CHROOT}" in
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
sleep 1
|
Lodetach ${FREELO}
|
||||||
${LB_LOSETUP} -d ${FREELO}
|
|
||||||
|
|
||||||
if [ -n "${MAKEDEV}" ]
|
if [ -n "${MAKEDEV}" ]
|
||||||
then
|
then
|
||||||
|
|
|
@ -93,8 +93,7 @@ Echo_warning "!!! The following error/warning messages can be ignored !!!"
|
||||||
Losetup $FREELO source.img 0
|
Losetup $FREELO source.img 0
|
||||||
Chroot chroot "parted -s ${FREELO} mklabel msdos" || true
|
Chroot chroot "parted -s ${FREELO} mklabel msdos" || true
|
||||||
Chroot chroot "parted -s ${FREELO} mkpart primary ${PARTITION_TYPE} 0.0 100%" || true
|
Chroot chroot "parted -s ${FREELO} mkpart primary ${PARTITION_TYPE} 0.0 100%" || true
|
||||||
sleep 1
|
Lodetach ${FREELO}
|
||||||
${LB_LOSETUP} -d ${FREELO}
|
|
||||||
|
|
||||||
Losetup $FREELO source.img 1
|
Losetup $FREELO source.img 1
|
||||||
|
|
||||||
|
@ -122,15 +121,13 @@ ${LB_ROOT_COMMAND} mount ${FREELO} source.tmp
|
||||||
cp -r source/* source.tmp
|
cp -r source/* source.tmp
|
||||||
${LB_ROOT_COMMAND} umount source.tmp
|
${LB_ROOT_COMMAND} umount source.tmp
|
||||||
rmdir source.tmp
|
rmdir source.tmp
|
||||||
sleep 1
|
Lodetach ${FREELO}
|
||||||
${LB_LOSETUP} -d ${FREELO}
|
|
||||||
Echo_warning "!!! The above error/warning messages can be ignored !!!"
|
Echo_warning "!!! The above error/warning messages can be ignored !!!"
|
||||||
|
|
||||||
FREELO="$(${LB_LOSETUP} -f)"
|
FREELO="$(${LB_LOSETUP} -f)"
|
||||||
Losetup "$FREELO" source.img 0
|
Losetup "$FREELO" source.img 0
|
||||||
Chroot chroot "parted -s ${FREELO} set 1 lba off" || true
|
Chroot chroot "parted -s ${FREELO} set 1 lba off" || true
|
||||||
sleep 1
|
Lodetach ${FREELO}
|
||||||
${LB_LOSETUP} -d ${FREELO}
|
|
||||||
|
|
||||||
if [ -n "${MAKEDEV}" ]
|
if [ -n "${MAKEDEV}" ]
|
||||||
then
|
then
|
||||||
|
|
Loading…
Reference in New Issue