IntelFrameworkModulePkg BootMaint: Use safe string functions
Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Hao Wu <hao.a.wu@intel.com> Reviewed-by: Jeff Fan <jeff.fan@intel.com> Reviewed-by: Jaben Carsey <jaben.carsey@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17736 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
19d02cc20c
commit
49264dac6e
|
@ -5,7 +5,7 @@
|
||||||
|
|
||||||
Boot option manipulation
|
Boot option manipulation
|
||||||
|
|
||||||
Copyright (c) 2004 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -1010,11 +1010,9 @@ BOpt_GetBootOptions (
|
||||||
|
|
||||||
StringSize = StrSize((UINT16*)LoadOptionPtr);
|
StringSize = StrSize((UINT16*)LoadOptionPtr);
|
||||||
|
|
||||||
NewLoadContext->Description = AllocateZeroPool (StrSize((UINT16*)LoadOptionPtr));
|
NewLoadContext->Description = AllocateCopyPool (StrSize((UINT16*)LoadOptionPtr), LoadOptionPtr);
|
||||||
ASSERT (NewLoadContext->Description != NULL);
|
|
||||||
StrCpy (NewLoadContext->Description, (UINT16*)LoadOptionPtr);
|
|
||||||
|
|
||||||
ASSERT (NewLoadContext->Description != NULL);
|
ASSERT (NewLoadContext->Description != NULL);
|
||||||
|
|
||||||
NewMenuEntry->DisplayString = NewLoadContext->Description;
|
NewMenuEntry->DisplayString = NewLoadContext->Description;
|
||||||
|
|
||||||
LoadOptionPtr += StringSize;
|
LoadOptionPtr += StringSize;
|
||||||
|
@ -1089,6 +1087,7 @@ BOpt_AppendFileName (
|
||||||
{
|
{
|
||||||
UINTN Size1;
|
UINTN Size1;
|
||||||
UINTN Size2;
|
UINTN Size2;
|
||||||
|
UINTN MaxLen;
|
||||||
CHAR16 *Str;
|
CHAR16 *Str;
|
||||||
CHAR16 *TmpStr;
|
CHAR16 *TmpStr;
|
||||||
CHAR16 *Ptr;
|
CHAR16 *Ptr;
|
||||||
|
@ -1096,18 +1095,18 @@ BOpt_AppendFileName (
|
||||||
|
|
||||||
Size1 = StrSize (Str1);
|
Size1 = StrSize (Str1);
|
||||||
Size2 = StrSize (Str2);
|
Size2 = StrSize (Str2);
|
||||||
Str = AllocateZeroPool (Size1 + Size2 + sizeof (CHAR16));
|
MaxLen = (Size1 + Size2 + sizeof (CHAR16)) / sizeof (CHAR16);
|
||||||
|
Str = AllocateCopyPool (MaxLen * sizeof (CHAR16), Str1);
|
||||||
ASSERT (Str != NULL);
|
ASSERT (Str != NULL);
|
||||||
|
|
||||||
TmpStr = AllocateZeroPool (Size1 + Size2 + sizeof (CHAR16));
|
TmpStr = AllocateZeroPool (MaxLen * sizeof (CHAR16));
|
||||||
ASSERT (TmpStr != NULL);
|
ASSERT (TmpStr != NULL);
|
||||||
|
|
||||||
StrCat (Str, Str1);
|
|
||||||
if (!((*Str == '\\') && (*(Str + 1) == 0))) {
|
if (!((*Str == '\\') && (*(Str + 1) == 0))) {
|
||||||
StrCat (Str, L"\\");
|
StrCatS (Str, MaxLen, L"\\");
|
||||||
}
|
}
|
||||||
|
|
||||||
StrCat (Str, Str2);
|
StrCatS (Str, MaxLen, Str2);
|
||||||
|
|
||||||
Ptr = Str;
|
Ptr = Str;
|
||||||
LastSlash = Str;
|
LastSlash = Str;
|
||||||
|
@ -1120,11 +1119,11 @@ BOpt_AppendFileName (
|
||||||
//
|
//
|
||||||
|
|
||||||
//
|
//
|
||||||
// Use TmpStr as a backup, as StrCpy in BaseLib does not handle copy of two strings
|
// Use TmpStr as a backup, as StrCpyS in BaseLib does not handle copy of two strings
|
||||||
// that overlap.
|
// that overlap.
|
||||||
//
|
//
|
||||||
StrCpy (TmpStr, Ptr + 3);
|
StrCpyS (TmpStr, MaxLen, Ptr + 3);
|
||||||
StrCpy (LastSlash, TmpStr);
|
StrCpyS (LastSlash, MaxLen - (UINTN) (LastSlash - Str), TmpStr);
|
||||||
Ptr = LastSlash;
|
Ptr = LastSlash;
|
||||||
} else if (*Ptr == '\\' && *(Ptr + 1) == '.' && *(Ptr + 2) == '\\') {
|
} else if (*Ptr == '\\' && *(Ptr + 1) == '.' && *(Ptr + 2) == '\\') {
|
||||||
//
|
//
|
||||||
|
@ -1132,11 +1131,11 @@ BOpt_AppendFileName (
|
||||||
//
|
//
|
||||||
|
|
||||||
//
|
//
|
||||||
// Use TmpStr as a backup, as StrCpy in BaseLib does not handle copy of two strings
|
// Use TmpStr as a backup, as StrCpyS in BaseLib does not handle copy of two strings
|
||||||
// that overlap.
|
// that overlap.
|
||||||
//
|
//
|
||||||
StrCpy (TmpStr, Ptr + 2);
|
StrCpyS (TmpStr, MaxLen, Ptr + 2);
|
||||||
StrCpy (Ptr, TmpStr);
|
StrCpyS (Ptr, MaxLen - (UINTN) (Ptr - Str), TmpStr);
|
||||||
Ptr = LastSlash;
|
Ptr = LastSlash;
|
||||||
} else if (*Ptr == '\\') {
|
} else if (*Ptr == '\\') {
|
||||||
LastSlash = Ptr;
|
LastSlash = Ptr;
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Formset guids, form id and VarStore data structure for Boot Maintenance Manager.
|
Formset guids, form id and VarStore data structure for Boot Maintenance Manager.
|
||||||
|
|
||||||
Copyright (c) 2004 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -219,14 +219,20 @@ typedef struct {
|
||||||
#define KEY_VALUE_SAVE_AND_EXIT_DRIVER 0x1002
|
#define KEY_VALUE_SAVE_AND_EXIT_DRIVER 0x1002
|
||||||
#define KEY_VALUE_NO_SAVE_AND_EXIT_DRIVER 0x1003
|
#define KEY_VALUE_NO_SAVE_AND_EXIT_DRIVER 0x1003
|
||||||
|
|
||||||
|
//
|
||||||
|
// Description data and optional data size
|
||||||
|
//
|
||||||
|
#define DESCRIPTION_DATA_SIZE 75
|
||||||
|
#define OPTIONAL_DATA_SIZE 127
|
||||||
|
|
||||||
///
|
///
|
||||||
/// This is the data structure used by File Explorer formset
|
/// This is the data structure used by File Explorer formset
|
||||||
///
|
///
|
||||||
typedef struct {
|
typedef struct {
|
||||||
UINT16 BootDescriptionData[75];
|
UINT16 BootDescriptionData[DESCRIPTION_DATA_SIZE];
|
||||||
UINT16 BootOptionalData[127];
|
UINT16 BootOptionalData[OPTIONAL_DATA_SIZE];
|
||||||
UINT16 DriverDescriptionData[75];
|
UINT16 DriverDescriptionData[DESCRIPTION_DATA_SIZE];
|
||||||
UINT16 DriverOptionalData[127];
|
UINT16 DriverOptionalData[OPTIONAL_DATA_SIZE];
|
||||||
BOOLEAN BootOptionChanged;
|
BOOLEAN BootOptionChanged;
|
||||||
BOOLEAN DriverOptionChanged;
|
BOOLEAN DriverOptionChanged;
|
||||||
UINT8 Active;
|
UINT8 Active;
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Dynamically update the pages.
|
Dynamically update the pages.
|
||||||
|
|
||||||
Copyright (c) 2004 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -830,7 +830,7 @@ UpdateConModePage (
|
||||||
//
|
//
|
||||||
UnicodeValueToString (ModeString, 0, Col, 0);
|
UnicodeValueToString (ModeString, 0, Col, 0);
|
||||||
PStr = &ModeString[0];
|
PStr = &ModeString[0];
|
||||||
StrnCat (PStr, L" x ", StrLen(L" x ") + 1);
|
StrCatS (PStr, sizeof (ModeString) / sizeof (ModeString[0]), L" x ");
|
||||||
PStr = PStr + StrLen (PStr);
|
PStr = PStr + StrLen (PStr);
|
||||||
UnicodeValueToString (PStr , 0, Row, 0);
|
UnicodeValueToString (PStr , 0, Row, 0);
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Variable operation that will be used by bootmaint
|
Variable operation that will be used by bootmaint
|
||||||
|
|
||||||
Copyright (c) 2004 - 2014, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2004 - 2015, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -579,7 +579,7 @@ Var_UpdateDriverOption (
|
||||||
);
|
);
|
||||||
|
|
||||||
if (*DescriptionData == 0x0000) {
|
if (*DescriptionData == 0x0000) {
|
||||||
StrCpy (DescriptionData, DriverString);
|
StrCpyS (DescriptionData, DESCRIPTION_DATA_SIZE, DriverString);
|
||||||
}
|
}
|
||||||
|
|
||||||
BufferSize = sizeof (UINT32) + sizeof (UINT16) + StrSize (DescriptionData);
|
BufferSize = sizeof (UINT32) + sizeof (UINT16) + StrSize (DescriptionData);
|
||||||
|
@ -763,7 +763,11 @@ Var_UpdateBootOption (
|
||||||
UnicodeSPrint (BootString, sizeof (BootString), L"Boot%04x", Index);
|
UnicodeSPrint (BootString, sizeof (BootString), L"Boot%04x", Index);
|
||||||
|
|
||||||
if (NvRamMap->BootDescriptionData[0] == 0x0000) {
|
if (NvRamMap->BootDescriptionData[0] == 0x0000) {
|
||||||
StrCpy (NvRamMap->BootDescriptionData, BootString);
|
StrCpyS (
|
||||||
|
NvRamMap->BootDescriptionData,
|
||||||
|
sizeof (NvRamMap->BootDescriptionData) / sizeof (NvRamMap->BootDescriptionData[0]),
|
||||||
|
BootString
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
BufferSize = sizeof (UINT32) + sizeof (UINT16) + StrSize (NvRamMap->BootDescriptionData);
|
BufferSize = sizeof (UINT32) + sizeof (UINT16) + StrSize (NvRamMap->BootDescriptionData);
|
||||||
|
|
Loading…
Reference in New Issue