Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Olivier Martin <olivier.martin@arm.com> git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@14182 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /** @file
 | |
| *  Main file supporting the transition to PEI Core in Normal World for Versatile Express
 | |
| *
 | |
| *  Copyright (c) 2011, ARM Limited. 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.
 | |
| *
 | |
| **/
 | |
| #ifndef __PREPEICORE_H_
 | |
| #define __PREPEICORE_H_
 | |
| 
 | |
| #include <Library/ArmLib.h>
 | |
| #include <Library/ArmPlatformLib.h>
 | |
| #include <Library/BaseMemoryLib.h>
 | |
| #include <Library/DebugLib.h>
 | |
| #include <Library/IoLib.h>
 | |
| #include <Library/PcdLib.h>
 | |
| 
 | |
| #include <PiPei.h>
 | |
| #include <Ppi/TemporaryRamSupport.h>
 | |
| 
 | |
| VOID
 | |
| CreatePpiList (
 | |
|   OUT UINTN                   *PpiListSize,
 | |
|   OUT EFI_PEI_PPI_DESCRIPTOR  **PpiList
 | |
|   );
 | |
| 
 | |
| EFI_STATUS
 | |
| EFIAPI
 | |
| PrePeiCoreTemporaryRamSupport (
 | |
|   IN CONST EFI_PEI_SERVICES   **PeiServices,
 | |
|   IN EFI_PHYSICAL_ADDRESS     TemporaryMemoryBase,
 | |
|   IN EFI_PHYSICAL_ADDRESS     PermanentMemoryBase,
 | |
|   IN UINTN                    CopySize
 | |
|   );
 | |
| 
 | |
| EFI_STATUS
 | |
| PrePeiCoreGetGlobalVariableMemory (
 | |
|   OUT EFI_PHYSICAL_ADDRESS    *GlobalVariableBase
 | |
|   );
 | |
| 
 | |
| VOID
 | |
| SecSwitchStack (
 | |
|   INTN    StackDelta
 | |
|   );
 | |
| 
 | |
| // Vector Table for Pei Phase
 | |
| VOID  PeiVectorTable (VOID);
 | |
| 
 | |
| VOID
 | |
| EFIAPI
 | |
| PrimaryMain (
 | |
|   IN  EFI_PEI_CORE_ENTRY_POINT  PeiCoreEntryPoint
 | |
|   );
 | |
| 
 | |
| /*
 | |
|  * This is the main function for secondary cores. They loop around until a non Null value is written to
 | |
|  * SYS_FLAGS register.The SYS_FLAGS register is platform specific.
 | |
|  * Note:The secondary cores, while executing secondary_main, assumes that:
 | |
|  *      : SGI 0 is configured as Non-secure interrupt
 | |
|  *      : Priority Mask is configured to allow SGI 0
 | |
|  *      : Interrupt Distributor and CPU interfaces are enabled
 | |
|  *
 | |
|  */
 | |
| VOID
 | |
| EFIAPI
 | |
| SecondaryMain (
 | |
|   IN UINTN MpId
 | |
|   );
 | |
| 
 | |
| VOID
 | |
| PeiCommonExceptionEntry (
 | |
|   IN UINT32 Entry,
 | |
|   IN UINTN LR
 | |
|   );
 | |
| 
 | |
| #endif
 |