tpm2-tss 3.2.1
TPM Software stack 2.0 TCG spec compliant implementation
ifapi_policy_types.h
1/* SPDX-License-Identifier: BSD-2-Clause */
2/*******************************************************************************
3 * Copyright 2018-2019, Fraunhofer SIT sponsored by Infineon Technologies AG
4 * All rights reserved.
5 ******************************************************************************/
6#ifndef IFAPI_POLICY_TYPES_H
7#define IFAPI_POLICY_TYPES_H
8
9#include "tss2_tpm2_types.h"
10#include "fapi_types.h"
11
12typedef UINT32 TPMI_POLICYTYPE;
13#define POLICYELEMENTS 0
14#define POLICYOR 1
15#define POLICYSIGNED 2
16#define POLICYSECRET 3
17#define POLICYPCR 4
18#define POLICYLOCALITY 5
19#define POLICYNV 6
20#define POLICYCOUNTERTIMER 7
21#define POLICYCOMMANDCODE 8
22#define POLICYPHYSICALPRESENCE 9
23#define POLICYCPHASH 10
24#define POLICYNAMEHASH 11
25#define POLICYDUPLICATIONSELECT 12
26#define POLICYAUTHORIZE 13
27#define POLICYAUTHVALUE 14
28#define POLICYPASSWORD 15
29#define POLICYNVWRITTEN 16
30#define POLICYTEMPLATE 17
31#define POLICYAUTHORIZENV 18
32#define POLICYACTION 19
36typedef struct {
37 TPM2B_NONCE nonceTPM;
38 TPM2B_DIGEST cpHashA;
39 TPM2B_NONCE policyRef;
40 INT32 expiration;
41 TPMT_SIGNATURE auth;
42 TPM2B_NAME publicKey;
44 char *keyPath;
45 TPMT_PUBLIC keyPublic;
46 char *keyPEM;
47 TPMI_ALG_HASH keyPEMhashAlg;
48 TPMT_RSA_SCHEME rsaScheme;
49 TPMT_SIGNATURE signature_tpm;
51
54typedef struct {
55 TPM2B_NONCE nonceTPM;
56 TPM2B_DIGEST cpHashA;
57 TPM2B_NONCE policyRef;
58 INT32 expiration;
59 char *objectPath;
60 TPM2B_NAME objectName;
62
65typedef struct {
66 TPMA_LOCALITY locality;
68
71typedef struct {
72 char *nvPath;
73 TPMI_RH_NV_INDEX nvIndex;
74 TPM2B_NV_PUBLIC nvPublic;
75 TPMI_RH_NV_AUTH authHandle;
76 TPM2B_OPERAND operandB;
77 UINT16 offset;
78 TPM2_EO operation;
80
83typedef struct {
84 TPM2B_OPERAND operandB;
85 UINT16 offset;
86 TPM2_EO operation;
88
91typedef struct {
92 TPM2_CC code;
94
97typedef struct {
99
102typedef struct {
103 TPM2B_DIGEST cpHash;
105
108typedef struct {
109 UINT32 count;
110 UINT32 i;
111 TPM2B_NAME objectNames[3];
112 char *namePaths[3];
113 TPM2B_DIGEST nameHash;
115
118typedef struct {
119 TPM2B_NAME objectName;
120 TPM2B_NAME newParentName;
121 TPMI_YES_NO includeObject;
123 TPM2B_PUBLIC newParentPublic;
125
128typedef struct {
129 char *type;
130 TPMT_PUBLIC key;
131 TPM2B_NONCE policyRef;
132 TPMT_SIGNATURE signature;
133 TPMI_ALG_HASH keyPEMhashAlg;
134 UINT8_ARY pemSignature;
135 char *keyPEM;
136 TPMT_RSA_SCHEME rsaScheme;
138
139typedef struct policy_object_node POLICY_OBJECT;
140
143typedef struct {
144 TPM2B_DIGEST approvedPolicy;
145 TPM2B_NONCE policyRef;
146 TPM2B_NAME keyName;
147 TPMT_TK_VERIFIED checkTicket;
148 char *keyPath;
149 TPMT_PUBLIC keyPublic;
150 char *keyPEM;
151 TPMI_ALG_HASH keyPEMhashAlg;
152 TPMT_RSA_SCHEME rsaScheme;
153 TPMT_SIGNATURE signature;
155
158typedef struct {
160
163typedef struct {
165
168typedef struct {
169 TPMI_YES_NO writtenSet;
171
174typedef struct {
175 TPM2B_DIGEST templateHash;
176 TPM2B_PUBLIC templatePublic;
179
182typedef struct {
183 char *nvPath;
184 TPM2B_NV_PUBLIC nvPublic;
185 TPM2B_DIGEST policy;
186 TPMT_HA nv_policy;
187 uint8_t *policy_buffer;
189
192typedef struct {
193 char *action;
195
198typedef struct {
199 UINT32 pcr;
200 TPM2_ALG_ID hashAlg;
201 TPMU_HA digest;
203
206typedef struct TPML_PCRVALUES {
207 UINT32 count;
210
213typedef struct {
215 TPMS_PCR_SELECT currentPCRs;
216 TPML_PCR_SELECTION currentPCRandBanks;
218
222 UINT32 count;
225
227
230typedef struct {
231 char *name;
233 TPML_DIGEST_VALUES policyDigests;
236
239typedef struct TPML_POLICYBRANCHES {
240 UINT32 count;
243
246typedef struct {
249
252typedef union {
273
276typedef struct {
277 TPMI_POLICYTYPE type;
278 TPML_DIGEST_VALUES policyDigests;
281
285 UINT32 count;
287};
288
291typedef struct TPMS_POLICY {
293 TPML_DIGEST_VALUES policyDigests;
297
298#endif /* IFAPI_POLICY_TYPES_H */
Definition: ifapi_policy_types.h:206
TPMS_PCRVALUE pcrs[]
Definition: ifapi_policy_types.h:208
UINT32 count
Definition: ifapi_policy_types.h:207
Definition: ifapi_policy_types.h:221
UINT32 count
Definition: ifapi_policy_types.h:222
TPMS_POLICYAUTHORIZATION authorizations[]
Definition: ifapi_policy_types.h:223
Definition: ifapi_policy_types.h:239
TPMS_POLICYBRANCH authorizations[]
Definition: ifapi_policy_types.h:241
UINT32 count
Definition: ifapi_policy_types.h:240
Definition: ifapi_policy_types.h:284
UINT32 count
Definition: ifapi_policy_types.h:285
TPMT_POLICYELEMENT elements[]
Definition: ifapi_policy_types.h:286
Definition: ifapi_policy_types.h:198
UINT32 pcr
Definition: ifapi_policy_types.h:199
TPM2_ALG_ID hashAlg
Definition: ifapi_policy_types.h:200
TPMU_HA digest
Definition: ifapi_policy_types.h:201
Definition: ifapi_policy_types.h:192
char * action
Definition: ifapi_policy_types.h:193
Definition: ifapi_policy_types.h:128
char * type
Definition: ifapi_policy_types.h:129
TPMT_PUBLIC key
Definition: ifapi_policy_types.h:130
TPM2B_NONCE policyRef
Definition: ifapi_policy_types.h:131
TPMT_SIGNATURE signature
Definition: ifapi_policy_types.h:132
Definition: ifapi_policy_types.h:143
TPMT_RSA_SCHEME rsaScheme
Definition: ifapi_policy_types.h:152
TPMT_TK_VERIFIED checkTicket
Definition: ifapi_policy_types.h:147
TPM2B_NONCE policyRef
Definition: ifapi_policy_types.h:145
TPMT_PUBLIC keyPublic
Definition: ifapi_policy_types.h:149
char * keyPath
Definition: ifapi_policy_types.h:148
TPM2B_NAME keyName
Definition: ifapi_policy_types.h:146
TPM2B_DIGEST approvedPolicy
Definition: ifapi_policy_types.h:144
char * keyPEM
Definition: ifapi_policy_types.h:150
TPMI_ALG_HASH keyPEMhashAlg
Definition: ifapi_policy_types.h:151
Definition: ifapi_policy_types.h:182
TPM2B_DIGEST policy
Definition: ifapi_policy_types.h:185
char * nvPath
Definition: ifapi_policy_types.h:183
TPMT_HA nv_policy
Definition: ifapi_policy_types.h:186
TPM2B_NV_PUBLIC nvPublic
Definition: ifapi_policy_types.h:184
Definition: ifapi_policy_types.h:158
Definition: ifapi_policy_types.h:230
struct TPML_POLICYELEMENTS * policy
Definition: ifapi_policy_types.h:234
char * name
Definition: ifapi_policy_types.h:231
char * description
Definition: ifapi_policy_types.h:232
Definition: ifapi_policy_types.h:91
TPM2_CC code
Definition: ifapi_policy_types.h:92
Definition: ifapi_policy_types.h:83
TPM2B_OPERAND operandB
Definition: ifapi_policy_types.h:84
TPM2_EO operation
Definition: ifapi_policy_types.h:86
UINT16 offset
Definition: ifapi_policy_types.h:85
Definition: ifapi_policy_types.h:102
TPM2B_DIGEST cpHash
Definition: ifapi_policy_types.h:103
Definition: ifapi_policy_types.h:118
char * newParentPath
Definition: ifapi_policy_types.h:122
TPM2B_NAME newParentName
Definition: ifapi_policy_types.h:120
TPM2B_PUBLIC newParentPublic
Definition: ifapi_policy_types.h:123
TPMI_YES_NO includeObject
Definition: ifapi_policy_types.h:121
TPM2B_NAME objectName
Definition: ifapi_policy_types.h:119
Definition: ifapi_policy_types.h:291
struct TPML_POLICYELEMENTS * policy
Definition: ifapi_policy_types.h:295
struct TPML_POLICYAUTHORIZATIONS * policyAuthorizations
Definition: ifapi_policy_types.h:294
char * description
Definition: ifapi_policy_types.h:292
TPML_DIGEST_VALUES policyDigests
Definition: ifapi_policy_types.h:293
Definition: ifapi_policy_types.h:65
TPMA_LOCALITY locality
Definition: ifapi_policy_types.h:66
Definition: ifapi_policy_types.h:108
UINT32 i
Definition: ifapi_policy_types.h:110
UINT32 count
Definition: ifapi_policy_types.h:109
TPM2B_DIGEST nameHash
Definition: ifapi_policy_types.h:113
Definition: ifapi_policy_types.h:71
TPM2B_OPERAND operandB
Definition: ifapi_policy_types.h:76
TPMI_RH_NV_AUTH authHandle
Definition: ifapi_policy_types.h:75
char * nvPath
Definition: ifapi_policy_types.h:72
TPM2_EO operation
Definition: ifapi_policy_types.h:78
TPMI_RH_NV_INDEX nvIndex
Definition: ifapi_policy_types.h:73
TPM2B_NV_PUBLIC nvPublic
Definition: ifapi_policy_types.h:74
UINT16 offset
Definition: ifapi_policy_types.h:77
Definition: ifapi_policy_types.h:168
TPMI_YES_NO writtenSet
Definition: ifapi_policy_types.h:169
Definition: ifapi_policy_types.h:246
struct TPML_POLICYBRANCHES * branches
Definition: ifapi_policy_types.h:247
Definition: ifapi_policy_types.h:163
Definition: ifapi_policy_types.h:213
TPML_PCR_SELECTION currentPCRandBanks
Definition: ifapi_policy_types.h:216
TPMS_PCR_SELECT currentPCRs
Definition: ifapi_policy_types.h:215
struct TPML_PCRVALUES * pcrs
Definition: ifapi_policy_types.h:214
Definition: ifapi_policy_types.h:97
Definition: ifapi_policy_types.h:54
TPM2B_DIGEST cpHashA
Definition: ifapi_policy_types.h:56
TPM2B_NONCE policyRef
Definition: ifapi_policy_types.h:57
char * objectPath
Definition: ifapi_policy_types.h:59
TPM2B_NONCE nonceTPM
Definition: ifapi_policy_types.h:55
TPM2B_NAME objectName
Definition: ifapi_policy_types.h:60
INT32 expiration
Definition: ifapi_policy_types.h:58
Definition: ifapi_policy_types.h:36
TPMT_RSA_SCHEME rsaScheme
Definition: ifapi_policy_types.h:48
TPM2B_DIGEST cpHashA
Definition: ifapi_policy_types.h:38
TPM2B_NONCE policyRef
Definition: ifapi_policy_types.h:39
TPMT_PUBLIC keyPublic
Definition: ifapi_policy_types.h:45
char * keyPath
Definition: ifapi_policy_types.h:44
TPM2B_NONCE nonceTPM
Definition: ifapi_policy_types.h:37
TPM2B_NAME publicKey
Definition: ifapi_policy_types.h:42
TPMT_SIGNATURE auth
Definition: ifapi_policy_types.h:41
char * keyPEM
Definition: ifapi_policy_types.h:46
TPMI_ALG_HASH keyPEMhashAlg
Definition: ifapi_policy_types.h:47
char * publicKeyHint
Definition: ifapi_policy_types.h:43
INT32 expiration
Definition: ifapi_policy_types.h:40
Definition: ifapi_policy_types.h:174
char * templateName
Definition: ifapi_policy_types.h:177
TPM2B_PUBLIC templatePublic
Definition: ifapi_policy_types.h:176
TPM2B_DIGEST templateHash
Definition: ifapi_policy_types.h:175
Definition: ifapi_policy_types.h:276
TPMU_POLICYELEMENT element
Definition: ifapi_policy_types.h:279
TPMI_POLICYTYPE type
Definition: ifapi_policy_types.h:277
TPML_DIGEST_VALUES policyDigests
Definition: ifapi_policy_types.h:278
Definition: fapi_types.h:15
Definition: ifapi_policy_execute.h:44
Definition: ifapi_policy_types.h:252
TPMS_POLICYCOMMANDCODE PolicyCommandCode
Definition: ifapi_policy_types.h:260
TPMS_POLICYPCR PolicyPCR
Definition: ifapi_policy_types.h:256
TPMS_POLICYNV PolicyNV
Definition: ifapi_policy_types.h:258
TPMS_POLICYAUTHVALUE PolicyAuthValue
Definition: ifapi_policy_types.h:266
TPMS_POLICYSIGNED PolicySigned
Definition: ifapi_policy_types.h:254
TPMS_POLICYAUTHORIZE PolicyAuthorize
Definition: ifapi_policy_types.h:265
TPMS_POLICYLOCALITY PolicyLocality
Definition: ifapi_policy_types.h:257
TPMS_POLICYCOUNTERTIMER PolicyCounterTimer
Definition: ifapi_policy_types.h:259
TPMS_POLICYOR PolicyOr
Definition: ifapi_policy_types.h:253
TPMS_POLICYCPHASH PolicyCpHash
Definition: ifapi_policy_types.h:262
TPMS_POLICYSECRET PolicySecret
Definition: ifapi_policy_types.h:255
TPMS_POLICYDUPLICATIONSELECT PolicyDuplicationSelect
Definition: ifapi_policy_types.h:264
TPMS_POLICYAUTHORIZENV PolicyAuthorizeNv
Definition: ifapi_policy_types.h:270
TPMS_POLICYPASSWORD PolicyPassword
Definition: ifapi_policy_types.h:267
TPMS_POLICYPHYSICALPRESENCE PolicyPhysicalPresence
Definition: ifapi_policy_types.h:261
TPMS_POLICYACTION PolicyAction
Definition: ifapi_policy_types.h:271
TPMS_POLICYNVWRITTEN PolicyNvWritten
Definition: ifapi_policy_types.h:268
TPMS_POLICYTEMPLATE PolicyTemplate
Definition: ifapi_policy_types.h:269
TPMS_POLICYNAMEHASH PolicyNameHash
Definition: ifapi_policy_types.h:263