summaryrefslogtreecommitdiffstats
path: root/SecurityPkg/Tcg/Tcg2Config/Tcg2ConfigNvData.h
blob: 69ef5600478d80e11a4dbc9af34f196c48c715f1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/** @file
  Header file for NV data structure definition.

Copyright (c) 2015 - 2018, Intel Corporation. All rights reserved.<BR>
SPDX-License-Identifier: BSD-2-Clause-Patent

**/

#ifndef __TCG2_CONFIG_NV_DATA_H__
#define __TCG2_CONFIG_NV_DATA_H__

#include <Guid/HiiPlatformSetupFormset.h>
#include <Guid/Tcg2ConfigHii.h>
#include <IndustryStandard/TcgPhysicalPresence.h>

#define TCG2_CONFIGURATION_VARSTORE_ID       0x0001
#define TCG2_CONFIGURATION_INFO_VARSTORE_ID  0x0002
#define TCG2_VERSION_VARSTORE_ID             0x0003
#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
#define KEY_TPM_DEVICE_INTERFACE      0x2008
#define KEY_TCG2_PPI_VERSION          0x2009
#define KEY_TPM2_ACPI_REVISION        0x200A

#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

#define TPM2_ACPI_REVISION_3  3
#define TPM2_ACPI_REVISION_4  4

#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

#define TCG2_PPI_VERSION_1_2  0x322E31                    // "1.2"
#define TCG2_PPI_VERSION_1_3  0x332E31                    // "1.3"

//
// Nv Data structure referenced by IFR, TPM device user desired
//
typedef struct {
  UINT8    TpmDevice;
} TCG2_CONFIGURATION;

typedef struct {
  UINT64    PpiVersion;
  UINT8     Tpm2AcpiTableRev;
} TCG2_VERSION;

typedef struct {
  BOOLEAN    Sha1Supported;
  BOOLEAN    Sha256Supported;
  BOOLEAN    Sha384Supported;
  BOOLEAN    Sha512Supported;
  BOOLEAN    Sm3Supported;
  UINT8      TpmDeviceInterfaceAttempt;
  BOOLEAN    TpmDeviceInterfacePtpFifoSupported;
  BOOLEAN    TpmDeviceInterfacePtpCrbSupported;
  BOOLEAN    ChangeEPSSupported;
} TCG2_CONFIGURATION_INFO;

//
// Variable saved for S3, TPM detected, only valid in S3 path.
// This variable is ReadOnly.
//
typedef struct {
  UINT8    TpmDeviceDetected;
} TCG2_DEVICE_DETECTION;

#define TCG2_STORAGE_NAME           L"TCG2_CONFIGURATION"
#define TCG2_STORAGE_INFO_NAME      L"TCG2_CONFIGURATION_INFO"
#define TCG2_DEVICE_DETECTION_NAME  L"TCG2_DEVICE_DETECTION"
#define TCG2_VERSION_NAME           L"TCG2_VERSION"

#endif