2 * Main file supporting the SEC Phase on ARM PLatforms
4 * Copyright (c) 2011-2013, ARM Limited. All rights reserved.
6 * This program and the accompanying materials
7 * are licensed and made available under the terms and conditions of the BSD License
8 * which accompanies this distribution. The full text of the license may be found at
9 * http://opensource.org/licenses/bsd-license.php
11 * THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
20 #include <Library/ArmLib.h>
21 #include <Library/ArmCpuLib.h>
22 #include <Library/ArmPlatformLib.h>
23 #include <Library/ArmPlatformSecLib.h>
24 #include <Library/BaseLib.h>
25 #include <Library/DebugLib.h>
26 #include <Library/PcdLib.h>
28 #define IS_ALIGNED(Address, Align) (((UINTN)Address & (Align-1)) == 0)
31 TrustedWorldInitialization (
37 NonTrustedWorldTransition (
43 ArmSetupGicNonSecure (
44 IN INTN GicDistributorBase
,
45 IN INTN GicInterruptInterfaceBase
50 IN UINTN MonitorEntryPoint
,
53 IN VOID
* MonitorStackBase
57 return_from_exception (
58 IN UINTN NonSecureBase
68 IN ARM_PROCESSOR_MODE Mode
72 SecCommonExceptionEntry (
79 ArmSecArchTrustzoneInit (