ShellPkg/rm: fix hang when deleting an absolutely-empty directory
An ordinary empty directory should contain "." and ".." entries.
When an empty directory even doesn't contain "." or ".." entry,
FileHandleFindFirstFile() may return error status and a NULL
FileInfo.
IsDirectoryEmpty() implementation in Rm.c doesn't consider this
case and the deference of FileInfo->FileName causes page fault
exception because FileInfo is NULL.
The patch checks the return status of FileHandleFindFirstFile()
to fix this issue.
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Ruiyu Ni <ruiyu.ni@intel.com>
Reviewed-by: Jaben Carsey <jaben.carsey@intel.com>
(cherry picked from commit 7506fe43a1)
			
			
This commit is contained in:
		| @@ -2,7 +2,7 @@ | ||||
|   Main file for attrib shell level 2 function. | ||||
|  | ||||
|   (C) Copyright 2015 Hewlett-Packard Development Company, L.P.<BR> | ||||
|   Copyright (c) 2009 - 2015, Intel Corporation. All rights reserved.<BR> | ||||
|   Copyright (c) 2009 - 2018, Intel Corporation. All rights reserved.<BR> | ||||
|   This program and the accompanying materials | ||||
|   are licensed and made available under the terms and conditions of the BSD License | ||||
|   which accompanies this distribution.  The full text of the license may be found at | ||||
| @@ -33,6 +33,7 @@ IsDirectoryEmpty ( | ||||
|   IN EFI_HANDLE   FileHandle | ||||
|   ) | ||||
| { | ||||
|   EFI_STATUS      Status; | ||||
|   EFI_FILE_INFO   *FileInfo; | ||||
|   BOOLEAN         NoFile; | ||||
|   BOOLEAN         RetVal; | ||||
| @@ -41,8 +42,8 @@ IsDirectoryEmpty ( | ||||
|   NoFile = FALSE; | ||||
|   FileInfo = NULL; | ||||
|  | ||||
|   for (FileHandleFindFirstFile(FileHandle, &FileInfo) | ||||
|     ;  !NoFile | ||||
|   for (Status = FileHandleFindFirstFile(FileHandle, &FileInfo) | ||||
|     ;  !NoFile && !EFI_ERROR (Status) | ||||
|     ;  FileHandleFindNextFile(FileHandle, FileInfo, &NoFile) | ||||
|    ){ | ||||
|     if (StrStr(FileInfo->FileName, L".") != FileInfo->FileName | ||||
|   | ||||
		Reference in New Issue
	
	Block a user