/** @file * * Copyright (c) 2011-2021, Arm Limited. All rights reserved.
* * SPDX-License-Identifier: BSD-2-Clause-Patent * **/ #include #include #include #include #include #include ARM_PROCESSOR_TABLE mArmProcessorTableTemplate = { { EFI_ARM_PROCESSOR_TABLE_SIGNATURE, 0, EFI_ARM_PROCESSOR_TABLE_REVISION, EFI_ARM_PROCESSOR_TABLE_OEM_ID, EFI_ARM_PROCESSOR_TABLE_OEM_TABLE_ID, EFI_ARM_PROCESSOR_TABLE_OEM_REVISION, EFI_ARM_PROCESSOR_TABLE_CREATOR_ID, EFI_ARM_PROCESSOR_TABLE_CREATOR_REVISION, { 0 }, 0 }, // ARM Processor table header 0, // Number of entries in ARM processor Table NULL // ARM Processor Table }; /** Publish ARM Processor Data table in UEFI SYSTEM Table. * @param HobStart Pointer to the beginning of the HOB List from PEI. * * Description : This function iterates through HOB list and finds ARM processor Table Entry HOB. * If the ARM processor Table Entry HOB is found, the HOB data is copied to run-time memory * and a pointer is assigned to it in ARM processor table. Then the ARM processor table is * installed in EFI configuration table. **/ VOID EFIAPI PublishArmProcessorTable ( VOID ) { EFI_PEI_HOB_POINTERS Hob; Hob.Raw = GetHobList (); // Iterate through the HOBs and find if there is ARM PROCESSOR ENTRY HOB for ( ; !END_OF_HOB_LIST (Hob); Hob.Raw = GET_NEXT_HOB (Hob)) { // Check for Correct HOB type if ((GET_HOB_TYPE (Hob)) == EFI_HOB_TYPE_GUID_EXTENSION) { // Check for correct GUID type if (CompareGuid (&(Hob.Guid->Name), &gArmMpCoreInfoGuid)) { ARM_PROCESSOR_TABLE *ArmProcessorTable; EFI_STATUS Status; // Allocate Runtime memory for ARM processor table ArmProcessorTable = (ARM_PROCESSOR_TABLE *)AllocateRuntimePool (sizeof (ARM_PROCESSOR_TABLE)); // Check if the memory allocation is successful or not ASSERT (NULL != ArmProcessorTable); // Set ARM processor table to default values CopyMem (ArmProcessorTable, &mArmProcessorTableTemplate, sizeof (ARM_PROCESSOR_TABLE)); // Fill in Length fields of ARM processor table ArmProcessorTable->Header.Length = sizeof (ARM_PROCESSOR_TABLE); ArmProcessorTable->Header.DataLen = GET_GUID_HOB_DATA_SIZE (Hob); // Fill in Identifier(ARM processor table GUID) ArmProcessorTable->Header.Identifier = gArmMpCoreInfoGuid; // Set Number of ARM core entries in the Table ArmProcessorTable->NumberOfEntries = GET_GUID_HOB_DATA_SIZE (Hob)/sizeof (ARM_CORE_INFO); // Allocate runtime memory for ARM processor Table entries ArmProcessorTable->ArmCpus = (ARM_CORE_INFO *)AllocateRuntimePool ( ArmProcessorTable->NumberOfEntries * sizeof (ARM_CORE_INFO) ); // Check if the memory allocation is successful or not ASSERT (NULL != ArmProcessorTable->ArmCpus); // Copy ARM Processor Table data from HOB list to newly allocated memory CopyMem (ArmProcessorTable->ArmCpus, GET_GUID_HOB_DATA (Hob), ArmProcessorTable->Header.DataLen); // Install the ARM Processor table into EFI system configuration table Status = gBS->InstallConfigurationTable (&gArmMpCoreInfoGuid, ArmProcessorTable); ASSERT_EFI_ERROR (Status); } } } }