mirror of
https://github.com/ipxe/ipxe
synced 2025-12-12 14:32:49 +03:00
[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 <mcb30@ipxe.org>
This commit is contained in:
@@ -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 );
|
||||
|
||||
Reference in New Issue
Block a user