UINTN Spaces = 0;\r
CHAR8 Blanks[80];\r
\r
- AsciiStrCpy (Blanks, mBlanks);\r
+ AsciiStrCpyS (Blanks, sizeof Blanks, mBlanks);\r
for (EndAddress = Address + Length; Address < EndAddress; Offset += Line) {\r
AsciiPrint ("%08x: ", Offset);\r
for (Line = 0; (Line < 0x10) && (Address < EndAddress);) {\r
UnicodeFileName[0] = '\0';\r
MatchSubString = &UnicodeFileName[0];\r
if (Argc > 2) {\r
- AsciiStrToUnicodeStr (Argv[2], UnicodeFileName);\r
+ AsciiStrToUnicodeStrS (Argv[2], UnicodeFileName,\r
+ ARRAY_SIZE (UnicodeFileName));\r
if (UnicodeFileName[0] == '*') {\r
// Handle *Name substring matching\r
MatchSubString = &UnicodeFileName[1];\r
MatchSubString = NULL;\r
UnicodeFileName[0] = '\0';\r
if (Argc > 2) {\r
- AsciiStrToUnicodeStr (Argv[2], UnicodeFileName);\r
+ AsciiStrToUnicodeStrS (Argv[2], UnicodeFileName, MAX_CMD_LINE);\r
if (UnicodeFileName[0] == '*') {\r
MatchSubString = &UnicodeFileName[1];\r
}\r
\r
ImageInfo->LoadOptionsSize = (UINT32)AsciiStrSize (Argv[2]);\r
ImageInfo->LoadOptions = AllocatePool (ImageInfo->LoadOptionsSize);\r
- AsciiStrCpy (ImageInfo->LoadOptions, Argv[2]);\r
+ AsciiStrCpyS (ImageInfo->LoadOptions, ImageInfo->LoadOptionsSize, Argv[2]);\r
}\r
\r
// Transfer control to the EFI image we loaded with LoadImage()\r
UINTN Size;\r
UINTN Offset;\r
UINTN Chunk = FILE_COPY_CHUNK;\r
- UINTN FileNameLen;\r
+ UINTN FileNameLen, DestFileNameLen;\r
CHAR8* DestFileName;\r
CHAR8* SrcFileName;\r
CHAR8* SrcPtr;\r
}\r
\r
// Construct the destination filepath\r
- DestFileName = (CHAR8*)AllocatePool (FileNameLen + AsciiStrLen (SrcFileName) + 1);\r
- AsciiStrCpy (DestFileName, Argv[2]);\r
- AsciiStrCat (DestFileName, SrcFileName);\r
+ DestFileNameLen = FileNameLen + AsciiStrLen (SrcFileName) + 1;\r
+ DestFileName = (CHAR8*)AllocatePool (DestFileNameLen);\r
+ AsciiStrCpyS (DestFileName, DestFileNameLen, Argv[2]);\r
+ AsciiStrCatS (DestFileName, DestFileNameLen, SrcFileName);\r
}\r
\r
Source = EfiOpen(Argv[1], EFI_FILE_MODE_READ, 0);\r
}\r
\r
// Copy the new command line into the ring buffer\r
- AsciiStrnCpy(&mCmdHistory[mCmdHistoryStart][0], Cmd, MAX_CMD_LINE);\r
+ AsciiStrnCpyS (&mCmdHistory[mCmdHistoryStart][0], MAX_CMD_LINE, Cmd, MAX_CMD_LINE);\r
}\r
\r
// Reset the command history for the next up arrow press\r
}\r
AsciiPrint (History);\r
Index = AsciiStrLen (History);\r
- AsciiStrnCpy (Cmd, History, CmdMaxSize);\r
+ AsciiStrnCpyS (Cmd, CmdMaxSize, History, CmdMaxSize);\r
} else {\r
Cmd[Index++] = Char;\r
if (FixedPcdGetBool(PcdEmbeddedShellCharacterEcho) == TRUE) {\r
\r
Status = gRT->GetVariable(CommandLineVariableName, &VendorGuid, NULL, &CommandLineVariableSize, CommandLineVariable);\r
if (!EFI_ERROR(Status)) {\r
- UnicodeStrToAsciiStr(CommandLineVariable, CmdLine);\r
+ UnicodeStrToAsciiStrS (CommandLineVariable, CmdLine, MAX_CMD_LINE);\r
}\r
\r
FreePool(CommandLineVariable);\r
}\r
\r
if (EFI_ERROR(Status)) {\r
- AsciiStrCpy (CmdLine, (CHAR8 *)PcdGetPtr (PcdEmbeddedAutomaticBootCommand));\r
+ AsciiStrCpyS (CmdLine, MAX_CMD_LINE, (CHAR8 *)PcdGetPtr (PcdEmbeddedAutomaticBootCommand));\r
}\r
\r
for (;;) {\r
VOID* Value;\r
CHAR8* AsciiVariableName = NULL;\r
CHAR16* VariableName;\r
+ UINTN VariableNameLen;\r
UINT32 Index;\r
\r
if (Argc == 1) {\r
AsciiPrint("Variable name is missing.\n");\r
return Status;\r
} else {\r
- VariableName = AllocatePool((AsciiStrLen (AsciiVariableName) + 1) * sizeof (CHAR16));\r
- AsciiStrToUnicodeStr (AsciiVariableName,VariableName);\r
+ VariableNameLen = AsciiStrLen (AsciiVariableName) + 1;\r
+ VariableName = AllocatePool (VariableNameLen * sizeof (CHAR16));\r
+ AsciiStrToUnicodeStrS (AsciiVariableName, VariableName, VariableNameLen);\r
}\r
\r
// Try to get the variable size.\r
CHAR8* AsciiValue;\r
UINT32 AsciiValueLength;\r
CHAR16* VariableName;\r
+ UINTN VariableNameLen;\r
UINT32 Index;\r
UINT32 EscapedQuotes = 0;\r
BOOLEAN Volatile = FALSE;\r
//\r
\r
// Convert VariableName into Unicode\r
- VariableName = AllocatePool((AsciiStrLen (AsciiVariableSetting) + 1) * sizeof (CHAR16));\r
- AsciiStrToUnicodeStr (AsciiVariableSetting,VariableName);\r
+ VariableNameLen = AsciiStrLen (AsciiVariableSetting) + 1;\r
+ VariableName = AllocatePool (VariableNameLen * sizeof (CHAR16));\r
+ AsciiStrToUnicodeStrS (AsciiVariableSetting, VariableName, VariableNameLen);\r
\r
Status = gRT->SetVariable (\r
VariableName,\r
}\r
\r
// Convert VariableName into Unicode\r
- VariableName = AllocatePool((AsciiStrLen (AsciiVariableName) + 1) * sizeof (CHAR16));\r
- AsciiStrToUnicodeStr (AsciiVariableName,VariableName);\r
+ VariableNameLen = AsciiStrLen (AsciiVariableName) + 1;\r
+ VariableName = AllocatePool (VariableNameLen * sizeof (CHAR16));\r
+ AsciiStrToUnicodeStrS (AsciiVariableName, VariableName, VariableNameLen);\r
\r
Status = gRT->SetVariable (\r
VariableName,\r