mirror of https://github.com/acidanthera/audk.git
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:
parent
d91cb87049
commit
fa6c39dbfb
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue