]> git.proxmox.com Git - pve-kernel-meta.git/commitdiff
proxmox-boot: read only first line of /etc/kernel/cmdline
authorStoiko Ivanov <s.ivanov@proxmox.com>
Wed, 10 Nov 2021 15:25:10 +0000 (16:25 +0100)
committerThomas Lamprecht <t.lamprecht@proxmox.com>
Thu, 11 Nov 2021 10:18:42 +0000 (11:18 +0100)
following the commit of removing the wrong indentation of the linux
and initrd lines - this commit strips empty lines (and leading
trailing whitespace) in /etc/kernel/cmdline.

I managed to reproduce the issue reported in the forum [0] by adding
empty lines to /etc/kernel/cmdline) - without this - systemd-boot
booted quite happily even with the indentation.

considered using perl -pe with multiline matching but thanks to
Thomas' suggestion went with the shell-builtin read.

the check for existance of 'root=' in the resulting CMDLINE was added,
since my test-system had an empty line in the beginning, which again
rendered it unbootable.

quickly tested on a VM.

[0]: https://forum.proxmox.com/threads/problem-with-proxmox-boot-tool.99043/

Signed-off-by: Stoiko Ivanov <s.ivanov@proxmox.com>
proxmox-boot/zz-proxmox-boot

index 52171b2368cf29c78c2cbda5611ac9b531226765..26a9e7ea239492333faf4e02c91e49de581c0bc7 100755 (executable)
@@ -50,7 +50,9 @@ update_esps() {
            exit 0
        fi
        if [ -f /etc/kernel/cmdline ]; then
-               CMDLINE="$(cat /etc/kernel/cmdline)"
+               read -r CMDLINE < /etc/kernel/cmdline
+               echo ${CMDLINE} | grep -q 'root=' || \
+                       { warn "No root= parameter in /etc/kernel/cmdline found!"; exit 1; }
        else
                warn "No /etc/kernel/cmdline found - falling back to /proc/cmdline"
                # remove initrd entries