Merge branch 'layer-fixes' into ubuntu/master

bdmurray/intel-iot-models
Michael Hudson-Doyle 4 years ago
commit cb28f14e7c

7
debian/changelog vendored

@ -1,3 +1,10 @@
livecd-rootfs (2.729) UNRELEASED; urgency=medium
* Fix a few things found while porting the liver server ISO builds to
layers.
-- Michael Hudson-Doyle <michael.hudson@ubuntu.com> Fri, 25 Jun 2021 10:35:47 +1200
livecd-rootfs (2.728) impish; urgency=medium livecd-rootfs (2.728) impish; urgency=medium
[ Dan Bungert ] [ Dan Bungert ]

@ -1012,7 +1012,7 @@ PASSES=$(_sanitize_passes "$PASSES")
LIVE_PASSES=${LIVE_PASSES:-$(_get_live_passes "$PASSES")} LIVE_PASSES=${LIVE_PASSES:-$(_get_live_passes "$PASSES")}
if [ -n "$PASSES" ] && [ -z "$LIVE_PASSES" ]; then if [ -n "$PASSES" ] && [ -z "$LIVE_PASSES" ]; then
Echo_warning "Multi-layered mode is enabled, but we didn't find any live pass." \ echo "W: Multi-layered mode is enabled, but we didn't find any live pass." \
"Either set \$LIVE_PASSES or add a pass ending with '.live'." "Either set \$LIVE_PASSES or add a pass ending with '.live'."
fi fi
@ -1023,6 +1023,9 @@ echo "IMAGEFORMAT=\"$IMAGEFORMAT\"" >> config/chroot
if [ -n "$PASSES" ]; then if [ -n "$PASSES" ]; then
echo "PASSES=\"$PASSES\"" >> config/common echo "PASSES=\"$PASSES\"" >> config/common
fi fi
if [ -n "$NO_SQUASHFS_PASSES" ]; then
echo "NO_SQUASHFS_PASSES=\"$NO_SQUASHFS_PASSES\"" >> config/common
fi
if [ -n "$LIVE_PASSES" ]; then if [ -n "$LIVE_PASSES" ]; then
echo "LIVE_PASSES=\"$LIVE_PASSES\"" >> config/common echo "LIVE_PASSES=\"$LIVE_PASSES\"" >> config/common
fi fi

@ -66,7 +66,7 @@ build_layered_squashfs () {
return return
fi fi
rm -f .build/binary_chroot rm -f .build/binary_chroot .build/binary_hooks
mkdir -p "$overlay_dir/" mkdir -p "$overlay_dir/"
lowerdirs=$(get_lowerdirs_for_pass $pass) lowerdirs=$(get_lowerdirs_for_pass $pass)
@ -92,6 +92,22 @@ build_layered_squashfs () {
rm -f chroot/boot/initrd.img-* chroot/boot/vmlinu{x,z}-* rm -f chroot/boot/initrd.img-* chroot/boot/vmlinu{x,z}-*
fi fi
make_squashfs=yes
ppass="${pass}"
while :; do
for nsp in ${NO_SQUASHFS_PASSES}; do
if [ "${ppass}" = "${nsp}" ]; then
make_squashfs=no
break 2
fi
done
ppass="$(get_parent_pass "${ppass}")"
if [ -z "${ppass}" ]; then
break
fi
done
if [ $make_squashfs = yes ]; then
# Full manifest until that PASS # Full manifest until that PASS
squashfs_f_manifest="${base}.manifest" squashfs_f_manifest="${base}.manifest"
create_manifest "chroot" "${squashfs_f_manifest}.full" create_manifest "chroot" "${squashfs_f_manifest}.full"
@ -121,9 +137,8 @@ build_layered_squashfs () {
cp "${squashfs_f_manifest}.full" "${prefix}.manifest" cp "${squashfs_f_manifest}.full" "${prefix}.manifest"
fi fi
(cd "overlay.${pass}/" && create_squashfs "overlay.${pass}/" ${squashfs_f}
mksquashfs . ${squashfs_f} \ fi
-no-progress -xattrs -comp xz )
if [ -n "$lowerdirs" ]; then if [ -n "$lowerdirs" ]; then
umount chroot umount chroot

@ -131,7 +131,7 @@ reduce_pass_size () {
continue continue
fi fi
# Files are strictly identical between the 2 passes (only mod or access times differs). No need for unused delta. # Files are strictly identical between the 2 passes (only mod or access times differs). No need for unused delta.
Echo_message "reduce_pass_size: '$f' is strictly identical between $parent and $pass. Removing." Echo_message "reduce_pass_size: '%s' is strictly identical between %s and %s. Removing." "$f" "$pass" "$parent"
rm "$pass_dir/$f" rm "$pass_dir/$f"
done done
@ -143,7 +143,7 @@ create_chroot_pass () {
local pass=$1 local pass=$1
shift 1 # restore ${*} shift 1 # restore ${*}
Echo_message "lb_chroot_layered: treating pass $pass" Echo_message "lb_chroot_layered: treating pass %s" "$pass"
# We have already treated that pass just return. # We have already treated that pass just return.
local overlay_dir="overlay.${pass}" local overlay_dir="overlay.${pass}"
@ -154,7 +154,7 @@ create_chroot_pass () {
# Only get some function executed on root passes # Only get some function executed on root passes
# Copy bootstrap on root layers # Copy bootstrap on root layers
if $(is_root_layer $pass); then if $(is_root_layer $pass); then
rm -f .build/chroot_linux-image .build/chroot_preseed .build/chroot_hacks rm -f .build/chroot_linux-image .build/chroot_preseed
cp -a chroot.bootstrap/ "$overlay_dir/" cp -a chroot.bootstrap/ "$overlay_dir/"
fi fi
# Others have to be executed on every pass # Others have to be executed on every pass
@ -196,7 +196,6 @@ create_chroot_pass () {
# Only configure universe on root passes # Only configure universe on root passes
if $(is_root_layer $pass); then if $(is_root_layer $pass); then
lb chroot_archives chroot install ${*} lb chroot_archives chroot install ${*}
configure_universe
fi fi
# Customizing chroot # Customizing chroot
@ -247,13 +246,24 @@ create_chroot_pass () {
lb chroot_hooks ${*} lb chroot_hooks ${*}
# Run chroot_hacks only on root layers. # Run chroot_hacks only on live layers. chroot_hacks is what repacks
# chroot_hacks changes the mode of boot/initrd*. The side effect in # the initrd in a full casperized mode. We don't want to do that for
# layered mode is to create an initrd on each layer with a significant # each and every layer, just for the live layers (which
# impact on image size (+30MB per layer). This is an issue even with # lb_binary_layered will call lb binary_linux-image on).
# update-initramfs disabled.
if $(is_live_layer $pass); then if $(is_live_layer $pass); then
rm -f .build/chroot_hacks
lb chroot_hacks ${*} lb chroot_hacks ${*}
else
# chroot_hacks also removes some cruft, which is appropriate for
# any layer so we copy and paste that bit here.
rm -f chroot/boot/initrd*bak*
rm -f chroot/etc/apt/trusted.gpg~
rm -f chroot/etc/group- chroot/etc/passwd-
rm -f chroot/etc/gshadow- chroot/etc/shadow-
rm -f chroot/var/cache/debconf/*-old
rm -f chroot/var/lib/dpkg/*-old
rm -f chroot/var/log/apt/term.log
rm -f chroot/etc/adjtime
fi fi
lb chroot_interactive ${*} lb chroot_interactive ${*}
@ -267,6 +277,7 @@ create_chroot_pass () {
# Deconfiguring chroot # Deconfiguring chroot
if $(is_root_layer $pass); then if $(is_root_layer $pass); then
lb chroot_archives chroot remove ${*} lb chroot_archives chroot remove ${*}
configure_universe
fi fi
lb chroot_apt remove ${*} lb chroot_apt remove ${*}
lb chroot_hostname remove ${*} lb chroot_hostname remove ${*}

Loading…
Cancel
Save