[PATCH v2 6/6] efi_loader: run bootdev_hunt() to find ESP
Heinrich Schuchardt
heinrich.schuchardt at canonical.com
Wed Nov 27 08:06:31 CET 2024
Some hard devices need specific routines to scan for block devices,
e.g. NVMe (nvme scan), SCSI (scsi start).
Invoke bootdev_hunt() to find all block devices.
Reviewed-by: Ilias Apalodimas <ilias.apalodimas at linaro.org>
Reviewed-by: Simon Glass <sjg at chromium.org>
Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
---
v2:
no change
---
cmd/bootmenu.c | 39 +++++++++++++++++++++++++++++---------
doc/usage/cmd/bootmenu.rst | 13 ++++++++++---
2 files changed, 40 insertions(+), 12 deletions(-)
diff --git a/cmd/bootmenu.c b/cmd/bootmenu.c
index ffa63a4628d..90f4f3d583c 100644
--- a/cmd/bootmenu.c
+++ b/cmd/bootmenu.c
@@ -330,7 +330,13 @@ static int prepare_uefi_bootorder_entry(struct bootmenu_data *menu,
}
#endif
-static struct bootmenu_data *bootmenu_create(int delay)
+/**
+ * bootmenu_create() - create boot menu entries
+ *
+ * @uefi: consider UEFI boot options
+ * @delay: autostart delay in seconds
+ */
+static struct bootmenu_data *bootmenu_create(int uefi, int delay)
{
int ret;
unsigned short int i = 0;
@@ -357,7 +363,7 @@ static struct bootmenu_data *bootmenu_create(int delay)
goto cleanup;
#if (IS_ENABLED(CONFIG_CMD_BOOTEFI_BOOTMGR)) && (IS_ENABLED(CONFIG_CMD_EFICONFIG))
- if (i < MAX_COUNT - 1) {
+ if (uefi && i < MAX_COUNT - 1) {
efi_status_t efi_ret;
lib/efi_loader/efi_setup.c | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/lib/efi_loader/efi_setup.c b/lib/efi_loader/efi_setup.c
index aa59bc7779d..8e0ff16f3eb 100644
--- a/lib/efi_loader/efi_setup.c
+++ b/lib/efi_loader/efi_setup.c
@@ -7,6 +7,7 @@
#define LOG_CATEGORY LOGC_EFI
+#include <bootdev.h>
#include <efi_loader.h>
#include <efi_variable.h>
#include <log.h>
@@ -228,6 +229,13 @@ efi_status_t efi_init_obj_list(void)
* Probe block devices to find the ESP.
* efi_disks_register() must be called before efi_init_variables().
*/
+ if (CONFIG_IS_ENABLED(BOOTSTD)) {
+ int r;
+
+ r = bootdev_hunt(NULL, 0);
+ if (r)
+ log_debug("No boot device available\n");
+ }
ret = efi_disks_register();
if (ret != EFI_SUCCESS)
goto out;
--
2.45.2
More information about the U-Boot
mailing list