On 24.07.17 11:48, Rob Clark wrote:
On Tue, Jul 11, 2017 at 4:06 PM, Heinrich Schuchardt <xypron.g...@gmx.de> wrote:
efi_open_protocol was implemented to call a protocol specific open
function to retrieve the protocol interface.
The UEFI specification does not know of such a function.
It is not possible to implement InstallProtocolInterface with the
current design.
With the patch the protocol interface itself is stored in the list
of installed protocols of an efi_object instead of an open function.
Signed-off-by: Heinrich Schuchardt <xypron.g...@gmx.de>
---
v2
Remove implementation of efi_return_handle.
---
cmd/bootefi.c | 14 +++-----------
include/efi_loader.h | 17 ++---------------
lib/efi_loader/efi_boottime.c | 18 ++++++++++++++----
lib/efi_loader/efi_disk.c | 29 +++--------------------------
lib/efi_loader/efi_gop.c | 2 +-
lib/efi_loader/efi_image_loader.c | 8 --------
lib/efi_loader/efi_net.c | 30 +++---------------------------
7 files changed, 26 insertions(+), 92 deletions(-)
diff --git a/cmd/bootefi.c b/cmd/bootefi.c
index 7ddeead671..7cf0129a18 100644
--- a/cmd/bootefi.c
+++ b/cmd/bootefi.c
@@ -54,14 +54,6 @@ static struct efi_device_path_file_path
bootefi_device_path[] = {
}
};
-static efi_status_t EFIAPI bootefi_open_dp(void *handle, efi_guid_t *protocol,
- void **protocol_interface, void *agent_handle,
- void *controller_handle, uint32_t attributes)
-{
- *protocol_interface = bootefi_device_path;
- return EFI_SUCCESS;
-}
-
/* The EFI loaded_image interface for the image executed via "bootefi" */
static struct efi_loaded_image loaded_image_info = {
.device_handle = bootefi_device_path,
@@ -78,7 +70,7 @@ static struct efi_object loaded_image_info_obj = {
* return handle which points to loaded_image_info
*/
.guid = &efi_guid_loaded_image,
- .open = &efi_return_handle,
+ .protocol_interface = &loaded_image_info,
btw, I probably should have looked at this patchset earlier.. in
general, I like it, since it removes a lot of boilerplate. But there
are some cases where ->open() allows deferred allocation. For
example, I'm working on efi_file and simple-file-system-protocol
implementation. A file object can have a device-path accessed by
opening device-path protocol. 99% of the time this isn't used, so the
->open() approach lets me defer constructing a file's device-path.
How would you feel if I re-introduced ->open() as an optional thing
(where the normal case if open is NULL would be to just return
protocol_interface)?
Sounds very reasonable to me. I also think that first converting
everything to data-driven is a good thing, as it makes sure we have
everything that doesn't need to be deferred explicit.
So yes, please base an optional open method on top :).
Alex
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot