From af71a010d1753bf4c84a41d1d201bc7409cdf350 Mon Sep 17 00:00:00 2001 From: Yao Jiewen Date: Fri, 25 Dec 2015 02:15:44 +0000 Subject: ShellPkg: Fix memory leak in function 'EfiShellSetCurDir' and 'EfiShellSetMap'. (Sync patch r19529 from main trunk.) Cc: Ruiyu Ni Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Yao Jiewen Reviewed-by: Qiu Shumin Reviewed-by: Ruiyu Ni git-svn-id: https://svn.code.sf.net/p/edk2/code/branches/UDK2015@19541 6f19259b-4bc3-4df7-8a09-765794883524 --- ShellPkg/Application/Shell/ShellProtocol.c | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'ShellPkg/Application') diff --git a/ShellPkg/Application/Shell/ShellProtocol.c b/ShellPkg/Application/Shell/ShellProtocol.c index a6bf9c29b4..22d398757f 100644 --- a/ShellPkg/Application/Shell/ShellProtocol.c +++ b/ShellPkg/Application/Shell/ShellProtocol.c @@ -185,6 +185,9 @@ EfiShellSetMap( ){ if (StringNoCaseCompare(&MapListNode->MapName, &Mapping) == 0) { RemoveEntryList(&MapListNode->Link); + SHELL_FREE_NON_NULL(MapListNode->DevicePath); + SHELL_FREE_NON_NULL(MapListNode->MapName); + SHELL_FREE_NON_NULL(MapListNode->CurrentDirectoryPath); FreePool(MapListNode); return (EFI_SUCCESS); } @@ -2951,6 +2954,8 @@ EfiShellSetCurDir( } if (MapListItem == NULL) { + FreePool (DirectoryName); + SHELL_FREE_NON_NULL(MapName); return (EFI_NOT_FOUND); } @@ -2967,6 +2972,7 @@ EfiShellSetCurDir( ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL)); MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, DirectoryName+StrLen(MapName), 0); } + FreePool (MapName); } else { ASSERT((MapListItem->CurrentDirectoryPath == NULL && Size == 0) || (MapListItem->CurrentDirectoryPath != NULL)); MapListItem->CurrentDirectoryPath = StrnCatGrow(&MapListItem->CurrentDirectoryPath, &Size, DirectoryName, 0); @@ -2982,6 +2988,7 @@ EfiShellSetCurDir( // cant have a mapping in the directory... // if (StrStr(DirectoryName, L":") != NULL) { + FreePool (DirectoryName); return (EFI_INVALID_PARAMETER); } // @@ -2989,6 +2996,7 @@ EfiShellSetCurDir( // MapListItem = ShellCommandFindMapItem(FileSystem); if (MapListItem == NULL) { + FreePool (DirectoryName); return (EFI_INVALID_PARAMETER); } // gShellCurDir = MapListItem; @@ -3013,6 +3021,7 @@ EfiShellSetCurDir( } } } + FreePool (DirectoryName); // // if updated the current directory then update the environment variable // -- cgit v1.2.3