2015-06-16 04:53:43 +02:00
|
|
|
/** @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.
|
|
|
|
|
2016-06-01 10:06:53 +02:00
|
|
|
Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:00 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2015-06-16 04:53:43 +02:00
|
|
|
|
|
|
|
@par Revision Reference:
|
2016-06-01 10:06:53 +02:00
|
|
|
This PPI is introduced from PI Version 1.4.
|
2015-06-16 04:53:43 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#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 {
|
2021-12-05 23:54:05 +01:00
|
|
|
UINT32 CpuLocation;
|
|
|
|
EFI_SEC_PLATFORM_INFORMATION_RECORD InfoRecord;
|
2015-06-16 04:53:43 +02:00
|
|
|
} EFI_SEC_PLATFORM_INFORMATION_CPU;
|
|
|
|
|
|
|
|
///
|
|
|
|
/// EFI_SEC_PLATFORM_INFORMATION_RECORD2.
|
|
|
|
///
|
|
|
|
typedef struct {
|
|
|
|
///
|
|
|
|
/// The CPU location would be the local APIC ID
|
|
|
|
///
|
2021-12-05 23:54:05 +01:00
|
|
|
UINT32 NumberOfCpus;
|
|
|
|
EFI_SEC_PLATFORM_INFORMATION_CPU CpuInstance[1];
|
2015-06-16 04:53:43 +02:00
|
|
|
} 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
|
2021-12-05 23:54:05 +01:00
|
|
|
);
|
2015-06-16 04:53:43 +02:00
|
|
|
|
|
|
|
///
|
|
|
|
/// This service abstracts platform-specific information for many CPU's.
|
|
|
|
/// It is the multi-processor equivalent of PlatformInformation for
|
2016-06-01 10:06:53 +02:00
|
|
|
/// implementations that synchronize some, if not all CPU's in the SEC phase.
|
2015-06-16 04:53:43 +02:00
|
|
|
///
|
|
|
|
struct _EFI_SEC_PLATFORM_INFORMATION2_PPI {
|
2021-12-05 23:54:05 +01:00
|
|
|
EFI_SEC_PLATFORM_INFORMATION2 PlatformInformation2;
|
2015-06-16 04:53:43 +02:00
|
|
|
};
|
|
|
|
|
2021-12-05 23:54:05 +01:00
|
|
|
extern EFI_GUID gEfiSecPlatformInformation2PpiGuid;
|
2015-06-16 04:53:43 +02:00
|
|
|
|
|
|
|
#endif
|