Ping.
Any comments on this?

On Wed, Apr 26, 2023 at 01:39:27PM +0200, Gerd Hoffmann wrote:
> In case ShellConvertStringToUint64() fails the Handles are left
> uninitialized.  That can for example happen for Handle2 and Handle3 in
> case only one parameter was specified on the command line.  Which can
> trigger the ASSERT() in line 185.
> 
> Reproducer: boot ovmf to efi shell in qemu, using q35 machine type, then
> try disconnect the sata controller in efi shell.
> 
> Fix that by explicitly setting them to NULL in that case.  While being
> at it also simplify the logic and avoid pointlessly calling
> ShellConvertStringToUint64() in case ParamN is NULL.
> 
> Signed-off-by: Gerd Hoffmann <kra...@redhat.com>
> ---
>  .../UefiShellDriver1CommandsLib/Disconnect.c  | 19 +++++++++++++------
>  1 file changed, 13 insertions(+), 6 deletions(-)
> 
> diff --git a/ShellPkg/Library/UefiShellDriver1CommandsLib/Disconnect.c 
> b/ShellPkg/Library/UefiShellDriver1CommandsLib/Disconnect.c
> index fd49d1f7ceb4..fac6463e3c28 100644
> --- a/ShellPkg/Library/UefiShellDriver1CommandsLib/Disconnect.c
> +++ b/ShellPkg/Library/UefiShellDriver1CommandsLib/Disconnect.c
> @@ -160,16 +160,23 @@ ShellCommandRunDisconnect (
>          Param1 = ShellCommandLineGetRawValue (Package, 1);
>          Param2 = ShellCommandLineGetRawValue (Package, 2);
>          Param3 = ShellCommandLineGetRawValue (Package, 3);
> -        if (!EFI_ERROR (ShellConvertStringToUint64 (Param1, &Intermediate1, 
> TRUE, FALSE))) {
> -          Handle1 = Param1 != NULL ? ConvertHandleIndexToHandle 
> ((UINTN)Intermediate1) : NULL;
> +
> +        if (Param1 && !EFI_ERROR (ShellConvertStringToUint64 (Param1, 
> &Intermediate1, TRUE, FALSE))) {
> +          Handle1 = ConvertHandleIndexToHandle ((UINTN)Intermediate1);
> +        } else {
> +          Handle1 = NULL;
>          }
>  
> -        if (!EFI_ERROR (ShellConvertStringToUint64 (Param2, &Intermediate2, 
> TRUE, FALSE))) {
> -          Handle2 = Param2 != NULL ? ConvertHandleIndexToHandle 
> ((UINTN)Intermediate2) : NULL;
> +        if (Param2 && !EFI_ERROR (ShellConvertStringToUint64 (Param2, 
> &Intermediate2, TRUE, FALSE))) {
> +          Handle2 = ConvertHandleIndexToHandle ((UINTN)Intermediate2);
> +        } else {
> +          Handle2 = NULL;
>          }
>  
> -        if (!EFI_ERROR (ShellConvertStringToUint64 (Param3, &Intermediate3, 
> TRUE, FALSE))) {
> -          Handle3 = Param3 != NULL ? ConvertHandleIndexToHandle 
> ((UINTN)Intermediate3) : NULL;
> +        if (Param3 && !EFI_ERROR (ShellConvertStringToUint64 (Param3, 
> &Intermediate3, TRUE, FALSE))) {
> +          Handle3 = ConvertHandleIndexToHandle ((UINTN)Intermediate3);
> +        } else {
> +          Handle3 = NULL;
>          }
>  
>          if ((Param1 != NULL) && (Handle1 == NULL)) {
> -- 
> 2.40.0
> 

-- 



-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#103982): https://edk2.groups.io/g/devel/message/103982
Mute This Topic: https://groups.io/mt/98512679/21656
Group Owner: devel+ow...@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [arch...@mail-archive.com]
-=-=-=-=-=-=-=-=-=-=-=-


Reply via email to