efi_loader: provide function comments for boot services
Provide comments describing the boot service functions. Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de> Signed-off-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
parent
e67e7249c8
commit
332468f7fc
@ -161,6 +161,19 @@ static u64 efi_div10(u64 a)
|
||||
return ret;
|
||||
}
|
||||
|
||||
/*
|
||||
* Queue an EFI event.
|
||||
*
|
||||
* This function queues the notification function of the event for future
|
||||
* execution.
|
||||
*
|
||||
* The notification function is called if the task priority level of the
|
||||
* event is higher than the current task priority level.
|
||||
*
|
||||
* For the SignalEvent service see efi_signal_event_ext.
|
||||
*
|
||||
* @event event to signal
|
||||
*/
|
||||
void efi_signal_event(struct efi_event *event)
|
||||
{
|
||||
if (event->notify_function) {
|
||||
@ -174,12 +187,28 @@ void efi_signal_event(struct efi_event *event)
|
||||
event->is_queued = false;
|
||||
}
|
||||
|
||||
/*
|
||||
* Write a debug message for an EPI API service that is not implemented yet.
|
||||
*
|
||||
* @funcname function that is not yet implemented
|
||||
* @return EFI_UNSUPPORTED
|
||||
*/
|
||||
static efi_status_t efi_unsupported(const char *funcname)
|
||||
{
|
||||
debug("EFI: App called into unimplemented function %s\n", funcname);
|
||||
return EFI_EXIT(EFI_UNSUPPORTED);
|
||||
}
|
||||
|
||||
/*
|
||||
* Raise the task priority level.
|
||||
*
|
||||
* This function implements the RaiseTpl service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @new_tpl new value of the task priority level
|
||||
* @return old value of the task priority level
|
||||
*/
|
||||
static unsigned long EFIAPI efi_raise_tpl(UINTN new_tpl)
|
||||
{
|
||||
UINTN old_tpl = efi_tpl;
|
||||
@ -196,6 +225,15 @@ static unsigned long EFIAPI efi_raise_tpl(UINTN new_tpl)
|
||||
return old_tpl;
|
||||
}
|
||||
|
||||
/*
|
||||
* Lower the task priority level.
|
||||
*
|
||||
* This function implements the RestoreTpl service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @old_tpl value of the task priority level to be restored
|
||||
*/
|
||||
static void EFIAPI efi_restore_tpl(UINTN old_tpl)
|
||||
{
|
||||
EFI_ENTRY("0x%zx", old_tpl);
|
||||
@ -209,6 +247,19 @@ static void EFIAPI efi_restore_tpl(UINTN old_tpl)
|
||||
EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Allocate memory pages.
|
||||
*
|
||||
* This function implements the AllocatePages service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @type type of allocation to be performed
|
||||
* @memory_type usage type of the allocated memory
|
||||
* @pages number of pages to be allocated
|
||||
* @memory allocated memory
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_allocate_pages_ext(int type, int memory_type,
|
||||
unsigned long pages,
|
||||
uint64_t *memory)
|
||||
@ -220,6 +271,17 @@ static efi_status_t EFIAPI efi_allocate_pages_ext(int type, int memory_type,
|
||||
return EFI_EXIT(r);
|
||||
}
|
||||
|
||||
/*
|
||||
* Free memory pages.
|
||||
*
|
||||
* This function implements the FreePages service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @memory start of the memory area to be freed
|
||||
* @pages number of pages to be freed
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_free_pages_ext(uint64_t memory,
|
||||
unsigned long pages)
|
||||
{
|
||||
@ -230,6 +292,21 @@ static efi_status_t EFIAPI efi_free_pages_ext(uint64_t memory,
|
||||
return EFI_EXIT(r);
|
||||
}
|
||||
|
||||
/*
|
||||
* Get map describing memory usage.
|
||||
*
|
||||
* This function implements the GetMemoryMap service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @memory_map_size on entry the size, in bytes, of the memory map buffer,
|
||||
* on exit the size of the copied memory map
|
||||
* @memory_map buffer to which the memory map is written
|
||||
* @map_key key for the memory map
|
||||
* @descriptor_size size of an individual memory descriptor
|
||||
* @descriptor_version version number of the memory descriptor structure
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_get_memory_map_ext(
|
||||
unsigned long *memory_map_size,
|
||||
struct efi_mem_desc *memory_map,
|
||||
@ -246,6 +323,18 @@ static efi_status_t EFIAPI efi_get_memory_map_ext(
|
||||
return EFI_EXIT(r);
|
||||
}
|
||||
|
||||
/*
|
||||
* Allocate memory from pool.
|
||||
*
|
||||
* This function implements the AllocatePool service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @pool_type type of the pool from which memory is to be allocated
|
||||
* @size number of bytes to be allocated
|
||||
* @buffer allocated memory
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_allocate_pool_ext(int pool_type,
|
||||
unsigned long size,
|
||||
void **buffer)
|
||||
@ -257,6 +346,16 @@ static efi_status_t EFIAPI efi_allocate_pool_ext(int pool_type,
|
||||
return EFI_EXIT(r);
|
||||
}
|
||||
|
||||
/*
|
||||
* Free memory from pool.
|
||||
*
|
||||
* This function implements the FreePool service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @buffer start of memory to be freed
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_free_pool_ext(void *buffer)
|
||||
{
|
||||
efi_status_t r;
|
||||
@ -289,6 +388,21 @@ static efi_status_t efi_create_handle(void **handle)
|
||||
*/
|
||||
static struct efi_event efi_events[16];
|
||||
|
||||
/*
|
||||
* Create an event.
|
||||
*
|
||||
* This function is used inside U-Boot code to create an event.
|
||||
*
|
||||
* For the API function implementing the CreateEvent service see
|
||||
* efi_create_event_ext.
|
||||
*
|
||||
* @type type of the event to create
|
||||
* @notify_tpl task priority level of the event
|
||||
* @notify_function notification function of the event
|
||||
* @notify_context pointer passed to the notification function
|
||||
* @event created event
|
||||
* @return status code
|
||||
*/
|
||||
efi_status_t efi_create_event(uint32_t type, UINTN notify_tpl,
|
||||
void (EFIAPI *notify_function) (
|
||||
struct efi_event *event,
|
||||
@ -324,6 +438,20 @@ efi_status_t efi_create_event(uint32_t type, UINTN notify_tpl,
|
||||
return EFI_OUT_OF_RESOURCES;
|
||||
}
|
||||
|
||||
/*
|
||||
* Create an event.
|
||||
*
|
||||
* This function implements the CreateEvent service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @type type of the event to create
|
||||
* @notify_tpl task priority level of the event
|
||||
* @notify_function notification function of the event
|
||||
* @notify_context pointer passed to the notification function
|
||||
* @event created event
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_create_event_ext(
|
||||
uint32_t type, UINTN notify_tpl,
|
||||
void (EFIAPI *notify_function) (
|
||||
@ -339,8 +467,11 @@ static efi_status_t EFIAPI efi_create_event_ext(
|
||||
|
||||
|
||||
/*
|
||||
* Check if a timer event has occurred or a queued notification function should
|
||||
* be called.
|
||||
*
|
||||
* Our timers have to work without interrupts, so we check whenever keyboard
|
||||
* input or disk accesses happen if enough time elapsed for it to fire.
|
||||
* input or disk accesses happen if enough time elapsed for them to fire.
|
||||
*/
|
||||
void efi_timer_check(void)
|
||||
{
|
||||
@ -372,6 +503,17 @@ void efi_timer_check(void)
|
||||
WATCHDOG_RESET();
|
||||
}
|
||||
|
||||
/*
|
||||
* Set the trigger time for a timer event or stop the event.
|
||||
*
|
||||
* This is the function for internal usage in U-Boot. For the API function
|
||||
* implementing the SetTimer service see efi_set_timer_ext.
|
||||
*
|
||||
* @event event for which the timer is set
|
||||
* @type type of the timer
|
||||
* @trigger_time trigger period in multiples of 100ns
|
||||
* @return status code
|
||||
*/
|
||||
efi_status_t efi_set_timer(struct efi_event *event, enum efi_timer_delay type,
|
||||
uint64_t trigger_time)
|
||||
{
|
||||
@ -409,6 +551,18 @@ efi_status_t efi_set_timer(struct efi_event *event, enum efi_timer_delay type,
|
||||
return EFI_INVALID_PARAMETER;
|
||||
}
|
||||
|
||||
/*
|
||||
* Set the trigger time for a timer event or stop the event.
|
||||
*
|
||||
* This function implements the SetTimer service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @event event for which the timer is set
|
||||
* @type type of the timer
|
||||
* @trigger_time trigger period in multiples of 100ns
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_set_timer_ext(struct efi_event *event,
|
||||
enum efi_timer_delay type,
|
||||
uint64_t trigger_time)
|
||||
@ -417,6 +571,18 @@ static efi_status_t EFIAPI efi_set_timer_ext(struct efi_event *event,
|
||||
return EFI_EXIT(efi_set_timer(event, type, trigger_time));
|
||||
}
|
||||
|
||||
/*
|
||||
* Wait for events to be signaled.
|
||||
*
|
||||
* This function implements the WaitForEvent service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @num_events number of events to be waited for
|
||||
* @events events to be waited for
|
||||
* @index index of the event that was signaled
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_wait_for_event(unsigned long num_events,
|
||||
struct efi_event **event,
|
||||
unsigned long *index)
|
||||
@ -466,6 +632,18 @@ out:
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Signal an EFI event.
|
||||
*
|
||||
* This function implements the SignalEvent service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* This functions sets the signaled state of the event and queues the
|
||||
* notification function for execution.
|
||||
*
|
||||
* @event event to signal
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_signal_event_ext(struct efi_event *event)
|
||||
{
|
||||
int i;
|
||||
@ -484,6 +662,16 @@ static efi_status_t EFIAPI efi_signal_event_ext(struct efi_event *event)
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Close an EFI event.
|
||||
*
|
||||
* This function implements the CloseEvent service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @event event to close
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_close_event(struct efi_event *event)
|
||||
{
|
||||
int i;
|
||||
@ -501,6 +689,18 @@ static efi_status_t EFIAPI efi_close_event(struct efi_event *event)
|
||||
return EFI_EXIT(EFI_INVALID_PARAMETER);
|
||||
}
|
||||
|
||||
/*
|
||||
* Check if an event is signaled.
|
||||
*
|
||||
* This function implements the CheckEvent service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* If an event is not signaled yet the notification function is queued.
|
||||
*
|
||||
* @event event to check
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_check_event(struct efi_event *event)
|
||||
{
|
||||
int i;
|
||||
@ -521,6 +721,20 @@ static efi_status_t EFIAPI efi_check_event(struct efi_event *event)
|
||||
return EFI_EXIT(EFI_INVALID_PARAMETER);
|
||||
}
|
||||
|
||||
/*
|
||||
* Install protocol interface.
|
||||
*
|
||||
* This is the function for internal calls. For the API implementation of the
|
||||
* InstallProtocolInterface service see function
|
||||
* efi_install_protocol_interface_ext.
|
||||
*
|
||||
* @handle handle on which the protocol shall be installed
|
||||
* @protocol GUID of the protocol to be installed
|
||||
* @protocol_interface_type type of the interface to be installed,
|
||||
* always EFI_NATIVE_INTERFACE
|
||||
* @protocol_interface interface of the protocol implementation
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_install_protocol_interface(void **handle,
|
||||
efi_guid_t *protocol, int protocol_interface_type,
|
||||
void *protocol_interface)
|
||||
@ -579,6 +793,20 @@ out:
|
||||
return r;
|
||||
}
|
||||
|
||||
/*
|
||||
* Install protocol interface.
|
||||
*
|
||||
* This function implements the InstallProtocolInterface service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle on which the protocol shall be installed
|
||||
* @protocol GUID of the protocol to be installed
|
||||
* @protocol_interface_type type of the interface to be installed,
|
||||
* always EFI_NATIVE_INTERFACE
|
||||
* @protocol_interface interface of the protocol implementation
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_install_protocol_interface_ext(void **handle,
|
||||
efi_guid_t *protocol, int protocol_interface_type,
|
||||
void *protocol_interface)
|
||||
@ -591,6 +819,20 @@ static efi_status_t EFIAPI efi_install_protocol_interface_ext(void **handle,
|
||||
protocol_interface));
|
||||
}
|
||||
|
||||
/*
|
||||
* Reinstall protocol interface.
|
||||
*
|
||||
* This function implements the ReinstallProtocolInterface service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle on which the protocol shall be
|
||||
* reinstalled
|
||||
* @protocol GUID of the protocol to be installed
|
||||
* @old_interface interface to be removed
|
||||
* @new_interface interface to be installed
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_reinstall_protocol_interface(void *handle,
|
||||
efi_guid_t *protocol, void *old_interface,
|
||||
void *new_interface)
|
||||
@ -600,6 +842,18 @@ static efi_status_t EFIAPI efi_reinstall_protocol_interface(void *handle,
|
||||
return EFI_EXIT(EFI_ACCESS_DENIED);
|
||||
}
|
||||
|
||||
/*
|
||||
* Uninstall protocol interface.
|
||||
*
|
||||
* This is the function for internal calls. For the API implementation of the
|
||||
* UninstallProtocolInterface service see function
|
||||
* efi_uninstall_protocol_interface_ext.
|
||||
*
|
||||
* @handle handle from which the protocol shall be removed
|
||||
* @protocol GUID of the protocol to be removed
|
||||
* @protocol_interface interface to be removed
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_uninstall_protocol_interface(void *handle,
|
||||
efi_guid_t *protocol, void *protocol_interface)
|
||||
{
|
||||
@ -641,6 +895,18 @@ out:
|
||||
return r;
|
||||
}
|
||||
|
||||
/*
|
||||
* Uninstall protocol interface.
|
||||
*
|
||||
* This function implements the UninstallProtocolInterface service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle from which the protocol shall be removed
|
||||
* @protocol GUID of the protocol to be removed
|
||||
* @protocol_interface interface to be removed
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_uninstall_protocol_interface_ext(void *handle,
|
||||
efi_guid_t *protocol, void *protocol_interface)
|
||||
{
|
||||
@ -650,6 +916,19 @@ static efi_status_t EFIAPI efi_uninstall_protocol_interface_ext(void *handle,
|
||||
protocol_interface));
|
||||
}
|
||||
|
||||
/*
|
||||
* Register an event for notification when a protocol is installed.
|
||||
*
|
||||
* This function implements the RegisterProtocolNotify service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @protocol GUID of the protocol whose installation shall be
|
||||
* notified
|
||||
* @event event to be signaled upon installation of the protocol
|
||||
* @registration key for retrieving the registration information
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_register_protocol_notify(efi_guid_t *protocol,
|
||||
struct efi_event *event,
|
||||
void **registration)
|
||||
@ -658,6 +937,17 @@ static efi_status_t EFIAPI efi_register_protocol_notify(efi_guid_t *protocol,
|
||||
return EFI_EXIT(EFI_OUT_OF_RESOURCES);
|
||||
}
|
||||
|
||||
/*
|
||||
* Determine if an EFI handle implements a protocol.
|
||||
*
|
||||
* See the documentation of the LocateHandle service in the UEFI specification.
|
||||
*
|
||||
* @search_type selection criterion
|
||||
* @protocol GUID of the protocol
|
||||
* @search_key registration key
|
||||
* @efiobj handle
|
||||
* @return 0 if the handle implements the protocol
|
||||
*/
|
||||
static int efi_search(enum efi_locate_search_type search_type,
|
||||
efi_guid_t *protocol, void *search_key,
|
||||
struct efi_object *efiobj)
|
||||
@ -681,6 +971,19 @@ static int efi_search(enum efi_locate_search_type search_type,
|
||||
return -1;
|
||||
}
|
||||
|
||||
/*
|
||||
* Locate handles implementing a protocol.
|
||||
*
|
||||
* This function is meant for U-Boot internal calls. For the API implementation
|
||||
* of the LocateHandle service see efi_locate_handle_ext.
|
||||
*
|
||||
* @search_type selection criterion
|
||||
* @protocol GUID of the protocol
|
||||
* @search_key registration key
|
||||
* @buffer_size size of the buffer to receive the handles in bytes
|
||||
* @buffer buffer to receive the relevant handles
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t efi_locate_handle(
|
||||
enum efi_locate_search_type search_type,
|
||||
efi_guid_t *protocol, void *search_key,
|
||||
@ -719,6 +1022,20 @@ static efi_status_t efi_locate_handle(
|
||||
return EFI_SUCCESS;
|
||||
}
|
||||
|
||||
/*
|
||||
* Locate handles implementing a protocol.
|
||||
*
|
||||
* This function implements the LocateHandle service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @search_type selection criterion
|
||||
* @protocol GUID of the protocol
|
||||
* @search_key registration key
|
||||
* @buffer_size size of the buffer to receive the handles in bytes
|
||||
* @buffer buffer to receive the relevant handles
|
||||
* @return 0 if the handle implements the protocol
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_locate_handle_ext(
|
||||
enum efi_locate_search_type search_type,
|
||||
efi_guid_t *protocol, void *search_key,
|
||||
@ -731,6 +1048,18 @@ static efi_status_t EFIAPI efi_locate_handle_ext(
|
||||
buffer_size, buffer));
|
||||
}
|
||||
|
||||
/*
|
||||
* Get the device path and handle of an device implementing a protocol.
|
||||
*
|
||||
* This function implements the LocateDevicePath service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @protocol GUID of the protocol
|
||||
* @device_path device path
|
||||
* @device handle of the device
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_locate_device_path(efi_guid_t *protocol,
|
||||
struct efi_device_path **device_path,
|
||||
efi_handle_t *device)
|
||||
@ -759,6 +1088,16 @@ static void efi_remove_configuration_table(int i)
|
||||
systab.nr_tables--;
|
||||
}
|
||||
|
||||
/*
|
||||
* Adds, updates, or removes a configuration table.
|
||||
*
|
||||
* This function is used for internal calls. For the API implementation of the
|
||||
* InstallConfigurationTable service see efi_install_configuration_table_ext.
|
||||
*
|
||||
* @guid GUID of the installed table
|
||||
* @table table to be installed
|
||||
* @return status code
|
||||
*/
|
||||
efi_status_t efi_install_configuration_table(const efi_guid_t *guid, void *table)
|
||||
{
|
||||
int i;
|
||||
@ -789,6 +1128,17 @@ efi_status_t efi_install_configuration_table(const efi_guid_t *guid, void *table
|
||||
return EFI_SUCCESS;
|
||||
}
|
||||
|
||||
/*
|
||||
* Adds, updates, or removes a configuration table.
|
||||
*
|
||||
* This function implements the InstallConfigurationTable service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @guid GUID of the installed table
|
||||
* @table table to be installed
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_install_configuration_table_ext(efi_guid_t *guid,
|
||||
void *table)
|
||||
{
|
||||
@ -796,8 +1146,15 @@ static efi_status_t EFIAPI efi_install_configuration_table_ext(efi_guid_t *guid,
|
||||
return EFI_EXIT(efi_install_configuration_table(guid, table));
|
||||
}
|
||||
|
||||
/* Initialize a loaded_image_info + loaded_image_info object with correct
|
||||
/*
|
||||
* Initialize a loaded_image_info + loaded_image_info object with correct
|
||||
* protocols, boot-device, etc.
|
||||
*
|
||||
* @info loaded image info to be passed to the enty point of the
|
||||
* image
|
||||
* @obj internal object associated with the loaded image
|
||||
* @device_path device path of the loaded image
|
||||
* @file_path file path of the loaded image
|
||||
*/
|
||||
void efi_setup_loaded_image(struct efi_loaded_image *info, struct efi_object *obj,
|
||||
struct efi_device_path *device_path,
|
||||
@ -832,6 +1189,12 @@ void efi_setup_loaded_image(struct efi_loaded_image *info, struct efi_object *ob
|
||||
list_add_tail(&obj->link, &efi_obj_list);
|
||||
}
|
||||
|
||||
/*
|
||||
* Load an image using a file path.
|
||||
*
|
||||
* @file_path the path of the image to load
|
||||
* @buffer buffer containing the loaded image
|
||||
*/
|
||||
efi_status_t efi_load_image_from_path(struct efi_device_path *file_path,
|
||||
void **buffer)
|
||||
{
|
||||
@ -873,6 +1236,22 @@ error:
|
||||
return ret;
|
||||
}
|
||||
|
||||
/*
|
||||
* Load an EFI image into memory.
|
||||
*
|
||||
* This function implements the LoadImage service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @boot_policy true for request originating from the boot manager
|
||||
* @parent_image the calles's image handle
|
||||
* @file_path the path of the image to load
|
||||
* @source_buffer memory location from which the image is installed
|
||||
* @source_size size of the memory area from which the image is
|
||||
* installed
|
||||
* @image_handle handle for the newly installed image
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_load_image(bool boot_policy,
|
||||
efi_handle_t parent_image,
|
||||
struct efi_device_path *file_path,
|
||||
@ -926,6 +1305,17 @@ static efi_status_t EFIAPI efi_load_image(bool boot_policy,
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Call the entry point of an image.
|
||||
*
|
||||
* This function implements the StartImage service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @image_handle handle of the image
|
||||
* @exit_data_size size of the buffer
|
||||
* @exit_data buffer to receive the exit data of the called image
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_start_image(efi_handle_t image_handle,
|
||||
unsigned long *exit_data_size,
|
||||
s16 **exit_data)
|
||||
@ -954,6 +1344,18 @@ static efi_status_t EFIAPI efi_start_image(efi_handle_t image_handle,
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Leave an EFI application or driver.
|
||||
*
|
||||
* This function implements the Exit service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @image_handle handle of the application or driver that is exiting
|
||||
* @exit_status status code
|
||||
* @exit_data_size size of the buffer in bytes
|
||||
* @exit_data buffer with data describing an error
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_exit(efi_handle_t image_handle,
|
||||
efi_status_t exit_status, unsigned long exit_data_size,
|
||||
int16_t *exit_data)
|
||||
@ -978,6 +1380,12 @@ static efi_status_t EFIAPI efi_exit(efi_handle_t image_handle,
|
||||
panic("EFI application exited");
|
||||
}
|
||||
|
||||
/*
|
||||
* Find the internal EFI object for a handle.
|
||||
*
|
||||
* @handle handle to find
|
||||
* @return EFI object
|
||||
*/
|
||||
static struct efi_object *efi_search_obj(void *handle)
|
||||
{
|
||||
struct list_head *lhandle;
|
||||
@ -992,6 +1400,16 @@ static struct efi_object *efi_search_obj(void *handle)
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/*
|
||||
* Unload an EFI image.
|
||||
*
|
||||
* This function implements the UnloadImage service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @image_handle handle of the image to be unloaded
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_unload_image(void *image_handle)
|
||||
{
|
||||
struct efi_object *efiobj;
|
||||
@ -1004,6 +1422,9 @@ static efi_status_t EFIAPI efi_unload_image(void *image_handle)
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Fix up caches for EFI payloads if necessary.
|
||||
*/
|
||||
static void efi_exit_caches(void)
|
||||
{
|
||||
#if defined(CONFIG_ARM) && !defined(CONFIG_ARM64)
|
||||
@ -1016,6 +1437,17 @@ static void efi_exit_caches(void)
|
||||
#endif
|
||||
}
|
||||
|
||||
/*
|
||||
* Stop boot services.
|
||||
*
|
||||
* This function implements the ExitBootServices service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @image_handle handle of the loaded image
|
||||
* @map_key key of the memory map
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_exit_boot_services(void *image_handle,
|
||||
unsigned long map_key)
|
||||
{
|
||||
@ -1051,6 +1483,16 @@ static efi_status_t EFIAPI efi_exit_boot_services(void *image_handle,
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Get next value of the counter.
|
||||
*
|
||||
* This function implements the NextMonotonicCount service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @count returned value of the counter
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_get_next_monotonic_count(uint64_t *count)
|
||||
{
|
||||
static uint64_t mono = 0;
|
||||
@ -1059,6 +1501,16 @@ static efi_status_t EFIAPI efi_get_next_monotonic_count(uint64_t *count)
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Sleep.
|
||||
*
|
||||
* This function implements the Stall sercive.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @microseconds period to sleep in microseconds
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_stall(unsigned long microseconds)
|
||||
{
|
||||
EFI_ENTRY("%ld", microseconds);
|
||||
@ -1066,6 +1518,18 @@ static efi_status_t EFIAPI efi_stall(unsigned long microseconds)
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Reset the watchdog timer.
|
||||
*
|
||||
* This function implements the WatchdogTimer service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @timeout seconds before reset by watchdog
|
||||
* @watchdog_code code to be logged when resetting
|
||||
* @data_size size of buffer in bytes
|
||||
* @watchdog_data buffer with data describing the reset reason
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_set_watchdog_timer(unsigned long timeout,
|
||||
uint64_t watchdog_code,
|
||||
unsigned long data_size,
|
||||
@ -1076,6 +1540,19 @@ static efi_status_t EFIAPI efi_set_watchdog_timer(unsigned long timeout,
|
||||
return efi_unsupported(__func__);
|
||||
}
|
||||
|
||||
/*
|
||||
* Connect a controller to a driver.
|
||||
*
|
||||
* This function implements the ConnectController service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @controller_handle handle of the controller
|
||||
* @driver_image_handle handle of the driver
|
||||
* @remain_device_path device path of a child controller
|
||||
* @recursive true to connect all child controllers
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_connect_controller(
|
||||
efi_handle_t controller_handle,
|
||||
efi_handle_t *driver_image_handle,
|
||||
@ -1087,6 +1564,18 @@ static efi_status_t EFIAPI efi_connect_controller(
|
||||
return EFI_EXIT(EFI_NOT_FOUND);
|
||||
}
|
||||
|
||||
/*
|
||||
* Disconnect a controller from a driver.
|
||||
*
|
||||
* This function implements the DisconnectController service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @controller_handle handle of the controller
|
||||
* @driver_image_handle handle of the driver
|
||||
* @child_handle handle of the child to destroy
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_disconnect_controller(void *controller_handle,
|
||||
void *driver_image_handle,
|
||||
void *child_handle)
|
||||
@ -1096,6 +1585,19 @@ static efi_status_t EFIAPI efi_disconnect_controller(void *controller_handle,
|
||||
return EFI_EXIT(EFI_INVALID_PARAMETER);
|
||||
}
|
||||
|
||||
/*
|
||||
* Close a protocol.
|
||||
*
|
||||
* This function implements the CloseProtocol service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle on which the protocol shall be closed
|
||||
* @protocol GUID of the protocol to close
|
||||
* @agent_handle handle of the driver
|
||||
* @controller_handle handle of the controller
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_close_protocol(void *handle,
|
||||
efi_guid_t *protocol,
|
||||
void *agent_handle,
|
||||
@ -1106,6 +1608,19 @@ static efi_status_t EFIAPI efi_close_protocol(void *handle,
|
||||
return EFI_EXIT(EFI_NOT_FOUND);
|
||||
}
|
||||
|
||||
/*
|
||||
* Provide information about then open status of a protocol on a handle
|
||||
*
|
||||
* This function implements the OpenProtocolInformation service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle for which the information shall be retrieved
|
||||
* @protocol GUID of the protocol
|
||||
* @entry_buffer buffer to receive the open protocol information
|
||||
* @entry_count number of entries available in the buffer
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_open_protocol_information(efi_handle_t handle,
|
||||
efi_guid_t *protocol,
|
||||
struct efi_open_protocol_info_entry **entry_buffer,
|
||||
@ -1116,6 +1631,17 @@ static efi_status_t EFIAPI efi_open_protocol_information(efi_handle_t handle,
|
||||
return EFI_EXIT(EFI_NOT_FOUND);
|
||||
}
|
||||
|
||||
/*
|
||||
* Get protocols installed on a handle.
|
||||
*
|
||||
* This function implements the ProtocolsPerHandleService.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle for which the information is retrieved
|
||||
* @protocol_buffer buffer with protocol GUIDs
|
||||
* @protocol_buffer_count number of entries in the buffer
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_protocols_per_handle(void *handle,
|
||||
efi_guid_t ***protocol_buffer,
|
||||
unsigned long *protocol_buffer_count)
|
||||
@ -1169,6 +1695,20 @@ static efi_status_t EFIAPI efi_protocols_per_handle(void *handle,
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Locate handles implementing a protocol.
|
||||
*
|
||||
* This function implements the LocateHandleBuffer service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @search_type selection criterion
|
||||
* @protocol GUID of the protocol
|
||||
* @search_key registration key
|
||||
* @no_handles number of returned handles
|
||||
* @buffer buffer with the returned handles
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_locate_handle_buffer(
|
||||
enum efi_locate_search_type search_type,
|
||||
efi_guid_t *protocol, void *search_key,
|
||||
@ -1202,6 +1742,17 @@ out:
|
||||
return EFI_EXIT(r);
|
||||
}
|
||||
|
||||
/*
|
||||
* Find an interface implementing a protocol.
|
||||
*
|
||||
* This function implements the LocateProtocol service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @protocol GUID of the protocol
|
||||
* @registration registration key passed to the notification function
|
||||
* @protocol_interface interface implementing the protocol
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_locate_protocol(efi_guid_t *protocol,
|
||||
void *registration,
|
||||
void **protocol_interface)
|
||||
@ -1237,6 +1788,18 @@ static efi_status_t EFIAPI efi_locate_protocol(efi_guid_t *protocol,
|
||||
return EFI_EXIT(EFI_NOT_FOUND);
|
||||
}
|
||||
|
||||
/*
|
||||
* Install multiple protocol interfaces.
|
||||
*
|
||||
* This function implements the MultipleProtocolInterfaces service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle on which the protocol interfaces shall be installed
|
||||
* @... NULL terminated argument list with pairs of protocol GUIDS and
|
||||
* interfaces
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_install_multiple_protocol_interfaces(
|
||||
void **handle, ...)
|
||||
{
|
||||
@ -1281,6 +1844,18 @@ static efi_status_t EFIAPI efi_install_multiple_protocol_interfaces(
|
||||
return EFI_EXIT(r);
|
||||
}
|
||||
|
||||
/*
|
||||
* Uninstall multiple protocol interfaces.
|
||||
*
|
||||
* This function implements the UninstallMultipleProtocolInterfaces service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle from which the protocol interfaces shall be removed
|
||||
* @... NULL terminated argument list with pairs of protocol GUIDS and
|
||||
* interfaces
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_uninstall_multiple_protocol_interfaces(
|
||||
void *handle, ...)
|
||||
{
|
||||
@ -1288,6 +1863,18 @@ static efi_status_t EFIAPI efi_uninstall_multiple_protocol_interfaces(
|
||||
return EFI_EXIT(EFI_INVALID_PARAMETER);
|
||||
}
|
||||
|
||||
/*
|
||||
* Calculate cyclic redundancy code.
|
||||
*
|
||||
* This function implements the CalculateCrc32 service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @data buffer with data
|
||||
* @data_size size of buffer in bytes
|
||||
* @crc32_p cyclic redundancy code
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_calculate_crc32(void *data,
|
||||
unsigned long data_size,
|
||||
uint32_t *crc32_p)
|
||||
@ -1297,6 +1884,17 @@ static efi_status_t EFIAPI efi_calculate_crc32(void *data,
|
||||
return EFI_EXIT(EFI_SUCCESS);
|
||||
}
|
||||
|
||||
/*
|
||||
* Copy memory.
|
||||
*
|
||||
* This function implements the CopyMem service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @destination destination of the copy operation
|
||||
* @source source of the copy operation
|
||||
* @length number of bytes to copy
|
||||
*/
|
||||
static void EFIAPI efi_copy_mem(void *destination, void *source,
|
||||
unsigned long length)
|
||||
{
|
||||
@ -1304,12 +1902,38 @@ static void EFIAPI efi_copy_mem(void *destination, void *source,
|
||||
memcpy(destination, source, length);
|
||||
}
|
||||
|
||||
/*
|
||||
* Fill memory with a byte value.
|
||||
*
|
||||
* This function implements the SetMem service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @buffer buffer to fill
|
||||
* @size size of buffer in bytes
|
||||
* @value byte to copy to the buffer
|
||||
*/
|
||||
static void EFIAPI efi_set_mem(void *buffer, unsigned long size, uint8_t value)
|
||||
{
|
||||
EFI_ENTRY("%p, %ld, 0x%x", buffer, size, value);
|
||||
memset(buffer, value, size);
|
||||
}
|
||||
|
||||
/*
|
||||
* Open protocol interface on a handle.
|
||||
*
|
||||
* This function implements the OpenProtocol interface.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle on which the protocol shall be opened
|
||||
* @protocol GUID of the protocol
|
||||
* @protocol_interface interface implementing the protocol
|
||||
* @agent_handle handle of the driver
|
||||
* @controller_handle handle of the controller
|
||||
* @attributes attributes indicating how to open the protocol
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_open_protocol(
|
||||
void *handle, efi_guid_t *protocol,
|
||||
void **protocol_interface, void *agent_handle,
|
||||
@ -1382,6 +2006,18 @@ out:
|
||||
return EFI_EXIT(r);
|
||||
}
|
||||
|
||||
/*
|
||||
* Get interface of a protocol on a handle.
|
||||
*
|
||||
* This function implements the HandleProtocol service.
|
||||
* See the Unified Extensible Firmware Interface (UEFI) specification
|
||||
* for details.
|
||||
*
|
||||
* @handle handle on which the protocol shall be opened
|
||||
* @protocol GUID of the protocol
|
||||
* @protocol_interface interface implementing the protocol
|
||||
* @return status code
|
||||
*/
|
||||
static efi_status_t EFIAPI efi_handle_protocol(void *handle,
|
||||
efi_guid_t *protocol,
|
||||
void **protocol_interface)
|
||||
|
Loading…
Reference in New Issue
Block a user