From mboxrd@z Thu Jan 1 00:00:00 1970 Authentication-Results: mx.groups.io; dkim=missing; spf=pass (domain: redhat.com, ip: 209.132.183.28, mailfrom: lersek@redhat.com) Received: from mx1.redhat.com (mx1.redhat.com [209.132.183.28]) by groups.io with SMTP; Tue, 17 Sep 2019 12:50:22 -0700 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 98A1E3082A6C; Tue, 17 Sep 2019 19:50:21 +0000 (UTC) Received: from lacos-laptop-7.usersys.redhat.com (ovpn-120-37.rdu2.redhat.com [10.10.120.37]) by smtp.corp.redhat.com (Postfix) with ESMTP id 8D27C600C4; Tue, 17 Sep 2019 19:50:20 +0000 (UTC) From: "Laszlo Ersek" To: edk2-devel-groups-io Cc: Jiaxin Wu , Siyuan Fu Subject: [PATCH 19/35] NetworkPkg: fix CloseProtocol & UninstallMultipleProtocolInterfaces calls Date: Tue, 17 Sep 2019 21:49:19 +0200 Message-Id: <20190917194935.24322-20-lersek@redhat.com> In-Reply-To: <20190917194935.24322-1-lersek@redhat.com> References: <20190917194935.24322-1-lersek@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.45]); Tue, 17 Sep 2019 19:50:21 +0000 (UTC) Content-Transfer-Encoding: quoted-printable Both the "ControllerHandle" parameter of CloseProtocol() and the "Handle" parameter of UninstallMultipleProtocolInterfaces() have type EFI_HANDLE, not (EFI_HANDLE*). This patch fixes actual bugs. The issues have been dormant likely because they are on error paths. (Or, in case of TlsAuthConfigDxe, because the driver is unloaded likely very infrequently.) Cc: Jiaxin Wu Cc: Siyuan Fu Signed-off-by: Laszlo Ersek --- Notes: build-tested only NetworkPkg/DnsDxe/DnsDriver.c | 4 ++-- NetworkPkg/IScsiDxe/IScsiConfig.c | 2 +- NetworkPkg/Ip4Dxe/Ip4Driver.c | 2 +- NetworkPkg/Ip6Dxe/Ip6Driver.c | 2 +- NetworkPkg/Mtftp4Dxe/Mtftp4Driver.c | 2 +- NetworkPkg/TlsAuthConfigDxe/TlsAuthConfigDxe.c | 2 +- 6 files changed, 7 insertions(+), 7 deletions(-) diff --git a/NetworkPkg/DnsDxe/DnsDriver.c b/NetworkPkg/DnsDxe/DnsDriver.= c index 94d072159a4d..ad007da8b7d6 100644 --- a/NetworkPkg/DnsDxe/DnsDriver.c +++ b/NetworkPkg/DnsDxe/DnsDriver.c @@ -1145,7 +1145,7 @@ Dns4ServiceBindingCreateChild ( DnsSb->ConnectUdp->UdpHandle, &gEfiUdp4ProtocolGuid, gDns4DriverBinding.DriverBindingHandle, - ChildHandle + *ChildHandle ); =20 gBS->UninstallMultipleProtocolInterfaces ( @@ -1388,7 +1388,7 @@ Dns6ServiceBindingCreateChild ( DnsSb->ConnectUdp->UdpHandle, &gEfiUdp6ProtocolGuid, gDns6DriverBinding.DriverBindingHandle, - ChildHandle + *ChildHandle ); =20 gBS->UninstallMultipleProtocolInterfaces ( diff --git a/NetworkPkg/IScsiDxe/IScsiConfig.c b/NetworkPkg/IScsiDxe/IScs= iConfig.c index b876da7f5ccd..d773849fd3b0 100644 --- a/NetworkPkg/IScsiDxe/IScsiConfig.c +++ b/NetworkPkg/IScsiDxe/IScsiConfig.c @@ -3852,7 +3852,7 @@ IScsiConfigFormInit ( ); if (CallbackInfo->RegisteredHandle =3D=3D NULL) { gBS->UninstallMultipleProtocolInterfaces ( - &CallbackInfo->DriverHandle, + CallbackInfo->DriverHandle, &gEfiDevicePathProtocolGuid, &mIScsiHiiVendorDevicePath, &gEfiHiiConfigAccessProtocolGuid, diff --git a/NetworkPkg/Ip4Dxe/Ip4Driver.c b/NetworkPkg/Ip4Dxe/Ip4Driver.= c index ebd4dec1dfe4..62be8b681a18 100644 --- a/NetworkPkg/Ip4Dxe/Ip4Driver.c +++ b/NetworkPkg/Ip4Dxe/Ip4Driver.c @@ -891,7 +891,7 @@ Ip4ServiceBindingCreateChild ( ); if (EFI_ERROR (Status)) { gBS->UninstallMultipleProtocolInterfaces ( - ChildHandle, + *ChildHandle, &gEfiIp4ProtocolGuid, &IpInstance->Ip4Proto, NULL diff --git a/NetworkPkg/Ip6Dxe/Ip6Driver.c b/NetworkPkg/Ip6Dxe/Ip6Driver.= c index 7dc9e45af7b6..63d8428dbced 100644 --- a/NetworkPkg/Ip6Dxe/Ip6Driver.c +++ b/NetworkPkg/Ip6Dxe/Ip6Driver.c @@ -888,7 +888,7 @@ Ip6ServiceBindingCreateChild ( ); if (EFI_ERROR (Status)) { gBS->UninstallMultipleProtocolInterfaces ( - ChildHandle, + *ChildHandle, &gEfiIp6ProtocolGuid, &IpInstance->Ip6Proto, NULL diff --git a/NetworkPkg/Mtftp4Dxe/Mtftp4Driver.c b/NetworkPkg/Mtftp4Dxe/M= tftp4Driver.c index ae9e65544a86..06c4e202d3ef 100644 --- a/NetworkPkg/Mtftp4Dxe/Mtftp4Driver.c +++ b/NetworkPkg/Mtftp4Dxe/Mtftp4Driver.c @@ -592,7 +592,7 @@ Mtftp4ServiceBindingCreateChild ( MtftpSb->ConnectUdp->UdpHandle, &gEfiUdp4ProtocolGuid, gMtftp4DriverBinding.DriverBindingHandle, - ChildHandle + *ChildHandle ); goto ON_ERROR; } diff --git a/NetworkPkg/TlsAuthConfigDxe/TlsAuthConfigDxe.c b/NetworkPkg/= TlsAuthConfigDxe/TlsAuthConfigDxe.c index 18ee763002b4..c0870ab9979c 100644 --- a/NetworkPkg/TlsAuthConfigDxe/TlsAuthConfigDxe.c +++ b/NetworkPkg/TlsAuthConfigDxe/TlsAuthConfigDxe.c @@ -39,7 +39,7 @@ TlsAuthConfigDxeUnload ( ASSERT (PrivateData->Signature =3D=3D TLS_AUTH_CONFIG_PRIVATE_DATA_SIG= NATURE); =20 gBS->UninstallMultipleProtocolInterfaces ( - &ImageHandle, + ImageHandle, &gEfiCallerIdGuid, PrivateData, NULL --=20 2.19.1.3.g30247aa5d201