REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3737 Apply uncrustify changes to .c/.h files in the ArmPkg package Cc: Andrew Fish <afish@apple.com> Cc: Leif Lindholm <leif@nuviainc.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Andrew Fish <afish@apple.com>
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| *  Exception Handling support specific for AArch64
 | |
| *
 | |
| *  Copyright (c) 2016 HP Development Company, L.P.
 | |
| *  Copyright (c) 2021, Arm Limited. All rights reserved.<BR>
 | |
| *
 | |
| *  SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| *
 | |
| **/
 | |
| 
 | |
| #include <Uefi.h>
 | |
| 
 | |
| #include <Chipset/AArch64.h>
 | |
| #include <Library/MemoryAllocationLib.h>
 | |
| #include <Protocol/DebugSupport.h> // for MAX_AARCH64_EXCEPTION
 | |
| 
 | |
| UINTN                   gMaxExceptionNumber                                   = MAX_AARCH64_EXCEPTION;
 | |
| EFI_EXCEPTION_CALLBACK  gExceptionHandlers[MAX_AARCH64_EXCEPTION + 1]         = { 0 };
 | |
| EFI_EXCEPTION_CALLBACK  gDebuggerExceptionHandlers[MAX_AARCH64_EXCEPTION + 1] = { 0 };
 | |
| PHYSICAL_ADDRESS        gExceptionVectorAlignmentMask                         = ARM_VECTOR_TABLE_ALIGNMENT;
 | |
| UINTN                   gDebuggerNoHandlerValue                               = 0; // todo: define for AArch64
 | |
| 
 | |
| #define EL0_STACK_SIZE  EFI_PAGES_TO_SIZE(2)
 | |
| STATIC UINTN  mNewStackBase[EL0_STACK_SIZE / sizeof (UINTN)];
 | |
| 
 | |
| VOID
 | |
| RegisterEl0Stack (
 | |
|   IN  VOID  *Stack
 | |
|   );
 | |
| 
 | |
| RETURN_STATUS
 | |
| ArchVectorConfig (
 | |
|   IN  UINTN  VectorBaseAddress
 | |
|   )
 | |
| {
 | |
|   UINTN  HcrReg;
 | |
| 
 | |
|   // Round down sp by 16 bytes alignment
 | |
|   RegisterEl0Stack (
 | |
|     (VOID *)(((UINTN)mNewStackBase + EL0_STACK_SIZE) & ~0xFUL)
 | |
|     );
 | |
| 
 | |
|   if (ArmReadCurrentEL () == AARCH64_EL2) {
 | |
|     HcrReg = ArmReadHcr ();
 | |
| 
 | |
|     // Trap General Exceptions. All exceptions that would be routed to EL1 are routed to EL2
 | |
|     HcrReg |= ARM_HCR_TGE;
 | |
| 
 | |
|     ArmWriteHcr (HcrReg);
 | |
|   }
 | |
| 
 | |
|   return RETURN_SUCCESS;
 | |
| }
 |