diff options
author | Rob Clark <robdclark@gmail.com> | 2017-09-13 18:05:33 -0400 |
---|---|---|
committer | Alexander Graf <agraf@suse.de> | 2017-09-20 10:36:56 +0200 |
commit | 95c5553ea268144056c4bafc318b9e8b5c096a6c (patch) | |
tree | 8b080f2e00b009421ebebe5a27cdd66b3ad70404 /include | |
parent | e15fc33548acda1b975bad172dc19033382dc211 (diff) | |
download | u-boot-95c5553ea268144056c4bafc318b9e8b5c096a6c.tar.gz u-boot-95c5553ea268144056c4bafc318b9e8b5c096a6c.tar.xz u-boot-95c5553ea268144056c4bafc318b9e8b5c096a6c.zip |
efi_loader: refactor boot device and loaded_image handling
Get rid of the hacky fake boot-device and duplicate device-path
constructing (which needs to match what efi_disk and efi_net do).
Instead convert over to use efi_device_path helpers to construct
device-paths, and use that to look up the actual boot device.
Also, extract out a helper to plug things in properly to the
loaded_image. In a following patch we'll want to re-use this in
efi_load_image() to handle the case of loading an image from a
file_path.
Signed-off-by: Rob Clark <robdclark@gmail.com>
Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'include')
-rw-r--r-- | include/efi_loader.h | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/include/efi_loader.h b/include/efi_loader.h index 784257bc1f..8752bcf010 100644 --- a/include/efi_loader.h +++ b/include/efi_loader.h @@ -159,7 +159,7 @@ int efi_disk_register(void); /* Called by bootefi to make GOP (graphical) interface available */ int efi_gop_register(void); /* Called by bootefi to make the network interface available */ -int efi_net_register(void **handle); +int efi_net_register(void); /* Called by bootefi to make SMBIOS tables available */ void efi_smbios_register(void); @@ -216,6 +216,9 @@ uint64_t efi_add_memory_map(uint64_t start, uint64_t pages, int memory_type, int efi_memory_init(void); /* Adds new or overrides configuration table entry to the system table */ efi_status_t efi_install_configuration_table(const efi_guid_t *guid, void *table); +void efi_setup_loaded_image(struct efi_loaded_image *info, struct efi_object *obj, + struct efi_device_path *device_path, + struct efi_device_path *file_path); #ifdef CONFIG_EFI_LOADER_BOUNCE_BUFFER extern void *efi_bounce_buffer; |