Source: grub-common
Severity: normal
X-Debbugs-Cc: [email protected]
On an UEFI system with LUKS2/argon2 encrypted root (/), LUKS1/PBKDF encrypted
boot (/boot) (and/via GRUB early crypto),
if desktop-base is installed (providing GRUB [emerald] theme),
mkconfig/05_debian_theme will cause GRUB to prompt to
unlock the LUKS2 device to load the theme background, which silently fails
(cryptomount: error: Invalid passphrase).
This causes GRUB to unnecessarily/annoyingly prompt twice for crypto
passphrases, though it seems a quick work-around at
the LUKS2/root partition prompt is to simply enter an empty phrase to jump to
the menu.
I understand LUKS2 GRUB support is a WIP; I do not know if this includes argon2
support. It would be great to avoid
this annoying prompt situation (e.g. by detecting LUKS2/argon2 on the
partition, or supporting the situation somehow;
preferrably still with a a single prompt in a manner similar to
cryptsetup-initramfs/KEYFILE_PATTERN and
crypttab/keyfile spec).
Thanks!
-- Package-specific info:
*********************** BEGIN /proc/mounts
/dev/mapper/root_crypt / ext4 rw,relatime,errors=remount-ro 0 0
/dev/mapper/boot_crypt /boot ext4 rw,relatime 0 0
/dev/nvme0n1p1 /boot/efi vfat
rw,relatime,fmask=0077,dmask=0077,codepage=437,iocharset=ascii,shortname=mixed,utf8,errors=remount-ro
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="0"
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_gpt
insmod cryptodisk
insmod luks2
insmod gcry_rijndael
insmod gcry_rijndael
insmod gcry_sha256
insmod ext2
cryptomount -u deadc0dedeadc0dedeadc0dedeadc0de
set root='cryptouuid/deadc0dedeadc0dedeadc0dedeadc0de'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root
--hint='cryptouuid/deadc0dedeadc0dedeadc0dedeadc0de'
d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3
else
search --no-floppy --fs-uuid --set=root d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3
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 ###
insmod part_gpt
insmod cryptodisk
insmod luks2
insmod gcry_rijndael
insmod gcry_rijndael
insmod gcry_sha256
insmod ext2
cryptomount -u deadc0dedeadc0dedeadc0dedeadc0de
set root='cryptouuid/deadc0dedeadc0dedeadc0dedeadc0de'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root
--hint='cryptouuid/deadc0dedeadc0dedeadc0dedeadc0de'
d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3
else
search --no-floppy --fs-uuid --set=root d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3
fi
insmod png
if background_image /usr/share/desktop-base/emerald-theme/grub/grub-16x9.png;
then
set color_normal=white/black
set color_highlight=black/white
else
set menu_color_normal=cyan/blue
set menu_color_highlight=white/blue
fi
### 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-d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3' {
load_video
insmod gzio
if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio; fi
insmod part_gpt
insmod cryptodisk
insmod luks
insmod gcry_rijndael
insmod gcry_rijndael
insmod gcry_sha512
insmod ext2
cryptomount -u baddbeefbaddbeefbaddbeefbaddbeef
set root='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root
--hint='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
else
search --no-floppy --fs-uuid --set=root
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
fi
echo 'Loading Linux 6.3.0-0-amd64 ...'
linux /vmlinuz-6.3.0-0-amd64
root=UUID=d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3 ro quiet
echo 'Loading initial ramdisk ...'
initrd /initrd.img-6.3.0-0-amd64
}
submenu 'Advanced options for Debian GNU/Linux' $menuentry_id_option
'gnulinux-advanced-d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3' {
menuentry 'Debian GNU/Linux, with Linux 6.3.0-0-amd64' --class debian
--class gnu-linux --class gnu --class os $menuentry_id_option
'gnulinux-6.3.0-0-amd64-advanced-d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3' {
load_video
insmod gzio
if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio;
fi
insmod part_gpt
insmod cryptodisk
insmod luks
insmod gcry_rijndael
insmod gcry_rijndael
insmod gcry_sha512
insmod ext2
cryptomount -u baddbeefbaddbeefbaddbeefbaddbeef
set root='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root
--hint='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
else
search --no-floppy --fs-uuid --set=root
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
fi
echo 'Loading Linux 6.3.0-0-amd64 ...'
linux /vmlinuz-6.3.0-0-amd64
root=UUID=d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3 ro quiet
echo 'Loading initial ramdisk ...'
initrd /initrd.img-6.3.0-0-amd64
}
menuentry 'Debian GNU/Linux, with Linux 6.3.0-0-amd64 (recovery mode)'
--class debian --class gnu-linux --class gnu --class os $menuentry_id_option
'gnulinux-6.3.0-0-amd64-recovery-d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3' {
load_video
insmod gzio
if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio;
fi
insmod part_gpt
insmod cryptodisk
insmod luks
insmod gcry_rijndael
insmod gcry_rijndael
insmod gcry_sha512
insmod ext2
cryptomount -u baddbeefbaddbeefbaddbeefbaddbeef
set root='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root
--hint='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
else
search --no-floppy --fs-uuid --set=root
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
fi
echo 'Loading Linux 6.3.0-0-amd64 ...'
linux /vmlinuz-6.3.0-0-amd64
root=UUID=d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3 ro single
echo 'Loading initial ramdisk ...'
initrd /initrd.img-6.3.0-0-amd64
}
menuentry 'Debian GNU/Linux, with Linux 6.1.0-9-amd64' --class debian
--class gnu-linux --class gnu --class os $menuentry_id_option
'gnulinux-6.1.0-9-amd64-advanced-d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3' {
load_video
insmod gzio
if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio;
fi
insmod part_gpt
insmod cryptodisk
insmod luks
insmod gcry_rijndael
insmod gcry_rijndael
insmod gcry_sha512
insmod ext2
cryptomount -u baddbeefbaddbeefbaddbeefbaddbeef
set root='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root
--hint='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
else
search --no-floppy --fs-uuid --set=root
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
fi
echo 'Loading Linux 6.1.0-9-amd64 ...'
linux /vmlinuz-6.1.0-9-amd64
root=UUID=d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3 ro quiet
echo 'Loading initial ramdisk ...'
initrd /initrd.img-6.1.0-9-amd64
}
menuentry 'Debian GNU/Linux, with Linux 6.1.0-9-amd64 (recovery mode)'
--class debian --class gnu-linux --class gnu --class os $menuentry_id_option
'gnulinux-6.1.0-9-amd64-recovery-d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3' {
load_video
insmod gzio
if [ x$grub_platform = xxen ]; then insmod xzio; insmod lzopio;
fi
insmod part_gpt
insmod cryptodisk
insmod luks
insmod gcry_rijndael
insmod gcry_rijndael
insmod gcry_sha512
insmod ext2
cryptomount -u baddbeefbaddbeefbaddbeefbaddbeef
set root='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
if [ x$feature_platform_search_hint = xy ]; then
search --no-floppy --fs-uuid --set=root
--hint='cryptouuid/baddbeefbaddbeefbaddbeefbaddbeef'
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
else
search --no-floppy --fs-uuid --set=root
b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f
fi
echo 'Loading Linux 6.1.0-9-amd64 ...'
linux /vmlinuz-6.1.0-9-amd64
root=UUID=d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3 ro single
echo 'Loading initial ramdisk ...'
initrd /initrd.img-6.1.0-9-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 ###
menuentry 'UEFI Firmware Settings' $menuentry_id_option 'uefi-firmware' {
fwsetup
}
### END /etc/grub.d/30_uefi-firmware ###
### BEGIN /etc/grub.d/35_fwupd ###
### END /etc/grub.d/35_fwupd ###
### 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 10 May 30 17:48 dm-name-boot_crypt -> ../../dm-1
lrwxrwxrwx 1 root root 10 May 30 17:48 dm-name-root_crypt -> ../../dm-0
lrwxrwxrwx 1 root root 10 May 30 17:48
dm-uuid-CRYPT-LUKS1-baddbeefbaddbeefbaddbeefbaddbeef-boot_crypt -> ../../dm-1
lrwxrwxrwx 1 root root 10 May 30 17:48
dm-uuid-CRYPT-LUKS2-deadc0dedeadc0dedeadc0dedeadc0de-root_crypt -> ../../dm-0
lrwxrwxrwx 1 root root 13 May 30 17:48 nvme -> ../../nvme0n1
lrwxrwxrwx 1 root root 15 May 30 17:48 nvme-part1 -> ../../nvme0n1p1
lrwxrwxrwx 1 root root 15 May 30 17:48 nvme-part2 -> ../../nvme0n1p2
lrwxrwxrwx 1 root root 15 May 30 17:48 nvme-part3 -> ../../nvme0n1p3
lrwxrwxrwx 1 root root 13 May 30 17:48 nvme-nvme.0000-00000001 -> ../../nvme0n1
lrwxrwxrwx 1 root root 15 May 30 17:48 nvme-nvme.0000-00000001-part1 ->
../../nvme0n1p1
lrwxrwxrwx 1 root root 15 May 30 17:48 nvme-nvme.0000-00000001-part2 ->
../../nvme0n1p2
lrwxrwxrwx 1 root root 15 May 30 17:48 nvme-nvme.0000-00000001-part3 ->
../../nvme0n1p3
*********************** END /dev/disk/by-id
*********************** BEGIN /dev/disk/by-uuid
total 0
lrwxrwxrwx 1 root root 15 May 30 17:48 baddbeef-badd-beef-badd-beefbaddbeef->
../../nvme0n1p2
lrwxrwxrwx 1 root root 15 May 30 17:48 deadc0de-dead-c0de-dead-c0dedeadc0de ->
../../nvme0n1p3
lrwxrwxrwx 1 root root 10 May 30 17:48 b4ddb33f-b4dd-b33f-b4dd-b33fb4ddb33f ->
../../dm-1
lrwxrwxrwx 1 root root 15 May 30 17:48 A5A5-A5A5 -> ../../nvme0n1p1
lrwxrwxrwx 1 root root 10 May 30 17:48 d34dc0d3-d34d-c0d3-d34d-c0d3d34dc0d3 ->
../../dm-0
*********************** END /dev/disk/by-uuid
-- System Information:
Debian Release: 12.0
APT prefers testing-security
APT policy: (500, 'testing-security'), (500, 'unstable'), (500, 'testing'),
(1, 'experimental')
Architecture: amd64 (x86_64)
Foreign Architectures: arm64, i386
Kernel: Linux 6.3.0-0-amd64 (SMP w/16 CPU threads; PREEMPT)
Locale: LANG=en_US.UTF-8, LC_CTYPE=en_US.UTF-8 (charmap=UTF-8), LANGUAGE not set
Shell: /bin/sh linked to /usr/bin/dash
Init: systemd (via /run/systemd/system)
LSM: AppArmor: enabled
-- no debconf information