| /** @file | |
| Copyright (c) 2011-2012, ARM Limited. All rights reserved. | |
| SPDX-License-Identifier: BSD-2-Clause-Patent | |
| **/ | |
| #include "PrePeiCore.h" | |
| VOID | |
| EFIAPI | |
| SecondaryMain ( | |
| IN UINTN MpId | |
| ) | |
| { | |
| ASSERT (FALSE); | |
| } | |
| VOID | |
| EFIAPI | |
| PrimaryMain ( | |
| IN EFI_PEI_CORE_ENTRY_POINT PeiCoreEntryPoint | |
| ) | |
| { | |
| EFI_SEC_PEI_HAND_OFF SecCoreData; | |
| UINTN PpiListSize; | |
| EFI_PEI_PPI_DESCRIPTOR *PpiList; | |
| UINTN TemporaryRamBase; | |
| UINTN TemporaryRamSize; | |
| CreatePpiList (&PpiListSize, &PpiList); | |
| // Adjust the Temporary Ram as the new Ppi List (Common + Platform Ppi Lists) is created at | |
| // the base of the primary core stack | |
| PpiListSize = ALIGN_VALUE (PpiListSize, CPU_STACK_ALIGNMENT); | |
| TemporaryRamBase = (UINTN)PcdGet64 (PcdCPUCoresStackBase) + PpiListSize; | |
| TemporaryRamSize = (UINTN)PcdGet32 (PcdCPUCorePrimaryStackSize) - PpiListSize; | |
| // | |
| // Bind this information into the SEC hand-off state | |
| // Note: this must be in sync with the stuff in the asm file | |
| // Note also: HOBs (pei temp ram) MUST be above stack | |
| // | |
| SecCoreData.DataSize = sizeof (EFI_SEC_PEI_HAND_OFF); | |
| SecCoreData.BootFirmwareVolumeBase = (VOID *)(UINTN)PcdGet64 (PcdFvBaseAddress); | |
| SecCoreData.BootFirmwareVolumeSize = PcdGet32 (PcdFvSize); | |
| SecCoreData.TemporaryRamBase = (VOID *)TemporaryRamBase; // We run on the primary core (and so we use the first stack) | |
| SecCoreData.TemporaryRamSize = TemporaryRamSize; | |
| SecCoreData.PeiTemporaryRamBase = SecCoreData.TemporaryRamBase; | |
| SecCoreData.PeiTemporaryRamSize = ALIGN_VALUE (SecCoreData.TemporaryRamSize / 2, CPU_STACK_ALIGNMENT); | |
| SecCoreData.StackBase = (VOID *)((UINTN)SecCoreData.TemporaryRamBase + SecCoreData.PeiTemporaryRamSize); | |
| SecCoreData.StackSize = (TemporaryRamBase + TemporaryRamSize) - (UINTN)SecCoreData.StackBase; | |
| // Jump to PEI core entry point | |
| (PeiCoreEntryPoint)(&SecCoreData, PpiList); | |
| } |