2015-08-13 10:24:17 +02:00
|
|
|
/** @file
|
|
|
|
Header file for NV data structure definition.
|
|
|
|
|
2018-06-27 15:13:09 +02:00
|
|
|
Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:56 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2015-08-13 10:24:17 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __TCG2_CONFIG_NV_DATA_H__
|
|
|
|
#define __TCG2_CONFIG_NV_DATA_H__
|
|
|
|
|
|
|
|
#include <Guid/HiiPlatformSetupFormset.h>
|
|
|
|
#include <Guid/Tcg2ConfigHii.h>
|
|
|
|
#include <IndustryStandard/TcgPhysicalPresence.h>
|
|
|
|
|
|
|
|
//
|
|
|
|
// BUGBUG: In order to pass VfrCompiler, we have to redefine below MACRO, which already in <Protocol/Tcg2Protocol.h>.
|
|
|
|
//
|
|
|
|
#ifndef __TCG2_H__
|
|
|
|
#define EFI_TCG2_EVENT_LOG_FORMAT_TCG_1_2 0x00000001
|
|
|
|
#define EFI_TCG2_EVENT_LOG_FORMAT_TCG_2 0x00000002
|
|
|
|
#endif
|
|
|
|
#define EFI_TCG2_EVENT_LOG_FORMAT_ALL (EFI_TCG2_EVENT_LOG_FORMAT_TCG_1_2 | EFI_TCG2_EVENT_LOG_FORMAT_TCG_2)
|
|
|
|
|
|
|
|
#define TCG2_CONFIGURATION_VARSTORE_ID 0x0001
|
2016-12-23 09:55:32 +01:00
|
|
|
#define TCG2_CONFIGURATION_INFO_VARSTORE_ID 0x0002
|
2016-12-09 08:53:22 +01:00
|
|
|
#define TCG2_VERSION_VARSTORE_ID 0x0003
|
2015-08-13 10:24:17 +02:00
|
|
|
#define TCG2_CONFIGURATION_FORM_ID 0x0001
|
|
|
|
|
|
|
|
#define KEY_TPM_DEVICE 0x2000
|
|
|
|
#define KEY_TPM2_OPERATION 0x2001
|
|
|
|
#define KEY_TPM2_OPERATION_PARAMETER 0x2002
|
|
|
|
#define KEY_TPM2_PCR_BANKS_REQUEST_0 0x2003
|
|
|
|
#define KEY_TPM2_PCR_BANKS_REQUEST_1 0x2004
|
|
|
|
#define KEY_TPM2_PCR_BANKS_REQUEST_2 0x2005
|
|
|
|
#define KEY_TPM2_PCR_BANKS_REQUEST_3 0x2006
|
|
|
|
#define KEY_TPM2_PCR_BANKS_REQUEST_4 0x2007
|
2016-01-26 02:30:55 +01:00
|
|
|
#define KEY_TPM_DEVICE_INTERFACE 0x2008
|
2016-12-09 08:53:22 +01:00
|
|
|
#define KEY_TCG2_PPI_VERSION 0x2009
|
2016-12-23 09:55:32 +01:00
|
|
|
#define KEY_TPM2_ACPI_REVISION 0x200A
|
2015-08-13 10:24:17 +02:00
|
|
|
|
|
|
|
#define TPM_DEVICE_NULL 0
|
|
|
|
#define TPM_DEVICE_1_2 1
|
|
|
|
#define TPM_DEVICE_2_0_DTPM 2
|
|
|
|
#define TPM_DEVICE_MIN TPM_DEVICE_1_2
|
|
|
|
#define TPM_DEVICE_MAX TPM_DEVICE_2_0_DTPM
|
|
|
|
#define TPM_DEVICE_DEFAULT TPM_DEVICE_1_2
|
|
|
|
|
2016-12-23 09:55:32 +01:00
|
|
|
#define TPM2_ACPI_REVISION_3 3
|
|
|
|
#define TPM2_ACPI_REVISION_4 4
|
|
|
|
|
2016-01-26 02:30:55 +01:00
|
|
|
#define TPM_DEVICE_INTERFACE_TIS 0
|
|
|
|
#define TPM_DEVICE_INTERFACE_PTP_FIFO 1
|
|
|
|
#define TPM_DEVICE_INTERFACE_PTP_CRB 2
|
|
|
|
#define TPM_DEVICE_INTERFACE_MAX TPM_DEVICE_INTERFACE_PTP_FIFO
|
|
|
|
#define TPM_DEVICE_INTERFACE_DEFAULT TPM_DEVICE_INTERFACE_PTP_CRB
|
|
|
|
|
2015-08-13 10:24:17 +02:00
|
|
|
#define TCG2_PROTOCOL_VERSION_DEFAULT 0x0001
|
|
|
|
#define EFI_TCG2_EVENT_LOG_FORMAT_DEFAULT EFI_TCG2_EVENT_LOG_FORMAT_TCG_1_2
|
|
|
|
|
2016-12-09 08:53:22 +01:00
|
|
|
#define TCG2_PPI_VERSION_1_2 0x322E31 // "1.2"
|
2018-06-27 15:13:09 +02:00
|
|
|
#define TCG2_PPI_VERSION_1_3 0x332E31 // "1.3"
|
2016-12-09 08:53:22 +01:00
|
|
|
|
2015-08-13 10:24:17 +02:00
|
|
|
//
|
|
|
|
// Nv Data structure referenced by IFR, TPM device user desired
|
|
|
|
//
|
|
|
|
typedef struct {
|
|
|
|
UINT8 TpmDevice;
|
|
|
|
} TCG2_CONFIGURATION;
|
|
|
|
|
2016-12-09 08:53:22 +01:00
|
|
|
typedef struct {
|
|
|
|
UINT64 PpiVersion;
|
2016-12-23 09:55:32 +01:00
|
|
|
UINT8 Tpm2AcpiTableRev;
|
2016-12-09 08:53:22 +01:00
|
|
|
} TCG2_VERSION;
|
|
|
|
|
2015-10-27 04:49:31 +01:00
|
|
|
typedef struct {
|
2016-01-26 02:30:55 +01:00
|
|
|
BOOLEAN Sha1Supported;
|
|
|
|
BOOLEAN Sha256Supported;
|
|
|
|
BOOLEAN Sha384Supported;
|
|
|
|
BOOLEAN Sha512Supported;
|
|
|
|
BOOLEAN Sm3Supported;
|
|
|
|
UINT8 TpmDeviceInterfaceAttempt;
|
|
|
|
BOOLEAN TpmDeviceInterfacePtpFifoSupported;
|
|
|
|
BOOLEAN TpmDeviceInterfacePtpCrbSupported;
|
2015-10-27 04:49:31 +01:00
|
|
|
} TCG2_CONFIGURATION_INFO;
|
|
|
|
|
2015-08-13 10:24:17 +02:00
|
|
|
//
|
|
|
|
// Variable saved for S3, TPM detected, only valid in S3 path.
|
|
|
|
// This variable is ReadOnly.
|
|
|
|
//
|
|
|
|
typedef struct {
|
|
|
|
UINT8 TpmDeviceDetected;
|
|
|
|
} TCG2_DEVICE_DETECTION;
|
|
|
|
|
2015-10-27 04:49:31 +01:00
|
|
|
#define TCG2_STORAGE_NAME L"TCG2_CONFIGURATION"
|
|
|
|
#define TCG2_STORAGE_INFO_NAME L"TCG2_CONFIGURATION_INFO"
|
2015-08-13 10:24:17 +02:00
|
|
|
#define TCG2_DEVICE_DETECTION_NAME L"TCG2_DEVICE_DETECTION"
|
2016-12-09 08:53:22 +01:00
|
|
|
#define TCG2_VERSION_NAME L"TCG2_VERSION"
|
2015-08-13 10:24:17 +02:00
|
|
|
|
|
|
|
#define TPM_INSTANCE_ID_LIST { \
|
|
|
|
{TPM_DEVICE_INTERFACE_NONE, TPM_DEVICE_NULL}, \
|
|
|
|
{TPM_DEVICE_INTERFACE_TPM12, TPM_DEVICE_1_2}, \
|
|
|
|
{TPM_DEVICE_INTERFACE_TPM20_DTPM, TPM_DEVICE_2_0_DTPM}, \
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// BUGBUG: In order to pass VfrCompiler, we have to redefine GUID here.
|
|
|
|
//
|
|
|
|
#ifndef __BASE_H__
|
|
|
|
typedef struct {
|
|
|
|
UINT32 Data1;
|
|
|
|
UINT16 Data2;
|
|
|
|
UINT16 Data3;
|
|
|
|
UINT8 Data4[8];
|
|
|
|
} GUID;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
GUID TpmInstanceGuid;
|
|
|
|
UINT8 TpmDevice;
|
|
|
|
} TPM_INSTANCE_ID;
|
|
|
|
|
|
|
|
#endif
|