Browse Source

Merge pull request #115 from parkoview/fixraceconditions

Fix some race conditions when running multiple instances of mender-co…
2.0.x
Lluis Campos 5 years ago
committed by GitHub
parent
commit
8b2bae9c9d
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 22
      mender-convert
  2. 3
      mender-convert-functions.sh

22
mender-convert

@ -140,20 +140,19 @@ do_raw_disk_image_shrink_rootfs() {
get_raw_disk_sizes ${raw_disk_image} raw_disk_counts raw_disk_sizes get_raw_disk_sizes ${raw_disk_image} raw_disk_counts raw_disk_sizes
local sector_size=${raw_disk_sizes[sector_size]} local sector_size=${raw_disk_sizes[sector_size]}
# Find first available loopback device.
loopdevice=($(losetup -f))
[ $? -ne 0 ] && { log "Error: inaccesible loopback device"; return 1; }
# Mount appropriate partition.
if [[ $raw_disk_counts -eq 1 ]]; then if [[ $raw_disk_counts -eq 1 ]]; then
sudo losetup $loopdevice $raw_disk_image -o $((${raw_disk_sizes[pboot_start]} * $sector_size)) offset=${raw_disk_sizes[pboot_start]}
elif [[ $raw_disk_counts -eq 2 ]]; then elif [[ $raw_disk_counts -eq 2 ]]; then
sudo losetup $loopdevice $raw_disk_image -o $((${raw_disk_sizes[prootfs_start]} * $sector_size)) offset=${raw_disk_sizes[prootfs_start]}
else else
log "Warning: invalid/unsupported embedded raw disk image. Skipping resize..." log "Warning: invalid/unsupported embedded raw disk image. Skipping resize..."
return 0 return 0
fi fi
# Find first available loopback device and mount appropriate partition.
loopdevice=$(sudo losetup --show -f -o $((${offset} * $sector_size)) $raw_disk_image)
[ $? -ne 0 ] && { log "Error: inaccesible loopback device"; return 1; }
block_size=($(sudo dumpe2fs -h $loopdevice | grep 'Block size' | tr -s ' ' | cut -d ' ' -f3)) block_size=($(sudo dumpe2fs -h $loopdevice | grep 'Block size' | tr -s ' ' | cut -d ' ' -f3))
min_size_blocks=($(sudo resize2fs -P $loopdevice | awk '{print $NF}')) min_size_blocks=($(sudo resize2fs -P $loopdevice | awk '{print $NF}'))
@ -170,7 +169,7 @@ do_raw_disk_image_shrink_rootfs() {
sudo e2fsck -y -f $loopdevice >> "$build_log" 2>&1 sudo e2fsck -y -f $loopdevice >> "$build_log" 2>&1
sudo losetup -d $loopdevice sudo losetup -d $loopdevice
sudo losetup $loopdevice $raw_disk_image loopdevice=$(sudo losetup --show -f $raw_disk_image)
if [[ $raw_disk_counts -eq 1 ]]; then if [[ $raw_disk_counts -eq 1 ]]; then
create_single_disk_partition_table $loopdevice \ create_single_disk_partition_table $loopdevice \
@ -622,14 +621,13 @@ do_mender_disk_image_to_artifact() {
[[ $ret -ne 0 ]] && \ [[ $ret -ne 0 ]] && \
{ log "Error: checking $mender_rootfs_basename file system failed. Aborting."; } { log "Error: checking $mender_rootfs_basename file system failed. Aborting."; }
# Find first available loopback device. # Find first available loopback device and use it.
loopdevice=($(sudo losetup -f || ret=$?)) loopdevice=($(sudo losetup --show -f ${mender_rootfs_image} || ret=$?))
[[ $ret -ne 0 ]] && \ [[ $ret -ne 0 ]] && \
{ log "Error: cannot find an unused loop device. Aborting."; } { log "Error: cannot find an unused loop device. Aborting."; }
if [ $ret -eq 0 ]; then if [ $ret -eq 0 ]; then
#Mount extracted ext4 partition to verify 'artifact_info' file content. # Mount extracted ext4 partition to verify 'artifact_info' file content.
sudo losetup $loopdevice ${mender_rootfs_image}
rootfs_mountpoint=${output_dir}/mnt/${rootfs_partition_id} rootfs_mountpoint=${output_dir}/mnt/${rootfs_partition_id}
mkdir -p ${rootfs_mountpoint} mkdir -p ${rootfs_mountpoint}
sudo mount $loopdevice ${rootfs_mountpoint} sudo mount $loopdevice ${rootfs_mountpoint}

3
mender-convert-functions.sh

@ -589,7 +589,8 @@ create_device_maps() {
local -n mappings=$2 local -n mappings=$2
if [[ -n "$1" ]]; then if [[ -n "$1" ]]; then
mapfile -t mappings < <( sudo kpartx -v -a $1 | grep 'loop' | cut -d' ' -f3 ) loopdevice=$(sudo losetup --show -f $1)
mapfile -t mappings < <( sudo kpartx -s -v -a $loopdevice | grep 'loop' | cut -d' ' -f3 )
[[ ${#mappings[@]} -eq 0 ]] \ [[ ${#mappings[@]} -eq 0 ]] \
&& { log "Error: partition mappings failed. Aborting."; exit 1; } && { log "Error: partition mappings failed. Aborting."; exit 1; }
else else

Loading…
Cancel
Save