summaryrefslogtreecommitdiff
path: root/config/grub/default
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2025-01-12 13:45:00 +0000
committerLeah Rowe <leah@libreboot.org>2025-01-12 13:45:00 +0000
commit66d084e7f7cba7a38e43de5204f439dd4ed4255b (patch)
tree9b898ed13e1d238975bbd46cf584696912f7188c /config/grub/default
parent5a3b0dab9668bbdc96d2bcf7e541fe0d99035b98 (diff)
grub.cfg: scan luks *inside lvm*
the user might have boot their kernel inside luks inside lvm for some dumb reason it's theoretically possible that the user would be so silly indeed Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'config/grub/default')
-rw-r--r--config/grub/default/config/payload14
1 files changed, 14 insertions, 0 deletions
diff --git a/config/grub/default/config/payload b/config/grub/default/config/payload
index 91afcc7b..3f134f1d 100644
--- a/config/grub/default/config/payload
+++ b/config/grub/default/config/payload
@@ -178,15 +178,29 @@ menuentry 'Load Operating System (incl. fully encrypted disks) [o]' --hotkey='o
search_bootcfg crypto
+ lvmvol=""
+
# after cryptomount, lvm volumes might be available
# using * is slow on some machines, but we use it here,
# just once. in so doing, we find every lvm volume
for vol in (*); do
if regexp ^lvm/ $vol; then
+ lvmvol="${lvmvol} ${vol}"
try_bootcfg "${vol}"
fi
done
+ # user might have put luks inside lvm
+ set pager=0
+ echo "Attempting to unlock encrypted LVMs"
+ for vol in ${lvmvol}; do
+ cryptomount "$vol"
+ done
+ set pager=1
+ echo
+
+ search_bootcfg crypto
+
true # Prevent pager requiring to accept each line instead of whole screen
}