MdeModulePkg/Universal/PlatformDriOverrideDxe: Use safe string functions to refine code.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Qiu Shumin <shumin.qiu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>

git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17787 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
Qiu Shumin 2015-07-01 08:28:13 +00:00 committed by shenshushi
parent e85e284e25
commit 3860b1a232

View File

@ -333,6 +333,7 @@ UpdateDeviceSelectPage (
EFI_STATUS Status; EFI_STATUS Status;
UINTN Index; UINTN Index;
UINTN DevicePathHandleCount; UINTN DevicePathHandleCount;
UINTN NewStrSize;
CHAR16 *NewString; CHAR16 *NewString;
EFI_STRING_ID NewStringToken; EFI_STRING_ID NewStringToken;
CHAR16 *ControllerName; CHAR16 *ControllerName;
@ -489,14 +490,15 @@ UpdateDeviceSelectPage (
// Export the driver name string and create item in set options page // Export the driver name string and create item in set options page
// //
Len = StrSize (ControllerName); Len = StrSize (ControllerName);
NewString = AllocateZeroPool (Len + StrSize (L"--")); NewStrSize = Len + StrSize (L"--");
NewString = AllocateZeroPool (NewStrSize);
ASSERT (NewString != NULL); ASSERT (NewString != NULL);
if (EFI_ERROR (CheckMapping (ControllerDevicePath,NULL, &mMappingDataBase, NULL, NULL))) { if (EFI_ERROR (CheckMapping (ControllerDevicePath,NULL, &mMappingDataBase, NULL, NULL))) {
StrCat (NewString, L"--"); StrCatS (NewString, NewStrSize/sizeof(CHAR16), L"--");
} else { } else {
StrCat (NewString, L"**"); StrCatS (NewString, NewStrSize/sizeof(CHAR16), L"**");
} }
StrCat (NewString, ControllerName); StrCatS (NewString, NewStrSize/sizeof(CHAR16), ControllerName);
NewStringToken = HiiSetString (Private->RegisteredHandle, mControllerToken[Index], NewString, NULL); NewStringToken = HiiSetString (Private->RegisteredHandle, mControllerToken[Index], NewString, NULL);
ASSERT (NewStringToken != 0); ASSERT (NewStringToken != 0);
@ -622,6 +624,7 @@ UpdateBindingDriverSelectPage (
{ {
EFI_STATUS Status; EFI_STATUS Status;
UINTN Index; UINTN Index;
UINTN NewStrSize;
CHAR16 *NewString; CHAR16 *NewString;
EFI_STRING_ID NewStringToken; EFI_STRING_ID NewStringToken;
EFI_STRING_ID NewStringHelpToken; EFI_STRING_ID NewStringHelpToken;
@ -814,7 +817,8 @@ UpdateBindingDriverSelectPage (
// //
// First create the driver image name // First create the driver image name
// //
NewString = AllocateZeroPool (StrSize (DriverName)); NewStrSize = StrSize (DriverName);
NewString = AllocateZeroPool (NewStrSize);
ASSERT (NewString != NULL); ASSERT (NewString != NULL);
if (EFI_ERROR (CheckMapping (mControllerDevicePathProtocol[mSelectedCtrIndex], LoadedImageDevicePath, &mMappingDataBase, NULL, NULL))) { if (EFI_ERROR (CheckMapping (mControllerDevicePathProtocol[mSelectedCtrIndex], LoadedImageDevicePath, &mMappingDataBase, NULL, NULL))) {
mDriSelection[Index] = FALSE; mDriSelection[Index] = FALSE;
@ -822,7 +826,7 @@ UpdateBindingDriverSelectPage (
mDriSelection[Index] = TRUE; mDriSelection[Index] = TRUE;
mLastSavedDriverImageNum++; mLastSavedDriverImageNum++;
} }
StrCat (NewString, DriverName); StrCatS (NewString, NewStrSize/sizeof(CHAR16), DriverName);
NewStringToken = HiiSetString (Private->RegisteredHandle, mDriverImageToken[Index], NewString, NULL); NewStringToken = HiiSetString (Private->RegisteredHandle, mDriverImageToken[Index], NewString, NULL);
ASSERT (NewStringToken != 0); ASSERT (NewStringToken != 0);
mDriverImageToken[Index] = NewStringToken; mDriverImageToken[Index] = NewStringToken;
@ -836,9 +840,10 @@ UpdateBindingDriverSelectPage (
// //
DriverName = DevicePathToStr (LoadedImageDevicePath); DriverName = DevicePathToStr (LoadedImageDevicePath);
NewString = AllocateZeroPool (StrSize (DriverName)); NewStrSize = StrSize (DriverName);
NewString = AllocateZeroPool (NewStrSize);
ASSERT (NewString != NULL); ASSERT (NewString != NULL);
StrCat (NewString, DriverName); StrCatS (NewString, NewStrSize/sizeof(CHAR16), DriverName);
NewStringHelpToken = HiiSetString (Private->RegisteredHandle, DriverImageFilePathToken[Index], NewString, NULL); NewStringHelpToken = HiiSetString (Private->RegisteredHandle, DriverImageFilePathToken[Index], NewString, NULL);
ASSERT (NewStringHelpToken != 0); ASSERT (NewStringHelpToken != 0);
DriverImageFilePathToken[Index] = NewStringHelpToken; DriverImageFilePathToken[Index] = NewStringHelpToken;