Bug#827956: grub: Doesn't apply default entry from /etc/default/grub

Diederik de Haas didi.debian at cknow.org
Tue Mar 2 09:24:41 GMT 2021


Package: grub-pc
Version: 2.04-15
Followup-For: Bug #827956

I have a 'server' with no keyboard or monitor attached. I want to
boot into a 5.9 kernel instead of a 5.10 kernel to see whether there's a
NFS problem with 5.10.
But regardless what I specify as GRUB_DEFAULT in /etc/default/grub, it
always boots the top entry.

I've tried the following things:
- Use the value following "$menuentry_id_option"
- Placed single quotes around previous value
- Placed double quotes around previous value
- Replace "$menuentry_id_option" with "--id" in case it was incorrectly
  not expanded/replaced in the grub entries
- Use a numerical value

None of which resulted in grub booting anything other then the top
entry.
If this can't be fixed, can then at least the documentation be updated
to say that grub only works interactively?


-- Package-specific info:

*********************** BEGIN /proc/mounts
/dev/sda2 / btrfs rw,relatime,ssd,space_cache,subvolid=5,subvol=/ 0 0
/dev/sda1 /boot ext4 rw,relatime 0 0
/dev/sdb1 /srv/media btrfs rw,relatime,space_cache,subvolid=5,subvol=/ 0 0
*********************** END /proc/mounts

*********************** BEGIN /boot/grub/grub.cfg
#
# DO NOT EDIT THIS FILE
#
# It is automatically generated by grub-mkconfig using templates
# from /etc/grub.d and settings from /etc/default/grub
#

### BEGIN /etc/grub.d/00_header ###
if [ -s $prefix/grubenv ]; then
  set have_grubenv=true
  load_env
fi
if [ "${next_entry}" ] ; then
   set default="${next_entry}"
   set next_entry=
   save_env next_entry
   set boot_once=true
else
   set default="gnulinux-5.9.0-5-amd64-advanced-2f82ed85-9840-4338-a5b2-71c735333ed9"
fi

if [ x"${feature_menuentry_id}" = xy ]; then
  menuentry_id_option="--id"
else
  menuentry_id_option=""
fi

export menuentry_id_option

if [ "${prev_saved_entry}" ]; then
  set saved_entry="${prev_saved_entry}"
  save_env saved_entry
  set prev_saved_entry=
  save_env prev_saved_entry
  set boot_once=true
fi

function savedefault {
  if [ -z "${boot_once}" ]; then
    saved_entry="${chosen}"
    save_env saved_entry
  fi
}
function load_video {
  if [ x$feature_all_video_module = xy ]; then
    insmod all_video
  else
    insmod efi_gop
    insmod efi_uga
    insmod ieee1275_fb
    insmod vbe
    insmod vga
    insmod video_bochs
    insmod video_cirrus
  fi
}

if [ x$feature_default_font_path = xy ] ; then
   font=unicode
else
insmod part_msdos
insmod btrfs
set root='hd0,msdos2'
if [ x$feature_platform_search_hint = xy ]; then
  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos2 --hint-efi=hd0,msdos2 --hint-baremetal=ahci0,msdos2  2f82ed85-9840-4338-a5b2-71c735333ed9
else
  search --no-floppy --fs-uuid --set=root 2f82ed85-9840-4338-a5b2-71c735333ed9
fi
    font="/usr/share/grub/unicode.pf2"
fi

if loadfont $font ; then
  set gfxmode=auto
  load_video
  insmod gfxterm
  set locale_dir=$prefix/locale
  set lang=en_US
  insmod gettext
fi
terminal_output gfxterm
if [ "${recordfail}" = 1 ] ; then
  set timeout=30
else
  if [ x$feature_timeout_style = xy ] ; then
    set timeout_style=menu
    set timeout=5
  # Fallback normal timeout code in case the timeout_style feature is
  # unavailable.
  else
    set timeout=5
  fi
fi
### END /etc/grub.d/00_header ###

### BEGIN /etc/grub.d/05_debian_theme ###
set menu_color_normal=cyan/blue
set menu_color_highlight=white/blue
### END /etc/grub.d/05_debian_theme ###

### BEGIN /etc/grub.d/10_linux ###
function gfxmode {
	set gfxpayload="${1}"
}
set linux_gfx_mode=
export linux_gfx_mode
menuentry 'Debian GNU/Linux' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-simple-2f82ed85-9840-4338-a5b2-71c735333ed9' {
	load_video
	insmod gzio
	if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
	insmod part_msdos
	insmod ext2
	set root='hd0,msdos1'
	if [ x$feature_platform_search_hint = xy ]; then
	  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  19f1e309-4c00-46c2-a832-30fe4ac85b47
	else
	  search --no-floppy --fs-uuid --set=root 19f1e309-4c00-46c2-a832-30fe4ac85b47
	fi
	echo	'Loading Linux 5.10.0-3-amd64 ...'
	linux	/vmlinuz-5.10.0-3-amd64 root=UUID=2f82ed85-9840-4338-a5b2-71c735333ed9 ro  quiet
	echo	'Loading initial ramdisk ...'
	initrd	/initrd.img-5.10.0-3-amd64
}
submenu 'Advanced options for Debian GNU/Linux' $menuentry_id_option 'gnulinux-advanced-2f82ed85-9840-4338-a5b2-71c735333ed9' {
	menuentry 'Debian GNU/Linux, with Linux 5.10.0-3-amd64' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-5.10.0-3-amd64-advanced-2f82ed85-9840-4338-a5b2-71c735333ed9' {
		load_video
		insmod gzio
		if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
		insmod part_msdos
		insmod ext2
		set root='hd0,msdos1'
		if [ x$feature_platform_search_hint = xy ]; then
		  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  19f1e309-4c00-46c2-a832-30fe4ac85b47
		else
		  search --no-floppy --fs-uuid --set=root 19f1e309-4c00-46c2-a832-30fe4ac85b47
		fi
		echo	'Loading Linux 5.10.0-3-amd64 ...'
		linux	/vmlinuz-5.10.0-3-amd64 root=UUID=2f82ed85-9840-4338-a5b2-71c735333ed9 ro  quiet
		echo	'Loading initial ramdisk ...'
		initrd	/initrd.img-5.10.0-3-amd64
	}
	menuentry 'Debian GNU/Linux, with Linux 5.10.0-3-amd64 (recovery mode)' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-5.10.0-3-amd64-recovery-2f82ed85-9840-4338-a5b2-71c735333ed9' {
		load_video
		insmod gzio
		if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
		insmod part_msdos
		insmod ext2
		set root='hd0,msdos1'
		if [ x$feature_platform_search_hint = xy ]; then
		  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  19f1e309-4c00-46c2-a832-30fe4ac85b47
		else
		  search --no-floppy --fs-uuid --set=root 19f1e309-4c00-46c2-a832-30fe4ac85b47
		fi
		echo	'Loading Linux 5.10.0-3-amd64 ...'
		linux	/vmlinuz-5.10.0-3-amd64 root=UUID=2f82ed85-9840-4338-a5b2-71c735333ed9 ro single 
		echo	'Loading initial ramdisk ...'
		initrd	/initrd.img-5.10.0-3-amd64
	}
	menuentry 'Debian GNU/Linux, with Linux 5.9.0-5-amd64' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-5.9.0-5-amd64-advanced-2f82ed85-9840-4338-a5b2-71c735333ed9' {
		load_video
		insmod gzio
		if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
		insmod part_msdos
		insmod ext2
		set root='hd0,msdos1'
		if [ x$feature_platform_search_hint = xy ]; then
		  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  19f1e309-4c00-46c2-a832-30fe4ac85b47
		else
		  search --no-floppy --fs-uuid --set=root 19f1e309-4c00-46c2-a832-30fe4ac85b47
		fi
		echo	'Loading Linux 5.9.0-5-amd64 ...'
		linux	/vmlinuz-5.9.0-5-amd64 root=UUID=2f82ed85-9840-4338-a5b2-71c735333ed9 ro  quiet
		echo	'Loading initial ramdisk ...'
		initrd	/initrd.img-5.9.0-5-amd64
	}
	menuentry 'Debian GNU/Linux, with Linux 5.9.0-5-amd64 (recovery mode)' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-5.9.0-5-amd64-recovery-2f82ed85-9840-4338-a5b2-71c735333ed9' {
		load_video
		insmod gzio
		if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
		insmod part_msdos
		insmod ext2
		set root='hd0,msdos1'
		if [ x$feature_platform_search_hint = xy ]; then
		  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  19f1e309-4c00-46c2-a832-30fe4ac85b47
		else
		  search --no-floppy --fs-uuid --set=root 19f1e309-4c00-46c2-a832-30fe4ac85b47
		fi
		echo	'Loading Linux 5.9.0-5-amd64 ...'
		linux	/vmlinuz-5.9.0-5-amd64 root=UUID=2f82ed85-9840-4338-a5b2-71c735333ed9 ro single 
		echo	'Loading initial ramdisk ...'
		initrd	/initrd.img-5.9.0-5-amd64
	}
}

### END /etc/grub.d/10_linux ###

### BEGIN /etc/grub.d/20_linux_xen ###

### END /etc/grub.d/20_linux_xen ###

### BEGIN /etc/grub.d/30_os-prober ###
### END /etc/grub.d/30_os-prober ###

### BEGIN /etc/grub.d/30_uefi-firmware ###
### END /etc/grub.d/30_uefi-firmware ###

### BEGIN /etc/grub.d/40_custom ###
# This file provides an easy way to add custom menu entries.  Simply type the
# menu entries you want to add after this comment.  Be careful not to change
# the 'exec tail' line above.
### END /etc/grub.d/40_custom ###

### BEGIN /etc/grub.d/41_custom ###
if [ -f  ${config_directory}/custom.cfg ]; then
  source ${config_directory}/custom.cfg
elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
  source $prefix/custom.cfg;
fi
### END /etc/grub.d/41_custom ###
*********************** END /boot/grub/grub.cfg

*********************** BEGIN /proc/mdstat
cat: /proc/mdstat: No such file or directory
*********************** END /proc/mdstat

*********************** BEGIN /dev/disk/by-id
total 0
lrwxrwxrwx 1 root root  9 Mar  2 10:01 ata-Samsung_SSD_750_EVO_250GB_S2SHNWAH533455F -> ../../sda
lrwxrwxrwx 1 root root 10 Mar  2 10:01 ata-Samsung_SSD_750_EVO_250GB_S2SHNWAH533455F-part1 -> ../../sda1
lrwxrwxrwx 1 root root 10 Mar  2 10:01 ata-Samsung_SSD_750_EVO_250GB_S2SHNWAH533455F-part2 -> ../../sda2
lrwxrwxrwx 1 root root 10 Mar  2 10:01 ata-Samsung_SSD_750_EVO_250GB_S2SHNWAH533455F-part3 -> ../../sda3
lrwxrwxrwx 1 root root  9 Mar  2 10:01 ata-WDC_WD80EFZX-68UW8N0_R6GLEWGY -> ../../sdb
lrwxrwxrwx 1 root root 10 Mar  2 10:01 ata-WDC_WD80EFZX-68UW8N0_R6GLEWGY-part1 -> ../../sdb1
lrwxrwxrwx 1 root root  9 Mar  2 10:01 wwn-0x5000cca263c862ce -> ../../sdb
lrwxrwxrwx 1 root root 10 Mar  2 10:01 wwn-0x5000cca263c862ce-part1 -> ../../sdb1
lrwxrwxrwx 1 root root  9 Mar  2 10:01 wwn-0x5002538d701ecaa2 -> ../../sda
lrwxrwxrwx 1 root root 10 Mar  2 10:01 wwn-0x5002538d701ecaa2-part1 -> ../../sda1
lrwxrwxrwx 1 root root 10 Mar  2 10:01 wwn-0x5002538d701ecaa2-part2 -> ../../sda2
lrwxrwxrwx 1 root root 10 Mar  2 10:01 wwn-0x5002538d701ecaa2-part3 -> ../../sda3
*********************** END /dev/disk/by-id

*********************** BEGIN /dev/disk/by-uuid
total 0
lrwxrwxrwx 1 root root 10 Mar  2 10:01 19f1e309-4c00-46c2-a832-30fe4ac85b47 -> ../../sda1
lrwxrwxrwx 1 root root 10 Mar  2 10:01 2f82ed85-9840-4338-a5b2-71c735333ed9 -> ../../sda2
lrwxrwxrwx 1 root root 10 Mar  2 10:01 581cac7e-bbc7-426f-b684-4aed93f27985 -> ../../sdb1
lrwxrwxrwx 1 root root 10 Mar  2 10:01 5e7c5c37-5d92-4977-87d5-71e1ad12853a -> ../../sda3
*********************** END /dev/disk/by-uuid

-- System Information:
Debian Release: bullseye/sid
  APT prefers testing
  APT policy: (990, 'testing'), (500, 'unstable')
Architecture: amd64 (x86_64)

Kernel: Linux 5.10.0-3-amd64 (SMP w/4 CPU threads)
Locale: LANG=en_US.UTF-8, LC_CTYPE=en_US.UTF-8 (charmap=UTF-8), LANGUAGE=en_US:en
Shell: /bin/sh linked to /usr/bin/dash
Init: systemd (via /run/systemd/system)
LSM: AppArmor: enabled

Versions of packages grub-pc depends on:
ii  debconf [debconf-2.0]  1.5.74
ii  grub-common            2.04-15
ii  grub-pc-bin            2.04-15
ii  grub2-common           2.04-15
ii  ucf                    3.0043

grub-pc recommends no packages.

grub-pc suggests no packages.

-- debconf information:
  grub-pc/chainload_from_menu.lst: true
* grub-pc/install_devices: /dev/disk/by-id/ata-Samsung_SSD_750_EVO_250GB_S2SHNWAH533455F
  grub-pc/partition_description:
  grub-pc/postrm_purge_boot_grub: false
  grub-pc/kopt_extracted: false
  grub2/kfreebsd_cmdline_default: quiet
  grub-pc/install_devices_failed_upgrade: true
  grub2/update_nvram: true
  grub-pc/timeout: 5
  grub-pc/install_devices_disks_changed:
  grub2/force_efi_extra_removable: false
  grub2/kfreebsd_cmdline:
  grub-pc/install_devices_failed: false
  grub-pc/mixed_legacy_and_grub2: true
* grub2/linux_cmdline_default: quiet
  grub-pc/install_devices_empty: false
  grub-pc/hidden_timeout: false
  grub-pc/disk_description:
* grub2/linux_cmdline:



More information about the Pkg-grub-devel mailing list