[U-Boot] [PATCH 12/23] efi_loader: implement OpenProtocolInformation
Heinrich Schuchardt
xypron.glpk at gmx.de
Thu Aug 31 17:39:11 UTC 2017
On 08/31/2017 02:51 PM, Simon Glass wrote:
> Hi Heinrich,
>
> On 27 August 2017 at 06:53, Heinrich Schuchardt <xypron.glpk at gmx.de> wrote:
>> efi_open_protocol_information provides the agent and controller
>> handles as well as the attributes and open count of an protocol
>> on a handle.
>>
>> Cc: Rob Clark <robdclark at gmail.com>
>> Signed-off-by: Heinrich Schuchardt <xypron.glpk at gmx.de>
>> ---
>> lib/efi_loader/efi_boottime.c | 55 ++++++++++++++++++++++++++++++++++++++++++-
>> 1 file changed, 54 insertions(+), 1 deletion(-)
>
> Reviewed-by: Simon Glass <sjg at chromium.org>
>
> I can't help wondering if this would be better as a linked list?
This is an API function. The interface of the function has to be kept
the way it is.
Internally we could use other storage models.
Best regards
Heinrich
>
>>
>> diff --git a/lib/efi_loader/efi_boottime.c b/lib/efi_loader/efi_boottime.c
>> index c9aec597a2..23b8894e73 100644
>> --- a/lib/efi_loader/efi_boottime.c
>> +++ b/lib/efi_loader/efi_boottime.c
>> @@ -985,9 +985,62 @@ static efi_status_t EFIAPI efi_open_protocol_information(efi_handle_t handle,
>> struct efi_open_protocol_info_entry **entry_buffer,
>> unsigned long *entry_count)
>> {
>> + unsigned long buffer_size;
>> + unsigned long count;
>> + struct efi_handler *handler;
>> + size_t i;
>> + efi_status_t r;
>> +
>> EFI_ENTRY("%p, %p, %p, %p", handle, protocol, entry_buffer,
>> entry_count);
>> - return EFI_EXIT(EFI_NOT_FOUND);
>> +
>> + /* Check parameters */
>> + if (!handle || !protocol || !entry_buffer) {
>> + r = EFI_INVALID_PARAMETER;
>> + goto out;
>> + }
>> +
>> + /* Find the protocol */
>> + r = efi_search_protocol(handle, protocol, &handler);
>> + if (r != EFI_SUCCESS)
>> + goto out;
>> +
>> + *entry_buffer = NULL;
>> +
>> + /* Count entries */
>> + count = 0;
>> + for (i = 0; i < ARRAY_SIZE(handler->open_info); ++i) {
>> + struct efi_open_protocol_info_entry *open_info =
>> + &handler->open_info[i];
>> +
>> + if (open_info->open_count)
>> + ++count;
>> + }
>> + *entry_count = count;
>> + if (!count) {
>> + r = EFI_SUCCESS;
>> + goto out;
>> + }
>> +
>> + /* Copy entries */
>> + buffer_size = count * sizeof(struct efi_open_protocol_info_entry);
>> + r = efi_allocate_pool(EFI_ALLOCATE_ANY_PAGES, buffer_size,
>> + (void **)entry_buffer);
>> + if (r != EFI_SUCCESS)
>> + goto out;
>> + count = 0;
>> + for (i = 0; i < ARRAY_SIZE(handler->open_info); ++i) {
>> + struct efi_open_protocol_info_entry *open_info =
>> + &handler->open_info[i];
>> +
>> + if (!open_info->open_count)
>> + continue;
>> + (*entry_buffer)[count] = *open_info;
>> + ++count;
>> + }
>> +
>> +out:
>> + return EFI_EXIT(r);
>> }
>>
>> static efi_status_t EFIAPI efi_protocols_per_handle(void *handle,
>> --
>> 2.14.1
>>
>
More information about the U-Boot
mailing list