[PATCH v2 09/11] efi_loader: move efi_main and command loop to efi_app_common

Simon Glass sjg at chromium.org
Thu Jun 25 10:54:34 CEST 2026


Hi Heinrich,

On 2026-06-21T08:19:04, Heinrich Schuchardt
<heinrich.schuchardt at canonical.com> wrote:
> efi_loader: move efi_main and command loop to efi_app_common
>
> Add the remaining shared code to efi_app_common to complete the
> refactoring:
>
> * efi_main() - common entry point; calls efi_app_init(), prints
>   app_banner, calls command_loop(), then clears the screen on exit.
> * struct efi_app_cmd - table entry holding the keyword, help text,
>   and a handler of type void (*fn)(u16 *args).
> * command_loop() - iterates app_cmds[], matches keywords with
>   starts_with(), and falls back to efi_app_help() on no match.
> * efi_app_help() - prints each table entry's help line plus the
>   built-in 'exit' line.
>
> Each dump app is updated accordingly:
> * efi_main is removed; command_loop becomes non-static.
> * app_banner[] is defined at file scope with the application's
>   title string.
> * Per-app duplicate state (bs, handle, systable) is removed; apps
>   now use the common module's state.
> [...]
>
> lib/efi_loader/dbginfodump.c    |  95 +++++-------------------------
>  lib/efi_loader/dtbdump.c        | 109 +++++++---------------------------
>  lib/efi_loader/efi_app_common.c | 111 ++++++++++++++++++++++++++++++++++-
>  lib/efi_loader/efi_app_common.h |  31 +++++-----
>  lib/efi_loader/initrddump.c     |  91 +++++------------------------
>  lib/efi_loader/smbiosdump.c     | 126 ++++++++--------------------------------
>  6 files changed, 205 insertions(+), 358 deletions(-)

> diff --git a/lib/efi_loader/efi_app_common.c b/lib/efi_loader/efi_app_common.c
> @@ -304,3 +317,99 @@ efi_status_t save_file(u16 *filename, void *buf, efi_uintn_t size)
> +extern u16 app_banner[];
> +extern struct efi_app_cmd app_cmds[];

Please move these extern declarations into efi_app_common.h next to
struct efi_app_cmd - inline externs in the .c file hide the contract
that every consumer must define both symbols; putting them in the
header makes the interface explicit and lets the compiler catch type
mismatches.

> diff --git a/lib/efi_loader/dbginfodump.c b/lib/efi_loader/dbginfodump.c
> @@ -118,20 +99,27 @@ static void print_info(struct efi_loaded_image *info)
> -static efi_status_t do_dump(void)
> +static void do_dump(u16 * __maybe_unused args)
>  {
>       struct dbg_info_header *dbg;
> +
> +     if (!device_path_to_text)
> +             bs->locate_protocol(&guid_device_path_to_text_protocol, NULL,
> +                                  (void **)&device_path_to_text);
> +
>       u32 count;

Declarations should be at the top of the block; u32 count lands after
the locate_protocol() call. Also, the locate_protocol() return value
is now ignored, so a permanent failure silently leaves
device_path_to_text NULL with no diagnostic; the previous code printed
'No device path to text protocol' on error. Please restore that or at
least check the return.

> diff --git a/lib/efi_loader/dbginfodump.c b/lib/efi_loader/dbginfodump.c
> @@ -164,60 +152,9 @@ static efi_status_t do_dump(void)
>               print(u'\r\n');
>       }
>
> -     return EFI_SUCCESS;
>  }

Stray blank line before the closing brace.

> diff --git a/lib/efi_loader/smbiosdump.c b/lib/efi_loader/smbiosdump.c
> @@ -156,16 +143,13 @@ static efi_status_t do_save(u16 *filename)
> -     ret = do_check();
> -     if (ret != EFI_SUCCESS)
> -             return ret;
> -
>       smbios3_anchor = get_config_table(&smbios3_guid);

Behaviour change not mentioned in the commit message: previously
'save' refused to write a malformed table because it ran do_check()
first; now it happily writes whatever is there. If intentional, please
call it out; otherwise restore the check.

> diff --git a/lib/efi_loader/efi_app_common.c b/lib/efi_loader/efi_app_common.c
> @@ -304,3 +317,99 @@ efi_status_t save_file(u16 *filename, void *buf, efi_uintn_t size)
> +                     for (cmd = app_cmds; cmd->fn; ++cmd) {
> +                             if (starts_with(pos, (u16 *)cmd->cmd)) {
> +                                     efi_uintn_t len;
> +
> +                                     for (len = 0; cmd->cmd[len]; ++len)
> +                                             ;

Isn't there a u16 strlen-style helper that exists here? Also,
cmd->cmd[len - 1] below assumes len > 0; an empty keyword would
underflow. Worth an assertion or comment documenting the invariant.

> diff --git a/lib/efi_loader/dbginfodump.c b/lib/efi_loader/dbginfodump.c
> @@ -0,0 +0,0 @@
> +struct efi_app_cmd app_cmds[] = {
> +     { u'dump', u"dump - print debug info table\r\n", do_dump },
> +     { }
> +};

The original help text column-aligned the dash ('dump       - print
...') across all apps. With the new table the dash sits right after
the keyword, so 'load' and 'save <initrd>' no longer line up in
initrddump, and likewise for dtbdump/smbiosdump. Easy to restore by
padding the help strings.

Regards,
Simon


More information about the U-Boot mailing list