| /** @file | |
| This file declares Sec Platform Information2 PPI. | |
| This service is the primary handoff state into the PEI Foundation. | |
| This service abstracts platform-specific information for many CPU's. | |
| Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.<BR> | |
| SPDX-License-Identifier: BSD-2-Clause-Patent | |
| @par Revision Reference: | |
| This PPI is introduced from PI Version 1.4. | |
| **/ | |
| #ifndef __SEC_PLATFORM_INFORMATION2_PPI_H__ | |
| #define __SEC_PLATFORM_INFORMATION2_PPI_H__ | |
| #include <Ppi/SecPlatformInformation.h> | |
| #define EFI_SEC_PLATFORM_INFORMATION2_GUID \ | |
| { \ | |
| 0x9e9f374b, 0x8f16, 0x4230, {0x98, 0x24, 0x58, 0x46, 0xee, 0x76, 0x6a, 0x97 } \ | |
| } | |
| typedef struct _EFI_SEC_PLATFORM_INFORMATION2_PPI EFI_SEC_PLATFORM_INFORMATION2_PPI; | |
| /// | |
| /// EFI_SEC_PLATFORM_INFORMATION_CPU. | |
| /// | |
| typedef struct { | |
| UINT32 CpuLocation; | |
| EFI_SEC_PLATFORM_INFORMATION_RECORD InfoRecord; | |
| } EFI_SEC_PLATFORM_INFORMATION_CPU; | |
| /// | |
| /// EFI_SEC_PLATFORM_INFORMATION_RECORD2. | |
| /// | |
| typedef struct { | |
| /// | |
| /// The CPU location would be the local APIC ID | |
| /// | |
| UINT32 NumberOfCpus; | |
| EFI_SEC_PLATFORM_INFORMATION_CPU CpuInstance[1]; | |
| } EFI_SEC_PLATFORM_INFORMATION_RECORD2; | |
| /** | |
| This interface conveys state information out of the Security (SEC) phase into PEI. | |
| This service is published by the SEC phase. | |
| @param PeiServices The pointer to the PEI Services Table. | |
| @param StructureSize The pointer to the variable describing size of the input buffer. | |
| @param PlatformInformationRecord2 The pointer to the EFI_SEC_PLATFORM_INFORMATION_RECORD2. | |
| @retval EFI_SUCCESS The data was successfully returned. | |
| @retval EFI_BUFFER_TOO_SMALL The buffer was too small. The current buffer size needed to | |
| hold the record is returned in StructureSize. | |
| **/ | |
| typedef | |
| EFI_STATUS | |
| (EFIAPI *EFI_SEC_PLATFORM_INFORMATION2)( | |
| IN CONST EFI_PEI_SERVICES **PeiServices, | |
| IN OUT UINT64 *StructureSize, | |
| OUT EFI_SEC_PLATFORM_INFORMATION_RECORD2 *PlatformInformationRecord2 | |
| ); | |
| /// | |
| /// This service abstracts platform-specific information for many CPU's. | |
| /// It is the multi-processor equivalent of PlatformInformation for | |
| /// implementations that synchronize some, if not all CPU's in the SEC phase. | |
| /// | |
| struct _EFI_SEC_PLATFORM_INFORMATION2_PPI { | |
| EFI_SEC_PLATFORM_INFORMATION2 PlatformInformation2; | |
| }; | |
| extern EFI_GUID gEfiSecPlatformInformation2PpiGuid; | |
| #endif |