mirror of https://github.com/acidanthera/audk.git
ShellPkg: Fixes for shell application launch, argument handling, and version output:
- Fixes shell application launch version output to match ‘ver’ command, as specified by the UEFI Shell spec. - Adds PcdShellSupplier for <shell-supplier-specific-data> line of version output. Defaulted to “EDK II”. - Display only 1 startup.nsh countdown line per second instead of 10 per second. - Fix issue where command line is just 1 or more “ “ characters and displayed garbage. - Fix for @echo –off and @echo –on to not restore echo state Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Chris Phillips <chrisp@hp.com> reviewed-by: Jaben Carsey <Jaben.Carsey@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@14784 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
03b08d7a06
commit
284e034f4f
|
@ -297,11 +297,28 @@ UefiMain (
|
||||||
0,
|
0,
|
||||||
gST->ConOut->Mode->CursorRow,
|
gST->ConOut->Mode->CursorRow,
|
||||||
NULL,
|
NULL,
|
||||||
STRING_TOKEN (STR_VER_OUTPUT_MAIN),
|
STRING_TOKEN (STR_VER_OUTPUT_MAIN_SHELL),
|
||||||
ShellInfoObject.HiiHandle,
|
ShellInfoObject.HiiHandle,
|
||||||
SupportLevel[PcdGet8(PcdShellSupportLevel)],
|
SupportLevel[PcdGet8(PcdShellSupportLevel)],
|
||||||
gEfiShellProtocol->MajorVersion,
|
gEfiShellProtocol->MajorVersion,
|
||||||
gEfiShellProtocol->MinorVersion,
|
gEfiShellProtocol->MinorVersion
|
||||||
|
);
|
||||||
|
|
||||||
|
ShellPrintHiiEx (
|
||||||
|
-1,
|
||||||
|
-1,
|
||||||
|
NULL,
|
||||||
|
STRING_TOKEN (STR_VER_OUTPUT_MAIN_SUPPLIER),
|
||||||
|
ShellInfoObject.HiiHandle,
|
||||||
|
(CHAR16 *) PcdGetPtr (PcdShellSupplier)
|
||||||
|
);
|
||||||
|
|
||||||
|
ShellPrintHiiEx (
|
||||||
|
-1,
|
||||||
|
-1,
|
||||||
|
NULL,
|
||||||
|
STRING_TOKEN (STR_VER_OUTPUT_MAIN_UEFI),
|
||||||
|
ShellInfoObject.HiiHandle,
|
||||||
(gST->Hdr.Revision&0xffff0000)>>16,
|
(gST->Hdr.Revision&0xffff0000)>>16,
|
||||||
(gST->Hdr.Revision&0x0000ffff),
|
(gST->Hdr.Revision&0x0000ffff),
|
||||||
gST->FirmwareVendor,
|
gST->FirmwareVendor,
|
||||||
|
@ -840,12 +857,12 @@ DoStartupScript(
|
||||||
//
|
//
|
||||||
// print out our warning and see if they press a key
|
// print out our warning and see if they press a key
|
||||||
//
|
//
|
||||||
for ( Status = EFI_UNSUPPORTED, Delay = ShellInfoObject.ShellInitSettings.Delay * 10
|
for ( Status = EFI_UNSUPPORTED, Delay = ShellInfoObject.ShellInitSettings.Delay
|
||||||
; Delay != 0 && EFI_ERROR(Status)
|
; Delay != 0 && EFI_ERROR(Status)
|
||||||
; Delay--
|
; Delay--
|
||||||
){
|
){
|
||||||
ShellPrintHiiEx(0, gST->ConOut->Mode->CursorRow, NULL, STRING_TOKEN (STR_SHELL_STARTUP_QUESTION), ShellInfoObject.HiiHandle, Delay/10);
|
ShellPrintHiiEx(0, gST->ConOut->Mode->CursorRow, NULL, STRING_TOKEN (STR_SHELL_STARTUP_QUESTION), ShellInfoObject.HiiHandle, Delay);
|
||||||
gBS->Stall (100000);
|
gBS->Stall (1000000);
|
||||||
if (!ShellInfoObject.ShellInitSettings.BitUnion.Bits.NoConsoleIn) {
|
if (!ShellInfoObject.ShellInitSettings.BitUnion.Bits.NoConsoleIn) {
|
||||||
Status = gST->ConIn->ReadKeyStroke (gST->ConIn, &Key);
|
Status = gST->ConIn->ReadKeyStroke (gST->ConIn, &Key);
|
||||||
}
|
}
|
||||||
|
@ -1396,13 +1413,32 @@ RunCommand(
|
||||||
if (CleanOriginal == NULL) {
|
if (CleanOriginal == NULL) {
|
||||||
return (EFI_OUT_OF_RESOURCES);
|
return (EFI_OUT_OF_RESOURCES);
|
||||||
}
|
}
|
||||||
while (CleanOriginal[StrLen(CleanOriginal)-1] == L' ') {
|
|
||||||
CleanOriginal[StrLen(CleanOriginal)-1] = CHAR_NULL;
|
//
|
||||||
}
|
// Remove any spaces at the beginning of the string.
|
||||||
|
//
|
||||||
while (CleanOriginal[0] == L' ') {
|
while (CleanOriginal[0] == L' ') {
|
||||||
CopyMem(CleanOriginal, CleanOriginal+1, StrSize(CleanOriginal) - sizeof(CleanOriginal[0]));
|
CopyMem(CleanOriginal, CleanOriginal+1, StrSize(CleanOriginal) - sizeof(CleanOriginal[0]));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Handle case that passed in command line is just 1 or more " " characters.
|
||||||
|
//
|
||||||
|
if (StrLen (CleanOriginal) == 0) {
|
||||||
|
if (CleanOriginal != NULL) {
|
||||||
|
FreePool(CleanOriginal);
|
||||||
|
CleanOriginal = NULL;
|
||||||
|
}
|
||||||
|
return (EFI_SUCCESS);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Remove any spaces at the end of the string.
|
||||||
|
//
|
||||||
|
while (CleanOriginal[StrLen(CleanOriginal)-1] == L' ') {
|
||||||
|
CleanOriginal[StrLen(CleanOriginal)-1] = CHAR_NULL;
|
||||||
|
}
|
||||||
|
|
||||||
CommandName = NULL;
|
CommandName = NULL;
|
||||||
if (StrStr(CleanOriginal, L" ") == NULL){
|
if (StrStr(CleanOriginal, L" ") == NULL){
|
||||||
StrnCatGrow(&CommandName, NULL, CleanOriginal, 0);
|
StrnCatGrow(&CommandName, NULL, CleanOriginal, 0);
|
||||||
|
@ -1892,9 +1928,15 @@ RunScriptFileHandle (
|
||||||
Status = RunCommand(CommandLine3+1);
|
Status = RunCommand(CommandLine3+1);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Now restore the pre-'@' echo state.
|
// If command was "@echo -off" or "@echo -on" then don't restore echo state
|
||||||
//
|
//
|
||||||
ShellCommandSetEchoState(PreCommandEchoState);
|
if (StrCmp (L"@echo -off", CommandLine3) != 0 &&
|
||||||
|
StrCmp (L"@echo -on", CommandLine3) != 0) {
|
||||||
|
//
|
||||||
|
// Now restore the pre-'@' echo state.
|
||||||
|
//
|
||||||
|
ShellCommandSetEchoState(PreCommandEchoState);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (ShellCommandGetEchoState()) {
|
if (ShellCommandGetEchoState()) {
|
||||||
CurDir = ShellInfoObject.NewEfiShellProtocol->GetEnv(L"cwd");
|
CurDir = ShellInfoObject.NewEfiShellProtocol->GetEnv(L"cwd");
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
## @file
|
## @file
|
||||||
# This is the shell application
|
# This is the shell application
|
||||||
#
|
#
|
||||||
|
# Copyright (c) 2013, Hewlett-Packard Development Company, L.P.
|
||||||
# Copyright (c) 2009 - 2013, Intel Corporation. All rights reserved.<BR>
|
# Copyright (c) 2009 - 2013, Intel Corporation. All rights reserved.<BR>
|
||||||
#
|
#
|
||||||
# This program and the accompanying materials
|
# This program and the accompanying materials
|
||||||
|
@ -106,4 +107,5 @@
|
||||||
gEfiShellPkgTokenSpaceGuid.PcdShellMapNameLength # ALWAYS_CONSUMED
|
gEfiShellPkgTokenSpaceGuid.PcdShellMapNameLength # ALWAYS_CONSUMED
|
||||||
gEfiShellPkgTokenSpaceGuid.PcdShellPrintBufferSize # ALWAYS_CONSUMED
|
gEfiShellPkgTokenSpaceGuid.PcdShellPrintBufferSize # ALWAYS_CONSUMED
|
||||||
gEfiShellPkgTokenSpaceGuid.PcdShellForceConsole # ALWAYS_CONSUMED
|
gEfiShellPkgTokenSpaceGuid.PcdShellForceConsole # ALWAYS_CONSUMED
|
||||||
|
gEfiShellPkgTokenSpaceGuid.PcdShellSupplier # ALWAYS_CONSUMED
|
||||||
|
|
||||||
|
|
Binary file not shown.
|
@ -2,6 +2,7 @@
|
||||||
# Provides shell level 3 functions
|
# Provides shell level 3 functions
|
||||||
# Note that the interactive versions of the time, date, and timezone functions are handled in the level 2 library.
|
# Note that the interactive versions of the time, date, and timezone functions are handled in the level 2 library.
|
||||||
#
|
#
|
||||||
|
# Copyright (c) 2013, Hewlett-Packard Development Company, L.P.
|
||||||
# Copyright (c) 2009-2011, Intel Corporation. All rights reserved. <BR>
|
# Copyright (c) 2009-2011, Intel Corporation. All rights reserved. <BR>
|
||||||
#
|
#
|
||||||
# This program and the accompanying materials
|
# This program and the accompanying materials
|
||||||
|
@ -66,4 +67,5 @@
|
||||||
[Pcd.common]
|
[Pcd.common]
|
||||||
gEfiShellPkgTokenSpaceGuid.PcdShellSupportLevel
|
gEfiShellPkgTokenSpaceGuid.PcdShellSupportLevel
|
||||||
gEfiShellPkgTokenSpaceGuid.PcdShellFileOperationSize
|
gEfiShellPkgTokenSpaceGuid.PcdShellFileOperationSize
|
||||||
|
gEfiShellPkgTokenSpaceGuid.PcdShellSupplier
|
||||||
|
|
||||||
|
|
Binary file not shown.
|
@ -1,6 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Main file for Ver shell level 3 function.
|
Main file for Ver shell level 3 function.
|
||||||
|
|
||||||
|
Copyright (c) 2013, Hewlett-Packard Development Company, L.P.
|
||||||
Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2009 - 2010, 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
|
||||||
|
@ -108,8 +109,9 @@ ShellCommandRunVer (
|
||||||
-1,
|
-1,
|
||||||
-1,
|
-1,
|
||||||
NULL,
|
NULL,
|
||||||
STRING_TOKEN (STR_VER_EXTRA_STRING),
|
STRING_TOKEN (STR_VER_OUTPUT_SUPPLIER),
|
||||||
gShellLevel3HiiHandle
|
gShellLevel3HiiHandle,
|
||||||
|
(CHAR16 *) PcdGetPtr (PcdShellSupplier)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
#
|
#
|
||||||
# This Package provides all definitions for EFI and UEFI Shell
|
# This Package provides all definitions for EFI and UEFI Shell
|
||||||
#
|
#
|
||||||
|
# Copyright (c) 2013, Hewlett-Packard Development Company, L.P.
|
||||||
# Copyright (c) 2009 - 2011, Intel Corporation. All rights reserved.<BR>
|
# Copyright (c) 2009 - 2011, Intel Corporation. All rights reserved.<BR>
|
||||||
#
|
#
|
||||||
# This program and the accompanying materials are licensed and made available under
|
# This program and the accompanying materials are licensed and made available under
|
||||||
|
@ -47,7 +48,7 @@
|
||||||
|
|
||||||
[Guids]
|
[Guids]
|
||||||
gEfiShellEnvironment2ExtGuid = {0xd2c18636, 0x40e5, 0x4eb5, {0xa3, 0x1b, 0x36, 0x69, 0x5f, 0xd4, 0x2c, 0x87}}
|
gEfiShellEnvironment2ExtGuid = {0xd2c18636, 0x40e5, 0x4eb5, {0xa3, 0x1b, 0x36, 0x69, 0x5f, 0xd4, 0x2c, 0x87}}
|
||||||
gEfiShellPkgTokenSpaceGuid = {0x171e9188, 0x31d3, 0x40f5, {0xb1, 0x0c, 0x53, 0x9b, 0x2d, 0xb9, 0x40, 0xcd}}
|
gEfiShellPkgTokenSpaceGuid = {0x171e9188, 0x31d3, 0x40f5, {0xb1, 0x0c, 0x53, 0x9b, 0x2d, 0xb9, 0x40, 0xcd}}
|
||||||
gShellVariableGuid = {0x158def5a, 0xf656, 0x419c, {0xb0, 0x27, 0x7a, 0x31, 0x92, 0xc0, 0x79, 0xd2}}
|
gShellVariableGuid = {0x158def5a, 0xf656, 0x419c, {0xb0, 0x27, 0x7a, 0x31, 0x92, 0xc0, 0x79, 0xd2}}
|
||||||
gShellMapGuid = {0x51271e13, 0x7de3, 0x43af, {0x8b, 0xc2, 0x71, 0xad, 0x3b, 0x82, 0x43, 0x25}}
|
gShellMapGuid = {0x51271e13, 0x7de3, 0x43af, {0x8b, 0xc2, 0x71, 0xad, 0x3b, 0x82, 0x43, 0x25}}
|
||||||
gShellAliasGuid = {0x0053d9d6, 0x2659, 0x4599, {0xa2, 0x6b, 0xef, 0x45, 0x36, 0xe6, 0x31, 0xa9}}
|
gShellAliasGuid = {0x0053d9d6, 0x2659, 0x4599, {0xa2, 0x6b, 0xef, 0x45, 0x36, 0xe6, 0x31, 0xa9}}
|
||||||
|
@ -119,3 +120,6 @@
|
||||||
## this flag determins the default number of screens kept for history log.
|
## this flag determins the default number of screens kept for history log.
|
||||||
# the spec defines 3 as the minimum
|
# the spec defines 3 as the minimum
|
||||||
gEfiShellPkgTokenSpaceGuid.PcdShellScreenLogCount|3|UINT8|0x00000008
|
gEfiShellPkgTokenSpaceGuid.PcdShellScreenLogCount|3|UINT8|0x00000008
|
||||||
|
|
||||||
|
## Unicode string of the shell supplier
|
||||||
|
gEfiShellPkgTokenSpaceGuid.PcdShellSupplier|L"EDK II"|VOID*|0x00000010
|
||||||
|
|
Loading…
Reference in New Issue