You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
124 lines
3.7 KiB
124 lines
3.7 KiB
4 days ago
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Javier Martinez Canillas <javierm@redhat.com>
|
||
|
Date: Mon, 30 Aug 2021 12:31:18 +0200
|
||
|
Subject: [PATCH] normal/main: Discover the device to read the config from as a
|
||
|
fallback
|
||
|
|
||
|
The GRUB core.img is generated locally, when this is done the grub2-probe
|
||
|
tool figures out the device and partition that needs to be read to parse
|
||
|
the GRUB configuration file.
|
||
|
|
||
|
But in some cases the core.img can't be generated on the host and instead
|
||
|
has to be done at package build time. For example, if needs to get signed
|
||
|
with a key that's only available on the package building infrastructure.
|
||
|
|
||
|
If that's the case, the prefix variable won't have a device and partition
|
||
|
but only a directory path. So there's no way for GRUB to know from which
|
||
|
device has to read the configuration file.
|
||
|
|
||
|
To allow GRUB to continue working on that scenario, fallback to iterating
|
||
|
over all the available devices, if reading the config failed when using
|
||
|
the prefix and fw_path variables.
|
||
|
|
||
|
Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
|
||
|
---
|
||
|
grub-core/normal/main.c | 58 +++++++++++++++++++++++++++++++++++++++++++------
|
||
|
1 file changed, 51 insertions(+), 7 deletions(-)
|
||
|
|
||
|
diff --git a/grub-core/normal/main.c b/grub-core/normal/main.c
|
||
|
index 7de9e4c36d..8f5fd81003 100644
|
||
|
--- a/grub-core/normal/main.c
|
||
|
+++ b/grub-core/normal/main.c
|
||
|
@@ -337,18 +337,13 @@ grub_enter_normal_mode (const char *config)
|
||
|
}
|
||
|
|
||
|
static grub_err_t
|
||
|
-grub_try_normal (const char *variable)
|
||
|
+grub_try_normal_prefix (const char *prefix)
|
||
|
{
|
||
|
char *config;
|
||
|
- const char *prefix;
|
||
|
grub_err_t err = GRUB_ERR_FILE_NOT_FOUND;
|
||
|
const char *net_search_cfg;
|
||
|
int disable_net_search = 0;
|
||
|
|
||
|
- prefix = grub_env_get (variable);
|
||
|
- if (!prefix)
|
||
|
- return GRUB_ERR_FILE_NOT_FOUND;
|
||
|
-
|
||
|
net_search_cfg = grub_env_get ("feature_net_search_cfg");
|
||
|
if (net_search_cfg && net_search_cfg[0] == 'n')
|
||
|
disable_net_search = 1;
|
||
|
@@ -362,7 +357,7 @@ grub_try_normal (const char *variable)
|
||
|
config = grub_malloc (config_len);
|
||
|
|
||
|
if (! config)
|
||
|
- return GRUB_ERR_FILE_NOT_FOUND;
|
||
|
+ return err;
|
||
|
|
||
|
grub_snprintf (config, config_len, "%s/grub.cfg", prefix);
|
||
|
err = grub_net_search_config_file (config);
|
||
|
@@ -391,6 +386,53 @@ grub_try_normal (const char *variable)
|
||
|
return err;
|
||
|
}
|
||
|
|
||
|
+static int
|
||
|
+grub_try_normal_dev (const char *name, void *data)
|
||
|
+{
|
||
|
+ grub_err_t err;
|
||
|
+ const char *prefix = grub_xasprintf ("(%s)%s", name, (char *)data);
|
||
|
+
|
||
|
+ if (!prefix)
|
||
|
+ return 0;
|
||
|
+
|
||
|
+ err = grub_try_normal_prefix (prefix);
|
||
|
+ if (err == GRUB_ERR_NONE)
|
||
|
+ return 1;
|
||
|
+
|
||
|
+ return 0;
|
||
|
+}
|
||
|
+
|
||
|
+static grub_err_t
|
||
|
+grub_try_normal_discover (void)
|
||
|
+{
|
||
|
+ char *prefix = grub_env_get ("prefix");
|
||
|
+ grub_err_t err = GRUB_ERR_FILE_NOT_FOUND;
|
||
|
+
|
||
|
+ if (!prefix)
|
||
|
+ return err;
|
||
|
+
|
||
|
+ if (grub_device_iterate (grub_try_normal_dev, (void *)prefix))
|
||
|
+ return GRUB_ERR_NONE;
|
||
|
+
|
||
|
+ return err;
|
||
|
+}
|
||
|
+
|
||
|
+static grub_err_t
|
||
|
+grub_try_normal (const char *variable)
|
||
|
+{
|
||
|
+ grub_err_t err = GRUB_ERR_FILE_NOT_FOUND;
|
||
|
+ const char *prefix;
|
||
|
+
|
||
|
+ if (!variable)
|
||
|
+ return err;
|
||
|
+
|
||
|
+ prefix = grub_env_get (variable);
|
||
|
+ if (!prefix)
|
||
|
+ return err;
|
||
|
+
|
||
|
+ return grub_try_normal_prefix (prefix);
|
||
|
+}
|
||
|
+
|
||
|
/* Enter normal mode from rescue mode. */
|
||
|
static grub_err_t
|
||
|
grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
||
|
@@ -405,6 +447,8 @@ grub_cmd_normal (struct grub_command *cmd __attribute__ ((unused)),
|
||
|
err = grub_try_normal ("fw_path");
|
||
|
if (err == GRUB_ERR_FILE_NOT_FOUND)
|
||
|
err = grub_try_normal ("prefix");
|
||
|
+ if (err == GRUB_ERR_FILE_NOT_FOUND)
|
||
|
+ err = grub_try_normal_discover ();
|
||
|
if (err == GRUB_ERR_FILE_NOT_FOUND)
|
||
|
grub_enter_normal_mode (0);
|
||
|
}
|