mirror of https://github.com/acidanthera/audk.git
ShellPkg: Connect all the consoles in "reconnect -r".
Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Qiu Shumin <shumin.qiu@intel.com> Reviewed-by: Jaben Carsey <Jaben.carsey@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16473 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
8f586b85c3
commit
d86b04fbe9
|
@ -93,6 +93,8 @@ ShellConnectPciRootBridge (
|
||||||
for (RootBridgeIndex = 0; RootBridgeIndex < RootBridgeHandleCount; RootBridgeIndex++) {
|
for (RootBridgeIndex = 0; RootBridgeIndex < RootBridgeHandleCount; RootBridgeIndex++) {
|
||||||
gBS->ConnectController (RootBridgeHandleBuffer[RootBridgeIndex], NULL, NULL, FALSE);
|
gBS->ConnectController (RootBridgeHandleBuffer[RootBridgeIndex], NULL, NULL, FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FreePool (RootBridgeHandleBuffer);
|
||||||
|
|
||||||
return EFI_SUCCESS;
|
return EFI_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -192,7 +194,7 @@ ConnectControllers (
|
||||||
**/
|
**/
|
||||||
EFI_STATUS
|
EFI_STATUS
|
||||||
EFIAPI
|
EFIAPI
|
||||||
ConnectFromDevPaths (
|
ShellConnectFromDevPaths (
|
||||||
IN CONST CHAR16 *Key
|
IN CONST CHAR16 *Key
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
@ -462,31 +464,31 @@ ShellCommandRunConnect (
|
||||||
// do the conin and conout from EFI variables
|
// do the conin and conout from EFI variables
|
||||||
// if the first fails dont 'loose' the error
|
// if the first fails dont 'loose' the error
|
||||||
//
|
//
|
||||||
Status = ConnectFromDevPaths(L"ConInDev");
|
Status = ShellConnectFromDevPaths(L"ConInDev");
|
||||||
if (EFI_ERROR(Status)) {
|
if (EFI_ERROR(Status)) {
|
||||||
ConnectFromDevPaths(L"ConOutDev");
|
ShellConnectFromDevPaths(L"ConOutDev");
|
||||||
} else {
|
} else {
|
||||||
Status = ConnectFromDevPaths(L"ConOutDev");
|
Status = ShellConnectFromDevPaths(L"ConOutDev");
|
||||||
}
|
}
|
||||||
if (EFI_ERROR(Status)) {
|
if (EFI_ERROR(Status)) {
|
||||||
ConnectFromDevPaths(L"ErrOutDev");
|
ShellConnectFromDevPaths(L"ErrOutDev");
|
||||||
} else {
|
} else {
|
||||||
Status = ConnectFromDevPaths(L"ErrOutDev");
|
Status = ShellConnectFromDevPaths(L"ErrOutDev");
|
||||||
}
|
}
|
||||||
if (EFI_ERROR(Status)) {
|
if (EFI_ERROR(Status)) {
|
||||||
ConnectFromDevPaths(L"ErrOut");
|
ShellConnectFromDevPaths(L"ErrOut");
|
||||||
} else {
|
} else {
|
||||||
Status = ConnectFromDevPaths(L"ErrOut");
|
Status = ShellConnectFromDevPaths(L"ErrOut");
|
||||||
}
|
}
|
||||||
if (EFI_ERROR(Status)) {
|
if (EFI_ERROR(Status)) {
|
||||||
ConnectFromDevPaths(L"ConIn");
|
ShellConnectFromDevPaths(L"ConIn");
|
||||||
} else {
|
} else {
|
||||||
Status = ConnectFromDevPaths(L"ConIn");
|
Status = ShellConnectFromDevPaths(L"ConIn");
|
||||||
}
|
}
|
||||||
if (EFI_ERROR(Status)) {
|
if (EFI_ERROR(Status)) {
|
||||||
ConnectFromDevPaths(L"ConOut");
|
ShellConnectFromDevPaths(L"ConOut");
|
||||||
} else {
|
} else {
|
||||||
Status = ConnectFromDevPaths(L"ConOut");
|
Status = ShellConnectFromDevPaths(L"ConOut");
|
||||||
}
|
}
|
||||||
if (EFI_ERROR(Status)) {
|
if (EFI_ERROR(Status)) {
|
||||||
ShellStatus = SHELL_DEVICE_ERROR;
|
ShellStatus = SHELL_DEVICE_ERROR;
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/** @file
|
/** @file
|
||||||
Main file for Reconnect shell Driver1 function.
|
Main file for Reconnect shell Driver1 function.
|
||||||
|
|
||||||
Copyright (c) 2010 - 2011, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2010 - 2014, 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
|
||||||
|
@ -14,6 +14,30 @@
|
||||||
|
|
||||||
#include "UefiShellDriver1CommandsLib.h"
|
#include "UefiShellDriver1CommandsLib.h"
|
||||||
|
|
||||||
|
STATIC CONST SHELL_PARAM_ITEM ParamList[] = {
|
||||||
|
{L"-r", TypeFlag},
|
||||||
|
{NULL, TypeMax}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
Connect all the possible console devices.
|
||||||
|
|
||||||
|
**/
|
||||||
|
VOID
|
||||||
|
ConnectAllConsoles (
|
||||||
|
VOID
|
||||||
|
)
|
||||||
|
{
|
||||||
|
ShellConnectFromDevPaths(L"ConInDev");
|
||||||
|
ShellConnectFromDevPaths(L"ConOutDev");
|
||||||
|
ShellConnectFromDevPaths(L"ErrOutDev");
|
||||||
|
|
||||||
|
ShellConnectFromDevPaths(L"ErrOut");
|
||||||
|
ShellConnectFromDevPaths(L"ConIn");
|
||||||
|
ShellConnectFromDevPaths(L"ConOut");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Function for 'reconnect' command.
|
Function for 'reconnect' command.
|
||||||
|
|
||||||
|
@ -28,15 +52,46 @@ ShellCommandRunReconnect (
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
SHELL_STATUS ShellStatus;
|
SHELL_STATUS ShellStatus;
|
||||||
|
LIST_ENTRY *Package;
|
||||||
|
CHAR16 *ProblemParam;
|
||||||
|
EFI_STATUS Status;
|
||||||
|
|
||||||
gInReconnect = TRUE;
|
gInReconnect = TRUE;
|
||||||
|
ShellStatus = SHELL_SUCCESS;
|
||||||
|
|
||||||
|
//
|
||||||
|
// initialize the shell lib (we must be in non-auto-init...)
|
||||||
|
//
|
||||||
|
Status = ShellInitialize();
|
||||||
|
ASSERT_EFI_ERROR(Status);
|
||||||
|
|
||||||
ShellStatus = ShellCommandRunDisconnect(ImageHandle, SystemTable);
|
Status = CommandInit();
|
||||||
if (ShellStatus == SHELL_SUCCESS) {
|
ASSERT_EFI_ERROR(Status);
|
||||||
ShellStatus = ShellCommandRunConnect(ImageHandle, SystemTable);
|
|
||||||
}
|
//
|
||||||
|
// parse the command line
|
||||||
|
//
|
||||||
|
Status = ShellCommandLineParse (ParamList, &Package, &ProblemParam, TRUE);
|
||||||
|
if (EFI_ERROR(Status)) {
|
||||||
|
if (Status == EFI_VOLUME_CORRUPTED && ProblemParam != NULL) {
|
||||||
|
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM), gShellDriver1HiiHandle, ProblemParam);
|
||||||
|
FreePool(ProblemParam);
|
||||||
|
ShellStatus = SHELL_INVALID_PARAMETER;
|
||||||
|
} else {
|
||||||
|
ASSERT(FALSE);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ShellStatus = ShellCommandRunDisconnect(ImageHandle, SystemTable);
|
||||||
|
if (ShellStatus == SHELL_SUCCESS) {
|
||||||
|
if (ShellCommandLineGetFlag(Package, L"-r")) {
|
||||||
|
ConnectAllConsoles();
|
||||||
|
}
|
||||||
|
ShellStatus = ShellCommandRunConnect(ImageHandle, SystemTable);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
gInReconnect = FALSE;
|
gInReconnect = FALSE;
|
||||||
|
|
||||||
return (ShellStatus);
|
return (ShellStatus);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -207,5 +207,20 @@ ShellCommandRunUnload (
|
||||||
IN EFI_SYSTEM_TABLE *SystemTable
|
IN EFI_SYSTEM_TABLE *SystemTable
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Do a connect from an EFI variable via it's key name.
|
||||||
|
|
||||||
|
@param[in] Key The name of the EFI Variable.
|
||||||
|
|
||||||
|
@retval EFI_SUCCESS The operation was successful.
|
||||||
|
**/
|
||||||
|
EFI_STATUS
|
||||||
|
EFIAPI
|
||||||
|
ShellConnectFromDevPaths (
|
||||||
|
IN CONST CHAR16 *Key
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue