mirror of https://github.com/acidanthera/audk.git
ShellPkg: Update SetVar to use existing attributes for updating existing variables.
Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Jaben Carsey <jaben.carsey@intel.com> Reviewed-by: Erik Bjorge <erik.c.bjorge@intel.com> Reviewed-by: Tapan Shah <tapandshah@hp.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@16194 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
7fe3fbad05
commit
475387e9de
|
@ -1,7 +1,7 @@
|
|||
/** @file
|
||||
Main file for SetVar shell Debug1 function.
|
||||
|
||||
Copyright (c) 2010 - 2013, Intel Corporation. All rights reserved.<BR>
|
||||
Copyright (c) 2010 - 2014, Intel Corporation. All rights reserved.<BR>
|
||||
This program and the accompanying materials
|
||||
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
|
||||
|
@ -44,7 +44,6 @@ ShellCommandRunSetVar (
|
|||
EFI_GUID Guid;
|
||||
CONST CHAR16 *StringGuid;
|
||||
UINT32 Attributes;
|
||||
UINT32 Attributes2;
|
||||
VOID *Buffer;
|
||||
UINTN Size;
|
||||
UINTN LoopVar;
|
||||
|
@ -98,7 +97,7 @@ ShellCommandRunSetVar (
|
|||
ShellStatus = SHELL_INVALID_PARAMETER;
|
||||
}
|
||||
}
|
||||
if (Data == NULL) {
|
||||
if (Data == NULL || Data[0] != L'=') {
|
||||
//
|
||||
// Display what's there
|
||||
//
|
||||
|
@ -129,12 +128,27 @@ ShellCommandRunSetVar (
|
|||
ASSERT(ShellStatus == SHELL_SUCCESS);
|
||||
}
|
||||
} else {
|
||||
if (Data[0] == L'=') {
|
||||
//
|
||||
// Change what's there or create a new one.
|
||||
//
|
||||
|
||||
ASSERT(Data[0] == L'=');
|
||||
Data++;
|
||||
|
||||
//
|
||||
// Determine if the variable exists and get the attributes
|
||||
//
|
||||
Status = gRT->GetVariable((CHAR16*)VariableName, &Guid, &Attributes, &Size, Buffer);
|
||||
if (Status == EFI_BUFFER_TOO_SMALL) {
|
||||
Buffer = AllocateZeroPool(Size);
|
||||
Status = gRT->GetVariable((CHAR16*)VariableName, &Guid, &Attributes, &Size, Buffer);
|
||||
}
|
||||
|
||||
if (EFI_ERROR(Status) || Buffer == NULL) {
|
||||
//
|
||||
// Change what's there
|
||||
// Creating a new variable. determine attributes from command line.
|
||||
//
|
||||
Attributes = 0;
|
||||
if (ShellCommandLineGetFlag(Package, L"-bs")) {
|
||||
Attributes |= EFI_VARIABLE_BOOTSERVICE_ACCESS;
|
||||
}
|
||||
|
@ -145,6 +159,12 @@ ShellCommandRunSetVar (
|
|||
if (ShellCommandLineGetFlag(Package, L"-nv")) {
|
||||
Attributes |= EFI_VARIABLE_NON_VOLATILE;
|
||||
}
|
||||
}
|
||||
SHELL_FREE_NON_NULL(Buffer);
|
||||
|
||||
//
|
||||
// What type is the new data.
|
||||
//
|
||||
if (ShellIsHexOrDecimalNumber(Data, TRUE, FALSE)) {
|
||||
if (StrLen(Data) % 2 != 0) {
|
||||
ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM_VAL), gShellDebug1HiiHandle, Data);
|
||||
|
@ -171,17 +191,6 @@ ShellCommandRunSetVar (
|
|||
}
|
||||
}
|
||||
} else if (StrnCmp(Data, L"\"", 1) == 0) {
|
||||
Size = 0;
|
||||
Attributes2 = 0;
|
||||
Status = gRT->GetVariable((CHAR16*)VariableName, &Guid, &Attributes2, &Size, Buffer);
|
||||
if (Status == EFI_BUFFER_TOO_SMALL) {
|
||||
Buffer = AllocateZeroPool(Size);
|
||||
Status = gRT->GetVariable((CHAR16*)VariableName, &Guid, &Attributes2, &Size, Buffer);
|
||||
if (Buffer != NULL) {
|
||||
FreePool(Buffer);
|
||||
}
|
||||
Attributes = Attributes2;
|
||||
}
|
||||
//
|
||||
// ascii text
|
||||
//
|
||||
|
|
Loading…
Reference in New Issue