tpm2-protocol 0.10.54

TPM 2.0 protocol definitions
Documentation
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
// SPDX-License-Identifier: MIT OR Apache-2.0
// Copyright (c) 2025 Opinsys Oy
// Copyright (c) 2024-2025 Jarkko Sakkinen

use crate::tpm_enum;
tpm_enum! {
    #[derive(Debug, PartialEq, Eq, PartialOrd, Ord, Copy, Clone, Hash, Default)]
    pub enum TpmAlgId(u16) {
        (Error, 0x0000, "TPM_ALG_ERROR"),
        (Rsa, 0x0001, "TPM_ALG_RSA"),
        (Sha1, 0x0004, "TPM_ALG_SHA1"),
        (Hmac, 0x0005, "TPM_ALG_HMAC"),
        (Aes, 0x0006, "TPM_ALG_AES"),
        (Mgf1, 0x0007, "TPM_ALG_MGF1"),
        (KeyedHash, 0x0008, "TPM_ALG_KEYEDHASH"),
        (Xor, 0x000A, "TPM_ALG_XOR"),
        (Sha256, 0x000B, "TPM_ALG_SHA256"),
        (Sha384, 0x000C, "TPM_ALG_SHA384"),
        (Sha512, 0x000D, "TPM_ALG_SHA512"),
        #[default]
        (Null, 0x0010, "TPM_ALG_NULL"),
        (Sm3_256, 0x0012, "TPM_ALG_SM3_256"),
        (Sm4, 0x0013, "TPM_ALG_SM4"),
        (Rsassa, 0x0014, "TPM_ALG_RSASSA"),
        (Rsaes, 0x0015, "TPM_ALG_RSAES"),
        (Rsapss, 0x0016, "TPM_ALG_RSAPSS"),
        (Oaep, 0x0017, "TPM_ALG_OAEP"),
        (Ecdsa, 0x0018, "TPM_ALG_ECDSA"),
        (Ecdh, 0x0019, "TPM_ALG_ECDH"),
        (Ecdaa, 0x001A, "TPM_ALG_ECDAA"),
        (Sm2, 0x001B, "TPM_ALG_SM2"),
        (Ecschnorr, 0x001C, "TPM_ALG_ECSCHNORR"),
        (Ecmqv, 0x001D, "TPM_ALG_ECMQV"),
        (Kdf1Sp800_56A, 0x0020, "TPM_ALG_KDF1_SP800_56A"),
        (Kdf2, 0x0021, "TPM_ALG_KDF2"),
        (Kdf1Sp800_108, 0x0022, "TPM_ALG_KDF1_SP800_108"),
        (Ecc, 0x0023, "TPM_ALG_ECC"),
        (SymCipher, 0x0025, "TPM_ALG_SYMCIPHER"),
        (Camellia, 0x0026, "TPM_ALG_CAMELLIA"),
        (Ctr, 0x0040, "TPM_ALG_CTR"),
        (Ofb, 0x0041, "TPM_ALG_OFB"),
        (Cbc, 0x0042, "TPM_ALG_CBC"),
        (Cfb, 0x0043, "TPM_ALG_CFB"),
        (Ecb, 0x0044, "TPM_ALG_ECB"),
    }
}

pub type TpmiAlgCipherMode = TpmAlgId;

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, Copy, Clone)]
    pub enum TpmAt(u32) {
        (Any, 0x0000_0000, "TPM_AT_ANY"),
        (Error, 0x0000_0001, "TPM_AT_ERROR"),
        (Pv1, 0x0000_0002, "TPM_AT_PV1"),
        (Vend, 0x8000_0000, "TPM_AT_VEND"),
    }
}

impl Default for TpmAt {
    fn default() -> Self {
        Self::Any
    }
}

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, Copy, Clone)]
    pub enum TpmCap(u32) {
        (Algs, 0x0000_0000, "TPM_CAP_ALGS"),
        (Handles, 0x0000_0001, "TPM_CAP_HANDLES"),
        (Commands, 0x0000_0002, "TPM_CAP_COMMANDS"),
        (Pcrs, 0x0000_0005, "TPM_CAP_PCRS"),
        (TpmProperties, 0x0000_0006, "TPM_CAP_TPM_PROPERTIES"),
        (EccCurves, 0x0000_0008, "TPM_CAP_ECC_CURVES"),
    }
}

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, PartialOrd, Ord, Copy, Clone)]
    pub enum TpmCc(u32) {
        (NvUndefineSpaceSpecial, 0x0000_011F, "TPM_CC_NV_UndefineSpaceSpecial"),
        (EvictControl, 0x0000_0120, "TPM_CC_EvictControl"),
        (HierarchyControl, 0x0000_0121, "TPM_CC_HierarchyControl"),
        (NvUndefineSpace, 0x0000_0122, "TPM_CC_NV_UndefineSpace"),
        (ChangeEps, 0x0000_0124, "TPM_CC_ChangeEPS"),
        (ChangePps, 0x0000_0125, "TPM_CC_ChangePPS"),
        (Clear, 0x0000_0126, "TPM_CC_Clear"),
        (ClearControl, 0x0000_0127, "TPM_CC_ClearControl"),
        (ClockSet, 0x0000_0128, "TPM_CC_ClockSet"),
        (HierarchyChangeAuth, 0x0000_0129, "TPM_CC_HierarchyChangeAuth"),
        (NvDefineSpace, 0x0000_012A, "TPM_CC_NV_DefineSpace"),
        (PcrAllocate, 0x0000_012B, "TPM_CC_PCR_Allocate"),
        (PcrSetAuthPolicy, 0x0000_012C, "TPM_CC_PCR_SetAuthPolicy"),
        (PpCommands, 0x0000_012D, "TPM_CC_PP_Commands"),
        (SetPrimaryPolicy, 0x0000_012E, "TPM_CC_SetPrimaryPolicy"),
        (FieldUpgradeStart, 0x0000_012F, "TPM_CC_FieldUpgradeStart"),
        (ClockRateAdjust, 0x0000_0130, "TPM_CC_ClockRateAdjust"),
        (CreatePrimary, 0x0000_0131, "TPM_CC_CreatePrimary"),
        (NvGlobalWriteLock, 0x0000_0132, "TPM_CC_NV_GlobalWriteLock"),
        (GetCommandAuditDigest, 0x0000_0133, "TPM_CC_GetCommandAuditDigest"),
        (NvIncrement, 0x0000_0134, "TPM_CC_NV_Increment"),
        (NvSetBits, 0x0000_0135, "TPM_CC_NV_SetBits"),
        (NvExtend, 0x0000_0136, "TPM_CC_NV_Extend"),
        (NvWrite, 0x0000_0137, "TPM_CC_NV_Write"),
        (NvWriteLock, 0x0000_0138, "TPM_CC_NV_WriteLock"),
        (DictionaryAttackLockReset, 0x0000_0139, "TPM_CC_DictionaryAttackLockReset"),
        (DictionaryAttackParameters, 0x0000_013A, "TPM_CC_DictionaryAttackParameters"),
        (NvChangeAuth, 0x0000_013B, "TPM_CC_NV_ChangeAuth"),
        (PcrEvent, 0x0000_013C, "TPM_CC_PCR_Event"),
        (PcrReset, 0x0000_013D, "TPM_CC_PCR_Reset"),
        (SequenceComplete, 0x0000_013E, "TPM_CC_SequenceComplete"),
        (SetAlgorithmSet, 0x0000_013F, "TPM_CC_SetAlgorithmSet"),
        (SetCommandCodeAuditStatus, 0x0000_0140, "TPM_CC_SetCommandCodeAuditStatus"),
        (FieldUpgradeData, 0x0000_0141, "TPM_CC_FieldUpgradeData"),
        (IncrementalSelfTest, 0x0000_0142, "TPM_CC_IncrementalSelfTest"),
        (SelfTest, 0x0000_0143, "TPM_CC_SelfTest"),
        (Startup, 0x0000_0144, "TPM_CC_Startup"),
        (Shutdown, 0x0000_0145, "TPM_CC_Shutdown"),
        (StirRandom, 0x0000_0146, "TPM_CC_StirRandom"),
        (ActivateCredential, 0x0000_0147, "TPM_CC_ActivateCredential"),
        (Certify, 0x0000_0148, "TPM_CC_Certify"),
        (PolicyNv, 0x0000_0149, "TPM_CC_PolicyNV"),
        (CertifyCreation, 0x0000_014A, "TPM_CC_CertifyCreation"),
        (Duplicate, 0x0000_014B, "TPM_CC_Duplicate"),
        (GetTime, 0x0000_014C, "TPM_CC_GetTime"),
        (GetSessionAuditDigest, 0x0000_014D, "TPM_CC_GetSessionAuditDigest"),
        (NvRead, 0x0000_014E, "TPM_CC_NV_Read"),
        (NvReadLock, 0x0000_014F, "TPM_CC_NV_ReadLock"),
        (ObjectChangeAuth, 0x0000_0150, "TPM_CC_ObjectChangeAuth"),
        (PolicySecret, 0x0000_0151, "TPM_CC_PolicySecret"),
        (Rewrap, 0x0000_0152, "TPM_CC_Rewrap"),
        (Create, 0x0000_0153, "TPM_CC_Create"),
        (EcdhZGen, 0x0000_0154, "TPM_CC_ECDH_ZGen"),
        (Hmac, 0x0000_0155, "TPM_CC_HMAC"),
        (Import, 0x0000_0156, "TPM_CC_Import"),
        (Load, 0x0000_0157, "TPM_CC_Load"),
        (Quote, 0x0000_0158, "TPM_CC_Quote"),
        (RsaDecrypt, 0x0000_0159, "TPM_CC_RSA_Decrypt"),
        (HmacStart, 0x0000_015B, "TPM_CC_HMAC_Start"),
        (SequenceUpdate, 0x0000_015C, "TPM_CC_SequenceUpdate"),
        (Sign, 0x0000_015D, "TPM_CC_Sign"),
        (Unseal, 0x0000_015E, "TPM_CC_Unseal"),
        (PolicySigned, 0x0000_0160, "TPM_CC_PolicySigned"),
        (ContextLoad, 0x0000_0161, "TPM_CC_ContextLoad"),
        (ContextSave, 0x0000_0162, "TPM_CC_ContextSave"),
        (EcdhKeyGen, 0x0000_0163, "TPM_CC_ECDH_KeyGen"),
        (EncryptDecrypt, 0x0000_0164, "TPM_CC_EncryptDecrypt"),
        (FlushContext, 0x0000_0165, "TPM_CC_FlushContext"),
        (LoadExternal, 0x0000_0167, "TPM_CC_LoadExternal"),
        (MakeCredential, 0x0000_0168, "TPM_CC_MakeCredential"),
        (NvReadPublic, 0x0000_0169, "TPM_CC_NV_ReadPublic"),
        (PolicyAuthorize, 0x0000_016A, "TPM_CC_PolicyAuthorize"),
        (PolicyAuthValue, 0x0000_016B, "TPM_CC_PolicyAuthValue"),
        (PolicyCommandCode, 0x0000_016C, "TPM_CC_PolicyCommandCode"),
        (PolicyCounterTimer, 0x0000_016D, "TPM_CC_PolicyCounterTimer"),
        (PolicyCpHash, 0x0000_016E, "TPM_CC_PolicyCpHash"),
        (PolicyLocality, 0x0000_016F, "TPM_CC_PolicyLocality"),
        (PolicyNameHash, 0x0000_0170, "TPM_CC_PolicyNameHash"),
        (PolicyOR, 0x0000_0171, "TPM_CC_PolicyOR"),
        (PolicyTicket, 0x0000_0172, "TPM_CC_PolicyTicket"),
        (ReadPublic, 0x0000_0173, "TPM_CC_ReadPublic"),
        (RsaEncrypt, 0x0000_0174, "TPM_CC_RSA_Encrypt"),
        (StartAuthSession, 0x0000_0176, "TPM_CC_StartAuthSession"),
        (VerifySignature, 0x0000_0177, "TPM_CC_VerifySignature"),
        (EccParameters, 0x0000_0178, "TPM_CC_ECC_Parameters"),
        (FirmwareRead, 0x0000_0179, "TPM_CC_FirmwareRead"),
        (GetCapability, 0x0000_017A, "TPM_CC_GetCapability"),
        (GetRandom, 0x0000_017B, "TPM_CC_GetRandom"),
        (GetTestResult, 0x0000_017C, "TPM_CC_GetTestResult"),
        (Hash, 0x0000_017D, "TPM_CC_Hash"),
        (PcrRead, 0x0000_017E, "TPM_CC_PCR_Read"),
        (PolicyPcr, 0x0000_017F, "TPM_CC_PolicyPCR"),
        (PolicyRestart, 0x0000_0180, "TPM_CC_PolicyRestart"),
        (ReadClock, 0x0000_0181, "TPM_CC_ReadClock"),
        (PcrExtend, 0x0000_0182, "TPM_CC_PCR_Extend"),
        (PcrSetAuthValue, 0x0000_0183, "TPM_CC_PCR_SetAuthValue"),
        (NvCertify, 0x0000_0184, "TPM_CC_NV_Certify"),
        (EventSequenceComplete, 0x0000_0185, "TPM_CC_EventSequenceComplete"),
        (HashSequenceStart, 0x0000_0186, "TPM_CC_HashSequenceStart"),
        (PolicyPhysicalPresence, 0x0000_0187, "TPM_CC_PolicyPhysicalPresence"),
        (PolicyDuplicationSelect, 0x0000_0188, "TPM_CC_PolicyDuplicationSelect"),
        (PolicyGetDigest, 0x0000_0189, "TPM_CC_PolicyGetDigest"),
        (TestParms, 0x0000_018A, "TPM_CC_TestParms"),
        (Commit, 0x0000_018B, "TPM_CC_Commit"),
        (PolicyPassword, 0x0000_018C, "TPM_CC_PolicyPassword"),
        (ZGen2Phase, 0x0000_018D, "TPM_CC_ZGen_2Phase"),
        (EcEphemeral, 0x0000_018E, "TPM_CC_EC_Ephemeral"),
        (PolicyNvWritten, 0x0000_018F, "TPM_CC_PolicyNvWritten"),
        (PolicyTemplate, 0x0000_0190, "TPM_CC_PolicyTemplate"),
        (CreateLoaded, 0x0000_0191, "TPM_CC_CreateLoaded"),
        (PolicyAuthorizeNv, 0x0000_0192, "TPM_CC_PolicyAuthorizeNV"),
        (EncryptDecrypt2, 0x0000_0193, "TPM_CC_EncryptDecrypt2"),
        (AcGetCapability, 0x0000_0194, "TPM_CC_AcGetCapability"),
        (AcSend, 0x0000_0195, "TPM_CC_AcSend"),
        (PolicyAcSendSelect, 0x0000_0196, "TPM_CC_Policy_AC_SendSelect"),
        (ActSetTimeout, 0x0000_0198, "TPM2_ACT_SetTimeout"),
        (EccEncrypt, 0x0000_0199, "TPM_CC_ECC_Encrypt"),
        (EccDecrypt, 0x0000_019A, "TPM_CC_ECC_Decrypt"),
        (PolicyCapability, 0x0000_019B, "TPM_CC_PolicyCapability"),
        (PolicyParameters, 0x0000_019C, "TPM_CC_PolicyParameters"),
        (NvDefineSpace2, 0x0000_019D, "TPM_CC_NV_DefineSpace2"),
        (NvReadPublic2, 0x0000_019E, "TPM_CC_NV_ReadPublic2"),
        (SetCapability, 0x0000_019F, "TPM_CC_SetCapability"),
        (ReadOnlyControl, 0x0000_01A0, "TPM_CC_ReadOnlyControl"),
        (PolicyTransportSpdm, 0x0000_01A1, "TPM_CC_Policy_TransportSPDM"),
        (VendorTcgTest, 0x2000_0000, "TPM_CC_Vendor_TCG_Test"),
    }
}

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, PartialOrd, Ord, Copy, Clone, Hash, Default)]
    pub enum TpmClockAdjust(i8) {
        (CoarseSlower, -3, "TPM_CLOCK_COARSE_SLOWER"),
        (MediumSlower, -2, "TPM_CLOCK_MEDIUM_SLOWER"),
        (FineSlower, -1, "TPM_CLOCK_FINE_SLOWER"),
        #[default]
        (NoChange, 0, "TPM_CLOCK_NO_CHANGE"),
        (FineFaster, 1, "TPM_CLOCK_FINE_FASTER"),
        (MediumFaster, 2, "TPM_CLOCK_MEDIUM_FASTER"),
        (CoarseFaster, 3, "TPM_CLOCK_COARSE_FASTER"),
    }
}

tpm_enum! {
    #[derive(Debug, Default, PartialEq, Eq, Copy, Clone)]
    pub enum TpmEo(u16) {
        #[default]
        (Eq, 0x0000, "TPM_EO_EQ"),
        (Neq, 0x0001, "TPM_EO_NEQ"),
        (SignedGt, 0x0002, "TPM_EO_SIGNED_GT"),
        (UnsignedGt, 0x0003, "TPM_EO_UNSIGNED_GT"),
        (SignedLt, 0x0004, "TPM_EO_SIGNED_LT"),
        (UnsignedLt, 0x0005, "TPM_EO_UNSIGNED_LT"),
        (SignedGe, 0x0006, "TPM_EO_SIGNED_GE"),
        (UnsignedGe, 0x0007, "TPM_EO_UNSIGNED_GE"),
        (SignedLe, 0x0008, "TPM_EO_SIGNED_LE"),
        (UnsignedLe, 0x0009, "TPM_EO_UNSIGNED_LE"),
        (Bitset, 0x000A, "TPM_EO_BITSET"),
        (Bitclear, 0x000B, "TPM_EO_BITCLEAR"),
    }
}

tpm_enum! {
    #[derive(Debug, Default, PartialEq, Eq, Clone, Copy)]
    pub enum TpmEccCurve(u16) {
        #[default]
        (None, 0x0000, "TPM_ECC_NONE"),
        (NistP192, 0x0001, "TPM_ECC_NIST_P192"),
        (NistP224, 0x0002, "TPM_ECC_NIST_P224"),
        (NistP256, 0x0003, "TPM_ECC_NIST_P256"),
        (NistP384, 0x0004, "TPM_ECC_NIST_P384"),
        (NistP521, 0x0005, "TPM_ECC_NIST_P521"),
        (BnP256, 0x0010, "TPM_ECC_BN_P256"),
        (BnP638, 0x0011, "TPM_ECC_BN_P638"),
        (Sm2P256, 0x0020, "TPM_ECC_SM2_P256"),
        (BpP256R1, 0x0030, "TPM_ECC_BP_P256_R1"),
        (BpP384R1, 0x0031, "TPM_ECC_BP_P384_R1"),
        (BpP512R1, 0x0032, "TPM_ECC_BP_P512_R1"),
        (Curve25519, 0x0040, "TPM_ECC_CURVE_25519"),
        (Curve448, 0x0041, "TPM_ECC_CURVE_448"),
    }
}

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, Copy, Clone)]
    pub enum TpmHt(u8) {
        (Pcr, 0x00, "TPM_HT_PCR"),
        (NvIndex, 0x01, "TPM_HT_NV_INDEX"),
        (HmacSession, 0x02, "TPM_HT_HMAC_SESSION"),
        (PolicySession, 0x03, "TPM_HT_POLICY_SESSION"),
        (ExternalNv, 0x11, "TPM_HT_EXTERNAL_NV"),
        (PermanentNv, 0x12, "TPM_HT_PERMANENT_NV"),
        (Permanent, 0x40, "TPM_HT_PERMANENT"),
        (Transient, 0x80, "TPM_HT_TRANSIENT"),
        (Persistent, 0x81, "TPM_HT_PERSISTENT"),
        (Ac, 0x90, "TPM_HT_AC"),
    }
}

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, Copy, Clone)]
    pub enum TpmPt(u32) {
        (FamilyIndicator, 0x100, "TPM_PT_FAMILY_INDICATOR"),
        (Level, 0x101, "TPM_PT_LEVEL"),
        (Revision, 0x102, "TPM_PT_REVISION"),
        (DayOfYear, 0x103, "TPM_PT_DAY_OF_YEAR"),
        (Year, 0x104, "TPM_PT_YEAR"),
        (Manufacturer, 0x105, "TPM_PT_MANUFACTURER"),
        (VendorString1, 0x106, "TPM_PT_VENDOR_STRING_1"),
        (VendorString2, 0x107, "TPM_PT_VENDOR_STRING_2"),
        (VendorString3, 0x108, "TPM_PT_VENDOR_STRING_3"),
        (VendorString4, 0x109, "TPM_PT_VENDOR_STRING_4"),
        (VendorTpmType, 0x10A, "TPM_PT_VENDOR_TPM_TYPE"),
        (FirmwareVersion1, 0x10B, "TPM_PT_FIRMWARE_VERSION_1"),
        (FirmwareVersion2, 0x10C, "TPM_PT_FIRMWARE_VERSION_2"),
        (InputBuffer, 0x10D, "TPM_PT_INPUT_BUFFER"),
        (HrTransientMin, 0x10E, "TPM_PT_HR_TRANSIENT_MIN"),
        (HrPersistentMin, 0x10F, "TPM_PT_HR_PERSISTENT_MIN"),
        (HrLoadedMin, 0x110, "TPM_PT_HR_LOADED_MIN"),
        (ActiveSessionsMax, 0x111, "TPM_PT_ACTIVE_SESSIONS_MAX"),
        (PcrCount, 0x112, "TPM_PT_PCR_COUNT"),
        (PcrSelectMin, 0x113, "TPM_PT_PCR_SELECT_MIN"),
        (ContextGapMax, 0x114, "TPM_PT_CONTEXT_GAP_MAX"),
        (NvCountersMax, 0x116, "TPM_PT_NV_COUNTERS_MAX"),
        (NvIndexMax, 0x117, "TPM_PT_NV_INDEX_MAX"),
        (Memory, 0x118, "TPM_PT_MEMORY"),
        (ClockUpdate, 0x119, "TPM_PT_CLOCK_UPDATE"),
        (ContextHash, 0x11A, "TPM_PT_CONTEXT_HASH"),
        (ContextSym, 0x11B, "TPM_PT_CONTEXT_SYM"),
        (ContextSymSize, 0x11C, "TPM_PT_CONTEXT_SYM_SIZE"),
        (OrderlyCount, 0x11D, "TPM_PT_ORDERLY_COUNT"),
        (MaxCommandSize, 0x11E, "TPM_PT_MAX_COMMAND_SIZE"),
        (MaxResponseSize, 0x11F, "TPM_PT_MAX_RESPONSE_SIZE"),
        (MaxDigest, 0x120, "TPM_PT_MAX_DIGEST"),
        (MaxObjectContext, 0x121, "TPM_PT_MAX_OBJECT_CONTEXT"),
        (MaxSessionContext, 0x122, "TPM_PT_MAX_SESSION_CONTEXT"),
        (PsFamilyIndicator, 0x123, "TPM_PT_PS_FAMILY_INDICATOR"),
        (PsLevel, 0x124, "TPM_PT_PS_LEVEL"),
        (PsRevision, 0x125, "TPM_PT_PS_REVISION"),
        (PsDayOfYear, 0x126, "TPM_PT_PS_DAY_OF_YEAR"),
        (PsYear, 0x127, "TPM_PT_PS_YEAR"),
        (SplitMax, 0x128, "TPM_PT_SPLIT_MAX"),
        (TotalCommands, 0x129, "TPM_PT_TOTAL_COMMANDS"),
        (LibraryCommands, 0x12A, "TPM_PT_LIBRARY_COMMANDS"),
        (VendorCommands, 0x12B, "TPM_PT_VENDOR_COMMANDS"),
        (NvBufferMax, 0x12C, "TPM_PT_NV_BUFFER_MAX"),
        (Modes, 0x12D, "TPM_PT_MODES"),
        (MaxCapBuffer, 0x12E, "TPM_PT_MAX_CAP_BUFFER"),
        (Permanent, 0x200, "TPM_PT_PERMANENT"),
        (StartupClear, 0x201, "TPM_PT_STARTUP_CLEAR"),
        (HrNvIndex, 0x202, "TPM_PT_HR_NV_INDEX"),
        (HrLoaded, 0x203, "TPM_PT_HR_LOADED"),
        (HrLoadedAvail, 0x204, "TPM_PT_HR_LOADED_AVAIL"),
        (HrActive, 0x205, "TPM_PT_HR_ACTIVE"),
        (HrActiveAvail, 0x206, "TPM_PT_HR_ACTIVE_AVAIL"),
        (HrTransientAvail, 0x207, "TPM_PT_HR_TRANSIENT_AVAIL"),
        (HrPersistent, 0x208, "TPM_PT_HR_PERSISTENT"),
        (HrPersistentAvail, 0x209, "TPM_PT_HR_PERSISTENT_AVAIL"),
        (NvCounters, 0x20A, "TPM_PT_NV_COUNTERS"),
        (NvCountersAvail, 0x20B, "TPM_PT_NV_COUNTERS_AVAIL"),
        (AlgorithmSet, 0x20C, "TPM_PT_ALGORITHM_SET"),
        (LoadedCurves, 0x20D, "TPM_PT_LOADED_CURVES"),
        (LockoutCounter, 0x20E, "TPM_PT_LOCKOUT_COUNTER"),
        (MaxAuthFail, 0x20F, "TPM_PT_MAX_AUTH_FAIL"),
        (LockoutInterval, 0x210, "TPM_PT_LOCKOUT_INTERVAL"),
        (LockoutRecovery, 0x211, "TPM_PT_LOCKOUT_RECOVERY"),
        (NvWriteRecovery, 0x212, "TPM_PT_NV_WRITE_RECOVERY"),
        (AuditCounter0, 0x213, "TPM_PT_AUDIT_COUNTER_0"),
        (AuditCounter1, 0x214, "TPM_PT_AUDIT_COUNTER_1"),
    }
}

tpm_enum! {
    #[derive(Debug, Default, PartialEq, Eq, Copy, Clone)]
    pub enum TpmRh(u32) {
        (Srk, 0x4000_0000, "TPM_RH_SRK"),
        (Owner, 0x4000_0001, "TPM_RH_OWNER"),
        (Revoke, 0x4000_0002, "TPM_RH_REVOKE"),
        (Transport, 0x4000_0003, "TPM_RH_TRANSPORT"),
        (Operator, 0x4000_0004, "TPM_RH_OPERATOR"),
        (Admin, 0x4000_0005, "TPM_RH_ADMIN"),
        (Ek, 0x4000_0006, "TPM_RH_EK"),
        #[default]
        (Null, 0x4000_0007, "TPM_RH_NULL"),
        (Unassigned, 0x4000_0008, "TPM_RH_UNASSIGNED"),
        (Pw, 0x4000_0009, "TPM_RS_PW"),
        (Lockout, 0x4000_000A, "TPM_RH_LOCKOUT"),
        (Endorsement, 0x4000_000B, "TPM_RH_ENDORSEMENT"),
        (Platform, 0x4000_000C, "TPM_RH_PLATFORM"),
        (PlatformNv, 0x4000_000D, "TPM_RH_PLATFORM_NV"),
        (FwOwner, 0x4000_0140, "TPM_RH_FW_OWNER"),
        (FwEndorsement, 0x4000_0141, "TPM_RH_FW_ENDORSEMENT"),
        (FwPlatform, 0x4000_0142, "TPM_RH_FW_PLATFORM"),
        (FwNull, 0x4000_0143, "TPM_RH_FW_NULL"),
        (SvnOwnerBase, 0x4001_0000, "TPM_RH_SVN_OWNER_BASE"),
        (SvnEndorsementBase, 0x4002_0000, "TPM_RH_SVN_ENDORSEMENT_BASE"),
        (SvnPlatformBase, 0x4003_0000, "TPM_RH_SVN_PLATFORM_BASE"),
        (SvnNullBase, 0x4004_0000, "TPM_RH_SVN_NULL_BASE"),
    }
}

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, Copy, Clone)]
    pub enum TpmSe(u8) {
        (Hmac, 0x00, "TPM_SE_HMAC"),
        (Policy, 0x01, "TPM_SE_POLICY"),
        (Trial, 0x03, "TPM_SE_TRIAL"),
    }
}

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, Copy, Clone, Default)]
    pub enum TpmSt(u16) {
        (RspCommand, 0x00C4, "TPM_ST_RSP_COMMAND"),
        #[default]
        (Null, 0x8000, "TPM_ST_NULL"),
        (NoSessions, 0x8001, "TPM_ST_NO_SESSIONS"),
        (Sessions, 0x8002, "TPM_ST_SESSIONS"),
        (AttestNv, 0x8014, "TPM_ST_ATTEST_NV"),
        (AttestCommandAudit, 0x8015, "TPM_ST_ATTEST_COMMAND_AUDIT"),
        (AttestSessionAudit, 0x8016, "TPM_ST_ATTEST_SESSION_AUDIT"),
        (AttestCertify, 0x8017, "TPM_ST_ATTEST_CERTIFY"),
        (AttestQuote, 0x8018, "TPM_ST_ATTEST_QUOTE"),
        (AttestTime, 0x8019, "TPM_ST_ATTEST_TIME"),
        (AttestCreation, 0x801A, "TPM_ST_ATTEST_CREATION"),
        (AttestNvDigest, 0x801C, "TPM_ST_ATTEST_NV_DIGEST"),
        (Creation, 0x8021, "TPM_ST_CREATION"),
        (Verified, 0x8022, "TPM_ST_VERIFIED"),
        (AuthSecret, 0x8023, "TPM_ST_AUTH_SECRET"),
        (HashCheck, 0x8024, "TPM_ST_HASHCHECK"),
        (AuthSigned, 0x8025, "TPM_ST_AUTH_SIGNED"),
    }
}

tpm_enum! {
    #[derive(Debug, PartialEq, Eq, Copy, Clone)]
    pub enum TpmSu(u16) {
        (Clear, 0x0000, "TPM_SU_CLEAR"),
        (State, 0x0001, "TPM_SU_STATE"),
    }
}