[Bug 1640878] Re: grub2 cannot currently generate configuration without initrd
Steve Langasek
steve.langasek at canonical.com
Wed Mar 1 21:59:07 UTC 2017
Surprisingly, the partuuid stuff works even on dos partition tables, as
of xenial. So I've successfully tested this, including a boot test!
** Tags removed: verification-needed
** Tags added: verification-done
--
You received this bug notification because you are a member of Ubuntu
Foundations Bugs, which is subscribed to grub2 in Ubuntu.
https://bugs.launchpad.net/bugs/1640878
Title:
grub2 cannot currently generate configuration without initrd
Status in grub2 package in Ubuntu:
Fix Released
Status in grub2-signed package in Ubuntu:
Fix Released
Status in grub2 source package in Xenial:
Fix Committed
Bug description:
As it currently stands grub2 cannot create grub.cfg menu entries that do not use an initrd image if one is present but the user does not desire to use it.
Furthermore, root= entries only support UUID and LABEL, but neither is an option if booting the kernel without an initrd.
Suggestion:
Allow grub2 to create configuration files without an "initrd" line and
passing PARTUUID as root= entry by adding configuration knobs.
[SRU Justification]
A lot of time is wasted across the many, many instances of Ubuntu loading initramfs when booting. It's a measurable savings of CPU time and electricity to skip loading an initramfs at boot if it's not required.
[Test case]
1. cp /boot/grub/grub.cfg /tmp/grub.cfg
2. install the grub packages from -proposed.
3. cmp /boot/grub/grub.cfg /tmp/grub.cfg || echo 'fail'
4. as root, configure /etc/default/grub to mount the root disk directly and bypass the initramfs:
echo GRUB_DISABLE_INITRD=true >> /etc/default/grub
root=$(awk </etc/fstab '$2 == "/" { print $1 }')
case $root in
LABEL=*|UUID=*)
dev="-l -t $root"
;;
*)
dev=$root
;;
esac
partuuid=$(blkid -s PARTUUID -o value $dev)
if [ -z "$partuuid" ]; then
echo "Error: cannot get partuuid for $root."
else
echo GRUB_FORCE_PARTUUID=$partuuid >> /etc/default/grub
fi
5. If a partuuid has been found, run update-grub. Note that this will only work if your root device is a partition on a GPT-formatted disk.
6. Check that /boot/grub/grub.cfg now contains entries that don't specify an initramfs, and do include root=PARTUUID=* on the kernel commandline.
[Regression potential]
This upload introduces no behavior changes unless the user updates /etc/default/grub to configure the use of the new feature, so there should be no regressions here. The SRU test case verifies that /boot/grub/grub.cfg remains unchanged with the new version.
To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/grub2/+bug/1640878/+subscriptions
More information about the foundations-bugs
mailing list