[PATCH v9 6/9] efi_loader: add return to efibootmgr event group
Ilias Apalodimas
ilias.apalodimas at linaro.org
Thu Nov 2 10:34:03 CET 2023
On Thu, 2 Nov 2023 at 08:46, Masahisa Kojima <masahisa.kojima at linaro.org> wrote:
>
> When the image loaded by efibootmgr returns, efibootmgr
> needs to clean the resources. Adding the event of returning
> to efibootmgr is useful to simplify the implementation.
>
> Signed-off-by: Masahisa Kojima <masahisa.kojima at linaro.org>
> ---
> cmd/bootefi.c | 12 ++++++++++++
> include/efi_api.h | 3 +++
> include/efi_loader.h | 2 ++
> lib/efi_loader/efi_boottime.c | 3 +++
> 4 files changed, 20 insertions(+)
>
> diff --git a/cmd/bootefi.c b/cmd/bootefi.c
> index 20e5c94a33..4d74969ad6 100644
> --- a/cmd/bootefi.c
> +++ b/cmd/bootefi.c
> @@ -356,6 +356,7 @@ static efi_status_t do_bootefi_exec(efi_handle_t handle, void *load_options)
> efi_status_t ret;
> efi_uintn_t exit_data_size = 0;
> u16 *exit_data = NULL;
> + struct efi_event *evt;
>
> /* On ARM switch from EL3 or secure mode to EL2 or non-secure mode */
> switch_to_non_secure_mode();
> @@ -394,6 +395,17 @@ out:
> log_err("Failed to remove loadfile2 for initrd\n");
> }
>
> + /* Notify EFI_EVENT_GROUP_RETURN_TO_EFIBOOTMGR event group. */
> + list_for_each_entry(evt, &efi_events, link) {
> + if (evt->group &&
> + !guidcmp(evt->group,
> + &efi_guid_event_group_return_to_efibootmgr)) {
> + efi_signal_event(evt);
> + EFI_CALL(systab.boottime->close_event(evt));
> + break;
> + }
> + }
> +
> /* Control is returned to U-Boot, disable EFI watchdog */
> efi_set_watchdog(0);
>
> diff --git a/include/efi_api.h b/include/efi_api.h
> index c2d6964467..0e92cb8a7f 100644
> --- a/include/efi_api.h
> +++ b/include/efi_api.h
> @@ -404,6 +404,9 @@ struct efi_runtime_services {
> #define EFI_EVENT_GROUP_RESET_SYSTEM \
> EFI_GUID(0x62da6a56, 0x13fb, 0x485a, 0xa8, 0xda, \
> 0xa3, 0xdd, 0x79, 0x12, 0xcb, 0x6b)
> +#define EFI_EVENT_GROUP_RETURN_TO_EFIBOOTMGR \
> + EFI_GUID(0xb4a40fe6, 0x9149, 0x4f29, 0x94, 0x47, \
> + 0x49, 0x38, 0x7a, 0x7f, 0xab, 0x87)
>
> /* EFI Configuration Table and GUID definitions */
> #define NULL_GUID \
> diff --git a/include/efi_loader.h b/include/efi_loader.h
> index e164e6067d..31954e84c3 100644
> --- a/include/efi_loader.h
> +++ b/include/efi_loader.h
> @@ -290,6 +290,8 @@ extern const efi_guid_t efi_guid_event_group_memory_map_change;
> extern const efi_guid_t efi_guid_event_group_ready_to_boot;
> /* event group ResetSystem() invoked (before ExitBootServices) */
> extern const efi_guid_t efi_guid_event_group_reset_system;
> +/* event group return to efibootmgr */
> +extern const efi_guid_t efi_guid_event_group_return_to_efibootmgr;
> /* GUID of the device tree table */
> extern const efi_guid_t efi_guid_fdt;
> extern const efi_guid_t efi_guid_loaded_image;
> diff --git a/lib/efi_loader/efi_boottime.c b/lib/efi_loader/efi_boottime.c
> index f9b10a9763..3767fa2db4 100644
> --- a/lib/efi_loader/efi_boottime.c
> +++ b/lib/efi_loader/efi_boottime.c
> @@ -90,6 +90,9 @@ const efi_guid_t efi_guid_event_group_ready_to_boot =
> /* event group ResetSystem() invoked (before ExitBootServices) */
> const efi_guid_t efi_guid_event_group_reset_system =
> EFI_EVENT_GROUP_RESET_SYSTEM;
> +/* event group return to efibootmgr */
> +const efi_guid_t efi_guid_event_group_return_to_efibootmgr =
> + EFI_EVENT_GROUP_RETURN_TO_EFIBOOTMGR;
> /* GUIDs of the Load File and Load File2 protocols */
> const efi_guid_t efi_guid_load_file_protocol = EFI_LOAD_FILE_PROTOCOL_GUID;
> const efi_guid_t efi_guid_load_file2_protocol = EFI_LOAD_FILE2_PROTOCOL_GUID;
> --
> 2.34.1
>
Now that we have the event we have touse it for loadfie2 in the future
Reviewed-by: Ilias Apalodimas <ilias.apalodimas at linaro.org>
More information about the U-Boot
mailing list