Ensure a console exists when booting for autoexpand to prevent start failure

This commit is contained in:
Lutz Schwarz 2020-09-03 17:02:34 +02:00
parent 87ef6d70e3
commit 9db4e9b68b
1 changed files with 46 additions and 0 deletions

View File

@ -81,6 +81,7 @@ function set_autoexpand() {
local new_rc_local=$( local new_rc_local=$(
cat <<\EOF1 cat <<\EOF1
#!/bin/bash #!/bin/bash
[ -f /boot/cmdline.txt.pishrink-bak ] && mv -fT /boot/cmdline.txt.pishrink-bak /boot/cmdline.txt
do_expand_rootfs() { do_expand_rootfs() {
ROOT_PART=$(mount | sed -n 's|^/dev/\(.*\) on / .*|\1|p') ROOT_PART=$(mount | sed -n 's|^/dev/\(.*\) on / .*|\1|p')
@ -175,9 +176,54 @@ EOF1
chmod +x "$mountdir/etc/rc.local.bak" chmod +x "$mountdir/etc/rc.local.bak"
fi fi
fi fi
# If rc.local is started by systemd it may fail to start if no console exists.
# Ensure a console is there until autoexpand was done:
boot_enable_console "$mountdir"
umount "$mountdir" umount "$mountdir"
} }
function boot_enable_console () {
local fsroot="$1"
local bootstart="$(echo "$parted_output" | grep '^1:' | cut -d ':' -f 2 | tr -d 'B')"
local boot bootloop bootroot
local SEDCMDS='s/console=null/console=tty0/'
if [ -z "$fsroot" -o "x$bootstart" != "x$partstart" ]
then
bootloop="$(losetup -f --show -o "$bootstart" "$img")"
bootroot="$(mktemp -d)"
partprobe "$bootloop"
mount "$bootloop" "$bootroot"
boot="$bootroot"
else
boot="$fsroot/boot"
fi
logVariables $LINENO fsroot bootstart bootloop bootroot boot
if grep -q console=null "$boot/cmdline.txt" ; then
info "/boot/cmdline.txt changed to temporarily enable console for autoexpand"
cp -p "$boot/cmdline.txt" "$boot/cmdline.txt.pishrink-bak"
sed -i "$boot/cmdline.txt" -e "$SEDCMDS"
else
# ok, already enabled. If a backup exists, it was done by us; check if the backup is stil valid.
if [ -f "$boot/cmdline.txt.pishrink-bak" ]; then
if [ "$(sed "$boot/cmdline.txt.pishrink-bak" -e "$SEDCMDS")" = "$(cat "$boot/cmdline.txt")" ]; then
info "/boot/cmdline.txt already changed to temporarily enable console for autoexpand"
else
# console was enabled by design - not by us. Remove backup to prevent installing it.
rm -f "$boot/cmdline.txt.pishrink-bak"
fi
fi
fi
[ -n "$bootroot" ] && umount "$bootroot"
[ -n "$bootloop" ] && losetup -d "$bootloop"
}
help() { help() {
local help local help
read -r -d '' help << EOM read -r -d '' help << EOM