blob: 3d9fdae5b5bbe332ba4cfb0da8bf471e7d009ab9 [file] [log] [blame]
/*++
Copyright (c) 2007, Intel Corporation
All rights reserved. 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
http://opensource.org/licenses/bsd-license.php
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
Module Name:
EdbCmdRegister.c
Abstract:
--*/
#include "Edb.h"
EFI_DEBUG_STATUS
DebuggerRegister (
IN CHAR16 *CommandArg,
IN EFI_DEBUGGER_PRIVATE_DATA *DebuggerPrivate,
IN EFI_EXCEPTION_TYPE ExceptionType,
IN OUT EFI_SYSTEM_CONTEXT SystemContext
)
/*++
Routine Description:
DebuggerCommand - Register
Arguments:
CommandArg - The argument for this command
DebuggerPrivate - EBC Debugger private data structure
InterruptType - Interrupt type.
SystemContext - EBC system context.
Returns:
EFI_DEBUG_CONTINUE - formal return value
--*/
{
CHAR16 *RegName;
CHAR16 *RegValStr;
UINT64 RegVal;
//
// Check Argument, NULL means print all register
//
if (CommandArg == 0) {
EDBPrint (
L" R0 - 0x%016lx, R1 - 0x%016lx\n",
SystemContext.SystemContextEbc->R0,
SystemContext.SystemContextEbc->R1
);
EDBPrint (
L" R2 - 0x%016lx, R3 - 0x%016lx\n",
SystemContext.SystemContextEbc->R2,
SystemContext.SystemContextEbc->R3
);
EDBPrint (
L" R4 - 0x%016lx, R5 - 0x%016lx\n",
SystemContext.SystemContextEbc->R4,
SystemContext.SystemContextEbc->R5
);
EDBPrint (
L" R6 - 0x%016lx, R7 - 0x%016lx\n",
SystemContext.SystemContextEbc->R6,
SystemContext.SystemContextEbc->R7
);
EDBPrint (
L" Flags - 0x%016lx, ControlFlags - 0x%016lx\n",
SystemContext.SystemContextEbc->Flags,
SystemContext.SystemContextEbc->ControlFlags
);
EDBPrint (
L" Ip - 0x%016lx\n",
SystemContext.SystemContextEbc->Ip
);
return EFI_DEBUG_CONTINUE;
}
//
// Get register name
//
RegName = CommandArg;
//
// Get register value
//
RegValStr = StrGetNextTokenLine (L" ");
if (RegValStr == NULL) {
EDBPrint (L"Invalid Register Value\n");
return EFI_DEBUG_CONTINUE;
}
RegVal = LXtoi (RegValStr);
//
// Assign register value
//
if (StriCmp (RegName, L"R0") == 0) {
SystemContext.SystemContextEbc->R0 = RegVal;
} else if (StriCmp (RegName, L"R1") == 0) {
SystemContext.SystemContextEbc->R1 = RegVal;
} else if (StriCmp (RegName, L"R2") == 0) {
SystemContext.SystemContextEbc->R2 = RegVal;
} else if (StriCmp (RegName, L"R3") == 0) {
SystemContext.SystemContextEbc->R3 = RegVal;
} else if (StriCmp (RegName, L"R4") == 0) {
SystemContext.SystemContextEbc->R4 = RegVal;
} else if (StriCmp (RegName, L"R5") == 0) {
SystemContext.SystemContextEbc->R5 = RegVal;
} else if (StriCmp (RegName, L"R6") == 0) {
SystemContext.SystemContextEbc->R6 = RegVal;
} else if (StriCmp (RegName, L"R7") == 0) {
SystemContext.SystemContextEbc->R7 = RegVal;
} else if (StriCmp (RegName, L"Flags") == 0) {
SystemContext.SystemContextEbc->Flags = RegVal;
} else if (StriCmp (RegName, L"ControlFlags") == 0) {
SystemContext.SystemContextEbc->ControlFlags = RegVal;
} else if (StriCmp (RegName, L"Ip") == 0) {
SystemContext.SystemContextEbc->Ip = RegVal;
} else {
EDBPrint (L"Invalid Register - %s\n", RegName);
}
//
// Done
//
return EFI_DEBUG_CONTINUE;
}