2014-09-09 17:57:18 +02:00
|
|
|
/** @file
|
|
|
|
Default exception handler
|
|
|
|
|
|
|
|
Copyright (c) 2014, ARM Limited. All rights reserved.
|
|
|
|
|
2019-04-04 01:03:18 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2014-09-09 17:57:18 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include <Base.h>
|
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
#include <Library/PrintLib.h>
|
|
|
|
#include <Library/ArmDisassemblerLib.h>
|
|
|
|
|
|
|
|
/**
|
|
|
|
Place a disassembly of of **OpCodePtr into buffer, and update OpCodePtr to
|
|
|
|
point to next instruction.
|
|
|
|
|
|
|
|
@param OpCodePtrPtr Pointer to pointer of instruction to disassemble.
|
|
|
|
@param Thumb TRUE for Thumb(2), FALSE for ARM instruction stream
|
|
|
|
@param Extended TRUE dump hex for instruction too.
|
|
|
|
@param ItBlock Size of IT Block
|
|
|
|
@param Buf Buffer to sprintf disassembly into.
|
|
|
|
@param Size Size of Buf in bytes.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
DisassembleInstruction (
|
|
|
|
IN UINT8 **OpCodePtr,
|
|
|
|
IN BOOLEAN Thumb,
|
|
|
|
IN BOOLEAN Extended,
|
|
|
|
IN OUT UINT32 *ItBlock,
|
|
|
|
OUT CHAR8 *Buf,
|
|
|
|
OUT UINTN Size
|
|
|
|
)
|
|
|
|
{
|
|
|
|
// Not yet supported for AArch64.
|
|
|
|
// Put error in the buffer as we have no return code and the buffer may be
|
|
|
|
// printed directly so needs a '\0'.
|
|
|
|
AsciiSPrint (Buf, Size, "AArch64 not supported");
|
|
|
|
return;
|
|
|
|
}
|