5d7e454
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
5d7e454
From: Javier Martinez Canillas <javierm@redhat.com>
5d7e454
Date: Tue, 26 Feb 2019 20:11:27 +0100
5d7e454
Subject: [PATCH] blscfg: fallback to default_kernelopts if BLS option field
5d7e454
 isn't set
5d7e454
5d7e454
If the $kernelopts variable isn't found, then the entry will fail to boot
5d7e454
since there won't be a kernel command line params set. This makes the BLS
5d7e454
configuration more fragile than a non-BLS one, since in that case it will
5d7e454
boot even without a correct grubenv file.
5d7e454
5d7e454
So set a $default_kernelopts in the GRUB config file that will be used as
5d7e454
a fallback if the value in the BLS options field can't be resolved.
5d7e454
5d7e454
Related: rhbz#1625124
5d7e454
5d7e454
Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
5d7e454
---
5d7e454
 grub-core/commands/blscfg.c | 7 +++++++
5d7e454
 util/grub.d/10_linux.in     | 2 ++
5d7e454
 2 files changed, 9 insertions(+)
5d7e454
5d7e454
diff --git a/grub-core/commands/blscfg.c b/grub-core/commands/blscfg.c
5d7e454
index 1ef2ae06cff..5635066e3eb 100644
5d7e454
--- a/grub-core/commands/blscfg.c
5d7e454
+++ b/grub-core/commands/blscfg.c
5d7e454
@@ -629,6 +629,9 @@ static char *expand_val(char *value)
5d7e454
   char *end = value;
5d7e454
   bool is_var = false;
5d7e454
 
5d7e454
+  if (!value)
5d7e454
+    return NULL;
5d7e454
+
5d7e454
   while (*value) {
5d7e454
     if (*value == '$') {
5d7e454
       if (start != end) {
5d7e454
@@ -732,6 +735,10 @@ static void create_entry (struct bls_entry *entry)
5d7e454
 
5d7e454
   title = bls_get_val (entry, "title", NULL);
5d7e454
   options = expand_val (bls_get_val (entry, "options", NULL));
5d7e454
+
5d7e454
+  if (!options)
5d7e454
+    options = expand_val (grub_env_get("default_kernelopts"));
5d7e454
+
5d7e454
   initrds = bls_make_list (entry, "initrd", NULL);
5d7e454
 
5d7e454
   hotkey = bls_get_val (entry, "grub_hotkey", NULL);
5d7e454
diff --git a/util/grub.d/10_linux.in b/util/grub.d/10_linux.in
5d7e454
index 22a85c69ea0..2547dd52115 100644
5d7e454
--- a/util/grub.d/10_linux.in
5d7e454
+++ b/util/grub.d/10_linux.in
5d7e454
@@ -158,6 +158,8 @@ linux_entry ()
5d7e454
     populate_header_warn
5d7e454
 
5d7e454
     cat << EOF
5d7e454
+set default_kernelopts="root=${linux_root_device_thisversion} ro ${args}"
5d7e454
+
5d7e454
 insmod blscfg
5d7e454
 blscfg
5d7e454
 if [ -s \$prefix/grubenv ]; then