[PATCH 02/16] efi_loader: efi_net: check efi_search_protocol return value

Adriano Cordova adrianox at gmail.com
Tue Mar 11 17:47:44 CET 2025


Signed-off-by: Adriano Cordova <adriano.cordova at canonical.com>
---
 lib/efi_loader/efi_net.c | 13 ++++++++++---
 1 file changed, 10 insertions(+), 3 deletions(-)

diff --git a/lib/efi_loader/efi_net.c b/lib/efi_loader/efi_net.c
index 0334eedaf5c..8c0a3f5243c 100644
--- a/lib/efi_loader/efi_net.c
+++ b/lib/efi_loader/efi_net.c
@@ -1020,7 +1020,9 @@ efi_status_t efi_netobj_set_dp(struct efi_net_obj *netobj, struct efi_device_pat
 		return EFI_OUT_OF_RESOURCES;
 
 	phandler = NULL;
-	efi_search_protocol(&netobj->header, &efi_guid_device_path, &phandler);
+	ret = efi_search_protocol(&netobj->header, &efi_guid_device_path, &phandler);
+	if (ret != EFI_SUCCESS && ret != EFI_NOT_FOUND)
+		return ret;
 
 	// If the device path protocol is not yet installed, install it
 	if (!phandler)
@@ -1051,12 +1053,15 @@ add:
 static struct efi_device_path *efi_netobj_get_dp(struct efi_net_obj *netobj)
 {
 	struct efi_handler *phandler;
+	efi_status_t r;
 
 	if (!efi_netobj_is_active(netobj))
 		return NULL;
 
 	phandler = NULL;
-	efi_search_protocol(&netobj->header, &efi_guid_device_path, &phandler);
+	r = efi_search_protocol(&netobj->header, &efi_guid_device_path, &phandler);
+	if (r != EFI_SUCCESS && r != EFI_NOT_FOUND)
+		return NULL;
 
 	if (phandler && phandler->protocol_interface)
 		return efi_dp_dup(phandler->protocol_interface);
@@ -1444,7 +1449,9 @@ int efi_net_unregister(void *ctx, struct event *event)
 			return -1;
 
 		phandler = NULL;
-		efi_search_protocol(&netobj->header, &efi_guid_device_path, &phandler);
+		ret = efi_search_protocol(&netobj->header, &efi_guid_device_path, &phandler);
+		if (ret != EFI_SUCCESS && ret != EFI_NOT_FOUND)
+			return -1;
 		if (phandler && phandler->protocol_interface)
 			interface = phandler->protocol_interface;
 
-- 
2.48.1



More information about the U-Boot mailing list