[U-Boot] [PATCH 17/18] efi_loader: refactor efi_setup_loaded_image
Alexander Graf
agraf at suse.de
Wed Nov 8 15:18:15 UTC 2017
On 10/26/2017 07:25 PM, Heinrich Schuchardt wrote:
> Use helper functions to add protocols.
>
> Signed-off-by: Heinrich Schuchardt <xypron.glpk at gmx.de>
> ---
> lib/efi_loader/efi_boottime.c | 39 +++++++++++++++++++++++++--------------
> 1 file changed, 25 insertions(+), 14 deletions(-)
>
> diff --git a/lib/efi_loader/efi_boottime.c b/lib/efi_loader/efi_boottime.c
> index a526280e4c..3f23e6d638 100644
> --- a/lib/efi_loader/efi_boottime.c
> +++ b/lib/efi_loader/efi_boottime.c
> @@ -1193,34 +1193,45 @@ void efi_setup_loaded_image(struct efi_loaded_image *info, struct efi_object *ob
> struct efi_device_path *device_path,
> struct efi_device_path *file_path)
> {
> + efi_status_t ret;
> +
> obj->handle = info;
>
> + info->file_path = file_path;
> + if (device_path)
> + info->device_handle = efi_dp_find_obj(device_path, NULL);
> +
> + list_add_tail(&obj->link, &efi_obj_list);
> /*
> * When asking for the device path interface, return
> * bootefi_device_path
> */
> - obj->protocols[0].guid = &efi_guid_device_path;
> - obj->protocols[0].protocol_interface = device_path;
> + ret = efi_add_protocol(obj->handle, &efi_guid_device_path, device_path);
Can we always assume that there are no other protocols installed
already? The current code simply overrides them if there are any.
Alex
> + if (ret != EFI_SUCCESS)
> + goto failure;
>
> /*
> * When asking for the loaded_image interface, just
> * return handle which points to loaded_image_info
> */
> - obj->protocols[1].guid = &efi_guid_loaded_image;
> - obj->protocols[1].protocol_interface = info;
> -
> - obj->protocols[2].guid = &efi_guid_console_control;
> - obj->protocols[2].protocol_interface = (void *)&efi_console_control;
> + ret = efi_add_protocol(obj->handle, &efi_guid_loaded_image, info);
> + if (ret != EFI_SUCCESS)
> + goto failure;
>
> - obj->protocols[3].guid = &efi_guid_device_path_to_text_protocol;
> - obj->protocols[3].protocol_interface =
> - (void *)&efi_device_path_to_text;
> + ret = efi_add_protocol(obj->handle, &efi_guid_console_control,
> + (void *)&efi_console_control);
> + if (ret != EFI_SUCCESS)
> + goto failure;
>
> - info->file_path = file_path;
> - if (device_path)
> - info->device_handle = efi_dp_find_obj(device_path, NULL);
> + ret = efi_add_protocol(obj->handle,
> + &efi_guid_device_path_to_text_protocol,
> + (void *)&efi_device_path_to_text);
> + if (ret != EFI_SUCCESS)
> + goto failure;
>
> - list_add_tail(&obj->link, &efi_obj_list);
> + return;
> +failure:
> + printf("ERROR: Failure to install protocols for loaded image\n");
> }
>
> /*
More information about the U-Boot
mailing list