2016-03-07 16:16:35 +01:00
|
|
|
/** @file
|
|
|
|
* Exception Handling support specific for AArch64
|
|
|
|
*
|
|
|
|
* Copyright (c) 2016 HP Development Company, L.P.
|
2020-12-22 13:21:04 +01:00
|
|
|
* Copyright (c) 2021, Arm Limited. All rights reserved.<BR>
|
2016-03-07 16:16:35 +01:00
|
|
|
*
|
2019-04-04 01:03:18 +02:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause-Patent
|
2016-03-07 16:16:35 +01:00
|
|
|
*
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include <Uefi.h>
|
|
|
|
|
|
|
|
#include <Chipset/AArch64.h>
|
2017-03-15 17:26:41 +01:00
|
|
|
#include <Library/MemoryAllocationLib.h>
|
2016-03-07 16:16:35 +01:00
|
|
|
#include <Protocol/DebugSupport.h> // for MAX_AARCH64_EXCEPTION
|
|
|
|
|
2021-12-05 23:53:50 +01:00
|
|
|
UINTN gMaxExceptionNumber = MAX_AARCH64_EXCEPTION;
|
|
|
|
EFI_EXCEPTION_CALLBACK gExceptionHandlers[MAX_AARCH64_EXCEPTION + 1] = { 0 };
|
2016-03-07 16:16:35 +01:00
|
|
|
EFI_EXCEPTION_CALLBACK gDebuggerExceptionHandlers[MAX_AARCH64_EXCEPTION + 1] = { 0 };
|
2021-12-05 23:53:50 +01:00
|
|
|
PHYSICAL_ADDRESS gExceptionVectorAlignmentMask = ARM_VECTOR_TABLE_ALIGNMENT;
|
|
|
|
UINTN gDebuggerNoHandlerValue = 0; // todo: define for AArch64
|
2016-03-07 16:16:35 +01:00
|
|
|
|
2020-06-09 03:26:30 +02:00
|
|
|
#define EL0_STACK_SIZE EFI_PAGES_TO_SIZE(2)
|
2021-12-05 23:53:50 +01:00
|
|
|
STATIC UINTN mNewStackBase[EL0_STACK_SIZE / sizeof (UINTN)];
|
2017-03-15 17:26:41 +01:00
|
|
|
|
|
|
|
VOID
|
|
|
|
RegisterEl0Stack (
|
2021-12-05 23:53:50 +01:00
|
|
|
IN VOID *Stack
|
2017-03-15 17:26:41 +01:00
|
|
|
);
|
|
|
|
|
2020-12-22 13:21:04 +01:00
|
|
|
RETURN_STATUS
|
|
|
|
ArchVectorConfig (
|
2021-12-05 23:53:50 +01:00
|
|
|
IN UINTN VectorBaseAddress
|
2016-03-07 16:16:35 +01:00
|
|
|
)
|
|
|
|
{
|
2021-12-05 23:53:50 +01:00
|
|
|
UINTN HcrReg;
|
2017-03-15 17:26:41 +01:00
|
|
|
|
2020-06-09 03:26:30 +02:00
|
|
|
// Round down sp by 16 bytes alignment
|
|
|
|
RegisterEl0Stack (
|
|
|
|
(VOID *)(((UINTN)mNewStackBase + EL0_STACK_SIZE) & ~0xFUL)
|
|
|
|
);
|
2016-03-07 16:16:35 +01:00
|
|
|
|
2021-12-05 23:53:50 +01:00
|
|
|
if (ArmReadCurrentEL () == AARCH64_EL2) {
|
|
|
|
HcrReg = ArmReadHcr ();
|
2016-03-07 16:16:35 +01:00
|
|
|
|
|
|
|
// Trap General Exceptions. All exceptions that would be routed to EL1 are routed to EL2
|
|
|
|
HcrReg |= ARM_HCR_TGE;
|
|
|
|
|
2021-12-05 23:53:50 +01:00
|
|
|
ArmWriteHcr (HcrReg);
|
2016-03-07 16:16:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return RETURN_SUCCESS;
|
|
|
|
}
|