From: Michael Brown Date: Thu, 20 Mar 2025 14:35:11 +0000 (+0000) Subject: [efi] Get veto candidate driver name from image handle X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=756e3907fdca0a9b4fe18a618eb35895d0208b86;p=thirdparty%2Fipxe.git [efi] Get veto candidate driver name from image handle Allow for drivers that do not install the driver binding protocol on the image handle by opening the component name protocol on the driver binding's ImageHandle rather than on the driver handle itself. Signed-off-by: Michael Brown --- diff --git a/src/interface/efi/efi_veto.c b/src/interface/efi/efi_veto.c index 1b2332041..4cf4e846d 100644 --- a/src/interface/efi/efi_veto.c +++ b/src/interface/efi/efi_veto.c @@ -598,10 +598,10 @@ static int efi_veto_find ( EFI_HANDLE driver, const char *manufacturer, goto err_loaded; } - /* Open component name protocol, if present*/ + /* Open component name protocol, if present */ if ( ( efirc = bs->OpenProtocol ( - driver, &efi_component_name_protocol_guid, - &wtf.interface, efi_image_handle, driver, + image, &efi_component_name_protocol_guid, + &wtf.interface, efi_image_handle, image, EFI_OPEN_PROTOCOL_GET_PROTOCOL ) ) != 0 ) { /* Ignore failure; is not required to be present */ wtf.interface = NULL; @@ -641,8 +641,8 @@ static int efi_veto_find ( EFI_HANDLE driver, const char *manufacturer, /* Close protocols */ if ( wtf.wtf ) { - bs->CloseProtocol ( driver, &efi_component_name_protocol_guid, - efi_image_handle, driver ); + bs->CloseProtocol ( image, &efi_component_name_protocol_guid, + efi_image_handle, image ); } bs->CloseProtocol ( image, &efi_loaded_image_protocol_guid, efi_image_handle, image );