IntelFrameworkModulePkg:Refine the code in LegacyBootMaintUiLib

Refine the code in LegacyBootMaintUiLib to prevent the potential risk.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Dandan Bi <dandan.bi@intel.com>

Reviewed-by: Qiu Shumin <shumin.qiu@intel.com>
Reviewed-by: Eric Dong <eric.dong@intel.com>

git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@18215 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
Dandan Bi 2015-08-13 00:56:09 +00:00 committed by dandanbi
parent d91cb87049
commit fa6c39dbfb
1 changed files with 9 additions and 4 deletions

View File

@ -144,6 +144,8 @@ OrderLegacyBootOption4SameType (
*EnBootOptionCount = 0; *EnBootOptionCount = 0;
Index = 0; Index = 0;
ASSERT (BbsIndexArray != NULL);
ASSERT (DeviceTypeArray != NULL);
ASSERT (*EnBootOption != NULL); ASSERT (*EnBootOption != NULL);
ASSERT (*DisBootOption != NULL); ASSERT (*DisBootOption != NULL);
@ -175,6 +177,7 @@ OrderLegacyBootOption4SameType (
// //
StartPosition = BootOrderSize / sizeof (UINT16); StartPosition = BootOrderSize / sizeof (UINT16);
NewBootOption = AllocatePool (DevOrderCount * sizeof (UINT16)); NewBootOption = AllocatePool (DevOrderCount * sizeof (UINT16));
ASSERT (NewBootOption != NULL);
while (DevOrderCount-- != 0) { while (DevOrderCount-- != 0) {
for (Index = 0; Index < BootOrderSize / sizeof (UINT16); Index++) { for (Index = 0; Index < BootOrderSize / sizeof (UINT16); Index++) {
if (BbsIndexArray[Index] == (DevOrder[DevOrderCount] & 0xFF)) { if (BbsIndexArray[Index] == (DevOrder[DevOrderCount] & 0xFF)) {
@ -1178,6 +1181,7 @@ GetLegacyOptionsOrder (
UINTN Pos; UINTN Pos;
UINTN Bit; UINTN Bit;
UINT8 *DisMap; UINT8 *DisMap;
UINTN TotalLength;
LegacyDev = NULL; LegacyDev = NULL;
OptionMenu = NULL; OptionMenu = NULL;
@ -1229,7 +1233,8 @@ GetLegacyOptionsOrder (
// Create oneof tag here for FD/HD/CD #1 #2 // Create oneof tag here for FD/HD/CD #1 #2
// //
for (Index = 0; Index < OptionMenu->MenuNumber; Index++) { for (Index = 0; Index < OptionMenu->MenuNumber; Index++) {
VarDevOrder = *(UINT16 *) ((UINT8 *) DevOrder + sizeof (BBS_TYPE) + sizeof (UINT16) + Index * sizeof (UINT16)); TotalLength = sizeof (BBS_TYPE) + sizeof (UINT16) + Index * sizeof (UINT16);
VarDevOrder = *(UINT16 *) ((UINT8 *) DevOrder + TotalLength);
if (0xFF00 == (VarDevOrder & 0xFF00)) { if (0xFF00 == (VarDevOrder & 0xFF00)) {
LegacyDev[Index] = 0xFF; LegacyDev[Index] = 0xFF;
@ -1241,7 +1246,7 @@ GetLegacyOptionsOrder (
} }
} }
VarData += sizeof (BBS_TYPE); VarData ++;
VarData += *(UINT16 *) VarData; VarData += *(UINT16 *) VarData;
DevOrder = (LEGACY_DEV_ORDER_ENTRY *) VarData; DevOrder = (LEGACY_DEV_ORDER_ENTRY *) VarData;
} }