/** @file Copyright (c) 2021, ARM Limited. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #include #include #include STATIC ARM_CORE_INFO mCoreInfoTable[] = { { 0x0, 0x0 }, // Cluster 0, Core 0 { 0x0, 0x1 }, // Cluster 0, Core 1 { 0x1, 0x0 }, // Cluster 1, Core 0 { 0x1, 0x1 } // Cluster 1, Core 1 }; /** Return the current Boot Mode. This function returns the boot reason on the platform. **/ EFI_BOOT_MODE ArmPlatformGetBootMode ( VOID ) { return BOOT_WITH_FULL_CONFIGURATION; } /** Initialize controllers that must be setup in the normal world. This function is called by the ArmPlatformPkg/Pei or ArmPlatformPkg/Pei/PlatformPeim in the PEI phase. @param[in] MpId Processor ID **/ RETURN_STATUS ArmPlatformInitialize ( IN UINTN MpId ) { return RETURN_SUCCESS; } /** Populate the Platform core information. This function populates the ARM_MP_CORE_INFO_PPI with information about the cores. @param[out] CoreCount Number of cores @param[out] ArmCoreTable Table containing information about the cores **/ EFI_STATUS PrePeiCoreGetMpCoreInfo ( OUT UINTN *CoreCount, OUT ARM_CORE_INFO **ArmCoreTable ) { *CoreCount = sizeof (mCoreInfoTable) / sizeof (ARM_CORE_INFO); *ArmCoreTable = mCoreInfoTable; return EFI_SUCCESS; } STATIC ARM_MP_CORE_INFO_PPI mMpCoreInfoPpi = { PrePeiCoreGetMpCoreInfo }; STATIC EFI_PEI_PPI_DESCRIPTOR gPlatformPpiTable[] = { { EFI_PEI_PPI_DESCRIPTOR_PPI, &gArmMpCoreInfoPpiGuid, &mMpCoreInfoPpi } }; /** Return the Platform specific PPIs This function exposes the Morello Platform Specific PPIs. @param[out] PpiListSize Size in Bytes of the Platform PPI List @param[out] PpiList Platform PPI List **/ VOID ArmPlatformGetPlatformPpiList ( OUT UINTN *PpiListSize, OUT EFI_PEI_PPI_DESCRIPTOR **PpiList ) { *PpiListSize = sizeof (gPlatformPpiTable); *PpiList = gPlatformPpiTable; }