blob: 4316df112805dd25df1f20c83cd721f1966e008e [file] [log] [blame]
/* Microsoft Reference Implementation for TPM 2.0
*
* The copyright in this software is being made available under the BSD License,
* included below. This software may be subject to other third party and
* contributor rights, including patent rights, and no such rights are granted
* under this license.
*
* Copyright (c) Microsoft Corporation
*
* All rights reserved.
*
* BSD License
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this list
* of conditions and the following disclaimer.
*
* Redistributions in binary form must reproduce the above copyright notice, this
* list of conditions and the following disclaimer in the documentation and/or
* other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ""AS IS""
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/*(Auto-generated)
* Created by NewMarshal; Version 1.4 Apr 7, 2019
* Date: Mar 6, 2020 Time: 01:50:10PM
*/
// This file contains the data initializer used for the table-driven marshaling code.
#include "Tpm.h"
#if TABLE_DRIVEN_MARSHAL
#include "TableMarshal.h"
#include "Marshal.h"
// The array marshaling table
ArrayMarshal_mst ArrayLookupTable[] = {
ARRAY_MARSHAL_ENTRY(UINT8),
ARRAY_MARSHAL_ENTRY(TPM_CC),
ARRAY_MARSHAL_ENTRY(TPMA_CC),
ARRAY_MARSHAL_ENTRY(TPM_ALG_ID),
ARRAY_MARSHAL_ENTRY(TPM_HANDLE),
ARRAY_MARSHAL_ENTRY(TPM2B_DIGEST),
ARRAY_MARSHAL_ENTRY(TPMT_HA),
ARRAY_MARSHAL_ENTRY(TPMS_PCR_SELECTION),
ARRAY_MARSHAL_ENTRY(TPMS_ALG_PROPERTY),
ARRAY_MARSHAL_ENTRY(TPMS_TAGGED_PROPERTY),
ARRAY_MARSHAL_ENTRY(TPMS_TAGGED_PCR_SELECT),
ARRAY_MARSHAL_ENTRY(TPM_ECC_CURVE),
ARRAY_MARSHAL_ENTRY(TPMS_TAGGED_POLICY),
ARRAY_MARSHAL_ENTRY(TPMS_ACT_DATA),
ARRAY_MARSHAL_ENTRY(TPMS_AC_OUTPUT)};
// The main marshaling structure
MarshalData_st MarshalData = {
// UINT8_DATA
{UINT_MTYPE, 0},
// UINT16_DATA
{UINT_MTYPE, 1},
// UINT32_DATA
{UINT_MTYPE, 2},
// UINT64_DATA
{UINT_MTYPE, 3},
// INT8_DATA
{UINT_MTYPE, 0 + IS_SIGNED},
// INT16_DATA
{UINT_MTYPE, 1 + IS_SIGNED},
// INT32_DATA
{UINT_MTYPE, 2 + IS_SIGNED},
// INT64_DATA
{UINT_MTYPE, 3 + IS_SIGNED},
// UINT0_DATA
{NULL_MTYPE, 0},
// TPM_ECC_CURVE_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_CURVE,
{TPM_ECC_NONE,
RANGE(1, 32, UINT16),
(UINT32)((ECC_NIST_P192 << 0) | (ECC_NIST_P224 << 1) | (ECC_NIST_P256 << 2) |
(ECC_NIST_P384 << 3) | (ECC_NIST_P521 << 4) | (ECC_BN_P256 << 15) |
(ECC_BN_P638 << 16) | (ECC_SM2_P256 << 31))}},
// TPM_CLOCK_ADJUST_DATA
{MIN_MAX_MTYPE, ONE_BYTES|IS_SIGNED, (UINT8)TPM_RC_VALUE,
{RANGE(TPM_CLOCK_COARSE_SLOWER, TPM_CLOCK_COARSE_FASTER, INT8)}},
// TPM_EO_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_VALUE,
{RANGE(TPM_EO_EQ, TPM_EO_BITCLEAR, UINT16)}},
// TPM_SU_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_VALUE, 2,
{TPM_SU_CLEAR, TPM_SU_STATE}},
// TPM_SE_DATA
{TABLE_MTYPE, ONE_BYTES, (UINT8)TPM_RC_VALUE, 3,
{TPM_SE_HMAC, TPM_SE_POLICY, TPM_SE_TRIAL}},
// TPM_CAP_DATA
{VALUES_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 1, 1,
{RANGE(TPM_CAP_ALGS, TPM_CAP_ACT, UINT32),
TPM_CAP_VENDOR_PROPERTY}},
// TPMA_ALGORITHM_DATA
{ATTRIBUTES_MTYPE, FOUR_BYTES, 0xFFFFF8F0},
// TPMA_OBJECT_DATA
{ATTRIBUTES_MTYPE, FOUR_BYTES, 0xFFF0F309},
// TPMA_SESSION_DATA
{ATTRIBUTES_MTYPE, ONE_BYTES, 0x00000018},
// TPMA_ACT_DATA
{ATTRIBUTES_MTYPE, FOUR_BYTES, 0xFFFFFFFC},
// TPMI_YES_NO_DATA
{TABLE_MTYPE, ONE_BYTES, (UINT8)TPM_RC_VALUE, 2,
{NO, YES}},
// TPMI_DH_OBJECT_DATA
{VALUES_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE, 2, 0,
{TPM_RH_NULL,
RANGE(TRANSIENT_FIRST, TRANSIENT_LAST, UINT32),
RANGE(PERSISTENT_FIRST, PERSISTENT_LAST, UINT32)}},
// TPMI_DH_PARENT_DATA
{VALUES_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE, 2, 3,
{TPM_RH_NULL,
RANGE(TRANSIENT_FIRST, TRANSIENT_LAST, UINT32),
RANGE(PERSISTENT_FIRST, PERSISTENT_LAST, UINT32),
TPM_RH_OWNER, TPM_RH_ENDORSEMENT, TPM_RH_PLATFORM}},
// TPMI_DH_PERSISTENT_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE,
{RANGE(PERSISTENT_FIRST, PERSISTENT_LAST, UINT32)}},
// TPMI_DH_ENTITY_DATA
{VALUES_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE, 5, 4,
{TPM_RH_NULL,
RANGE(TRANSIENT_FIRST, TRANSIENT_LAST, UINT32),
RANGE(PERSISTENT_FIRST, PERSISTENT_LAST, UINT32),
RANGE(NV_INDEX_FIRST, NV_INDEX_LAST, UINT32),
RANGE(PCR_FIRST, PCR_LAST, UINT32),
RANGE(TPM_RH_AUTH_00, TPM_RH_AUTH_FF, UINT32),
TPM_RH_OWNER, TPM_RH_LOCKOUT, TPM_RH_ENDORSEMENT, TPM_RH_PLATFORM}},
// TPMI_DH_PCR_DATA
{MIN_MAX_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE,
{TPM_RH_NULL,
RANGE(PCR_FIRST, PCR_LAST, UINT32)}},
// TPMI_SH_AUTH_SESSION_DATA
{VALUES_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE, 2, 0,
{TPM_RS_PW,
RANGE(HMAC_SESSION_FIRST, HMAC_SESSION_LAST, UINT32),
RANGE(POLICY_SESSION_FIRST, POLICY_SESSION_LAST, UINT32)}},
// TPMI_SH_HMAC_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE,
{RANGE(HMAC_SESSION_FIRST, HMAC_SESSION_LAST, UINT32)}},
// TPMI_SH_POLICY_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE,
{RANGE(POLICY_SESSION_FIRST, POLICY_SESSION_LAST, UINT32)}},
// TPMI_DH_CONTEXT_DATA
{VALUES_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 3, 0,
{RANGE(HMAC_SESSION_FIRST, HMAC_SESSION_LAST, UINT32),
RANGE(POLICY_SESSION_FIRST, POLICY_SESSION_LAST, UINT32),
RANGE(TRANSIENT_FIRST, TRANSIENT_LAST, UINT32)}},
// TPMI_DH_SAVED_DATA
{VALUES_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 2, 3,
{RANGE(HMAC_SESSION_FIRST, HMAC_SESSION_LAST, UINT32),
RANGE(POLICY_SESSION_FIRST, POLICY_SESSION_LAST, UINT32),
0x80000000, 0x80000001, 0x80000002}},
// TPMI_RH_HIERARCHY_DATA
{TABLE_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE, 3,
{TPM_RH_NULL,
TPM_RH_OWNER, TPM_RH_ENDORSEMENT, TPM_RH_PLATFORM}},
// TPMI_RH_ENABLES_DATA
{TABLE_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE, 4,
{TPM_RH_NULL,
TPM_RH_OWNER, TPM_RH_ENDORSEMENT, TPM_RH_PLATFORM, TPM_RH_PLATFORM_NV}},
// TPMI_RH_HIERARCHY_AUTH_DATA
{TABLE_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 4,
{TPM_RH_OWNER, TPM_RH_LOCKOUT, TPM_RH_ENDORSEMENT, TPM_RH_PLATFORM}},
// TPMI_RH_HIERARCHY_POLICY_DATA
{VALUES_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 1, 4,
{RANGE(TPM_RH_ACT_0, TPM_RH_ACT_F, UINT32),
TPM_RH_OWNER, TPM_RH_LOCKOUT, TPM_RH_ENDORSEMENT, TPM_RH_PLATFORM}},
// TPMI_RH_PLATFORM_DATA
{TABLE_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 1,
{TPM_RH_PLATFORM}},
// TPMI_RH_OWNER_DATA
{TABLE_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE, 1,
{TPM_RH_NULL,
TPM_RH_OWNER}},
// TPMI_RH_ENDORSEMENT_DATA
{TABLE_MTYPE, FOUR_BYTES|TAKES_NULL, (UINT8)TPM_RC_VALUE, 1,
{TPM_RH_NULL,
TPM_RH_ENDORSEMENT}},
// TPMI_RH_PROVISION_DATA
{TABLE_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 2,
{TPM_RH_OWNER, TPM_RH_PLATFORM}},
// TPMI_RH_CLEAR_DATA
{TABLE_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 2,
{TPM_RH_LOCKOUT, TPM_RH_PLATFORM}},
// TPMI_RH_NV_AUTH_DATA
{VALUES_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 1, 2,
{RANGE(NV_INDEX_FIRST, NV_INDEX_LAST, UINT32),
TPM_RH_OWNER, TPM_RH_PLATFORM}},
// TPMI_RH_LOCKOUT_DATA
{TABLE_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 1,
{TPM_RH_LOCKOUT}},
// TPMI_RH_NV_INDEX_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE,
{RANGE(NV_INDEX_FIRST, NV_INDEX_LAST, UINT32)}},
// TPMI_RH_AC_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE,
{RANGE(AC_FIRST, AC_LAST, UINT32)}},
// TPMI_RH_ACT_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE,
{RANGE(TPM_RH_ACT_0, TPM_RH_ACT_F, UINT32)}},
// TPMI_ALG_HASH_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_HASH,
{TPM_ALG_NULL,
RANGE(4, 41, UINT16),
(UINT32)((ALG_SHA1 << 0) | (ALG_SHA256 << 7) | (ALG_SHA384 << 8) |
(ALG_SHA512 << 9) | (ALG_SM3_256 << 14)),
(UINT32)((ALG_SHA3_256 << 3)|(ALG_SHA3_384 << 4)|(ALG_SHA3_512 << 5))}},
// TPMI_ALG_ASYM_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_ASYMMETRIC,
{TPM_ALG_NULL,
RANGE(1, 35, UINT16),
(UINT32)((ALG_RSA << 0)),
(UINT32)((ALG_ECC << 2))}},
// TPMI_ALG_SYM_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_SYMMETRIC,
{TPM_ALG_NULL,
RANGE(3, 38, UINT16),
(UINT32)((ALG_TDES << 0)|(ALG_AES << 3)|(ALG_XOR << 7)|(ALG_SM4 << 16)),
(UINT32)((ALG_CAMELLIA << 3))}},
// TPMI_ALG_SYM_OBJECT_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_SYMMETRIC,
{TPM_ALG_NULL,
RANGE(3, 38, UINT16),
(UINT32)((ALG_TDES << 0)|(ALG_AES << 3)|(ALG_SM4 << 16)),
(UINT32)((ALG_CAMELLIA << 3))}},
// TPMI_ALG_SYM_MODE_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_MODE,
{TPM_ALG_NULL,
RANGE(63, 68, UINT16),
(UINT32)((ALG_CMAC << 0) | (ALG_CTR << 1) | (ALG_OFB << 2) |
(ALG_CBC << 3) | (ALG_CFB << 4) | (ALG_ECB << 5))}},
// TPMI_ALG_KDF_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_KDF,
{TPM_ALG_NULL,
RANGE(7, 34, UINT16),
(UINT32)((ALG_MGF1 << 0) | (ALG_KDF1_SP800_56A << 25) |
(ALG_KDF2 << 26) | (ALG_KDF1_SP800_108 << 27))}},
// TPMI_ALG_SIG_SCHEME_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_SCHEME,
{TPM_ALG_NULL,
RANGE(5, 28, UINT16),
(UINT32)((ALG_HMAC << 0) | (ALG_RSASSA << 15) | (ALG_RSAPSS << 17) |
(ALG_ECDSA << 19) | (ALG_ECDAA << 21) | (ALG_SM2 << 22) |
(ALG_ECSCHNORR << 23))}},
// TPMI_ECC_KEY_EXCHANGE_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_SCHEME,
{TPM_ALG_NULL,
RANGE(25, 29, UINT16),
(UINT32)((ALG_ECDH << 0)|(ALG_SM2 << 2)|(ALG_ECMQV << 4))}},
// TPMI_ST_COMMAND_TAG_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_BAD_TAG, 2,
{TPM_ST_NO_SESSIONS, TPM_ST_SESSIONS}},
// TPMI_ALG_MAC_SCHEME_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_SYMMETRIC,
{TPM_ALG_NULL,
RANGE(4, 63, UINT16),
(UINT32)((ALG_SHA1 << 0) | (ALG_SHA256 << 7) | (ALG_SHA384 << 8) |
(ALG_SHA512 << 9) | (ALG_SM3_256 << 14)),
(UINT32)((ALG_SHA3_256 << 3) | (ALG_SHA3_384 << 4) | (ALG_SHA3_512 << 5) |
(ALG_CMAC << 27))}},
// TPMI_ALG_CIPHER_MODE_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_MODE,
{TPM_ALG_NULL,
RANGE(64, 68, UINT16),
(UINT32)((ALG_CTR << 0) | (ALG_OFB << 1) | (ALG_CBC << 2) | (ALG_CFB << 3) |
(ALG_ECB << 4))}},
// TPMS_EMPTY_DATA
{STRUCTURE_MTYPE, 1,
{SET_ELEMENT_TYPE(SIMPLE_STYPE), UINT0_MARSHAL_REF, 0}},
// TPMS_ALGORITHM_DESCRIPTION_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPM_ALG_ID_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DESCRIPTION, alg)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMA_ALGORITHM_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DESCRIPTION, attributes))}},
// TPMU_HA_DATA
{9, IS_ARRAY_UNION, (UINT16)(offsetof(TPMU_HA_mst, marshalingTypes)),
{(UINT32)TPM_ALG_SHA1, (UINT32)TPM_ALG_SHA256, (UINT32)TPM_ALG_SHA384,
(UINT32)TPM_ALG_SHA512, (UINT32)TPM_ALG_SM3_256, (UINT32)TPM_ALG_SHA3_256,
(UINT32)TPM_ALG_SHA3_384, (UINT32)TPM_ALG_SHA3_512, (UINT32)TPM_ALG_NULL},
{(UINT16)(SHA1_DIGEST_SIZE), (UINT16)(SHA256_DIGEST_SIZE),
(UINT16)(SHA384_DIGEST_SIZE), (UINT16)(SHA512_DIGEST_SIZE),
(UINT16)(SM3_256_DIGEST_SIZE), (UINT16)(SHA3_256_DIGEST_SIZE),
(UINT16)(SHA3_384_DIGEST_SIZE), (UINT16)(SHA3_512_DIGEST_SIZE),
(UINT16)(0)}
},
// TPMT_HA_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMT_HA, hashAlg)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_HA_MARSHAL_REF,
(UINT16)(offsetof(TPMT_HA, digest))}},
// TPM2B_DIGEST_DATA
{TPM2B_MTYPE, Type00_MARSHAL_REF},
// TPM2B_DATA_DATA
{TPM2B_MTYPE, Type01_MARSHAL_REF},
// TPM2B_EVENT_DATA
{TPM2B_MTYPE, Type02_MARSHAL_REF},
// TPM2B_MAX_BUFFER_DATA
{TPM2B_MTYPE, Type03_MARSHAL_REF},
// TPM2B_MAX_NV_BUFFER_DATA
{TPM2B_MTYPE, Type04_MARSHAL_REF},
// TPM2B_TIMEOUT_DATA
{TPM2B_MTYPE, Type05_MARSHAL_REF},
// TPM2B_IV_DATA
{TPM2B_MTYPE, Type06_MARSHAL_REF},
// NULL_UNION_DATA
{0},
// TPM2B_NAME_DATA
{TPM2B_MTYPE, Type07_MARSHAL_REF},
// TPMS_PCR_SELECT_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(ONE_BYTES),
Type08_MARSHAL_REF,
(UINT16)(offsetof(TPMS_PCR_SELECT, sizeofSelect)),
SET_ELEMENT_TYPE(ARRAY_STYPE)|SET_ELEMENT_NUMBER(0),
UINT8_ARRAY_MARSHAL_INDEX,
(UINT16)(offsetof(TPMS_PCR_SELECT, pcrSelect))}},
// TPMS_PCR_SELECTION_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_PCR_SELECTION, hash)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(ONE_BYTES),
Type08_MARSHAL_REF,
(UINT16)(offsetof(TPMS_PCR_SELECTION, sizeofSelect)),
SET_ELEMENT_TYPE(ARRAY_STYPE)|SET_ELEMENT_NUMBER(1),
UINT8_ARRAY_MARSHAL_INDEX,
(UINT16)(offsetof(TPMS_PCR_SELECTION, pcrSelect))}},
// TPMT_TK_CREATION_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
Type10_MARSHAL_REF,
(UINT16)(offsetof(TPMT_TK_CREATION, tag)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMI_RH_HIERARCHY_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMT_TK_CREATION, hierarchy)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMT_TK_CREATION, digest))}},
// TPMT_TK_VERIFIED_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
Type11_MARSHAL_REF,
(UINT16)(offsetof(TPMT_TK_VERIFIED, tag)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMI_RH_HIERARCHY_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMT_TK_VERIFIED, hierarchy)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMT_TK_VERIFIED, digest))}},
// TPMT_TK_AUTH_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
Type12_MARSHAL_REF,
(UINT16)(offsetof(TPMT_TK_AUTH, tag)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMI_RH_HIERARCHY_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMT_TK_AUTH, hierarchy)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMT_TK_AUTH, digest))}},
// TPMT_TK_HASHCHECK_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
Type13_MARSHAL_REF,
(UINT16)(offsetof(TPMT_TK_HASHCHECK, tag)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMI_RH_HIERARCHY_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMT_TK_HASHCHECK, hierarchy)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMT_TK_HASHCHECK, digest))}},
// TPMS_ALG_PROPERTY_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPM_ALG_ID_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALG_PROPERTY, alg)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMA_ALGORITHM_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALG_PROPERTY, algProperties))}},
// TPMS_TAGGED_PROPERTY_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPM_PT_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TAGGED_PROPERTY, property)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
UINT32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TAGGED_PROPERTY, value))}},
// TPMS_TAGGED_PCR_SELECT_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPM_PT_PCR_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TAGGED_PCR_SELECT, tag)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(ONE_BYTES),
Type08_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TAGGED_PCR_SELECT, sizeofSelect)),
SET_ELEMENT_TYPE(ARRAY_STYPE)|SET_ELEMENT_NUMBER(1),
UINT8_ARRAY_MARSHAL_INDEX,
(UINT16)(offsetof(TPMS_TAGGED_PCR_SELECT, pcrSelect))}},
// TPMS_TAGGED_POLICY_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPM_HANDLE_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TAGGED_POLICY, handle)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_HA_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TAGGED_POLICY, policyHash))}},
// TPMS_ACT_DATA_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPM_HANDLE_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ACT_DATA, handle)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
UINT32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ACT_DATA, timeout)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMA_ACT_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ACT_DATA, attributes))}},
// TPML_CC_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_CC, commandCodes)),
Type15_MARSHAL_REF,
TPM_CC_ARRAY_MARSHAL_INDEX},
// TPML_CCA_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_CCA, commandAttributes)),
Type15_MARSHAL_REF,
TPMA_CC_ARRAY_MARSHAL_INDEX},
// TPML_ALG_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_ALG, algorithms)),
Type17_MARSHAL_REF,
TPM_ALG_ID_ARRAY_MARSHAL_INDEX},
// TPML_HANDLE_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_HANDLE, handle)),
Type18_MARSHAL_REF,
TPM_HANDLE_ARRAY_MARSHAL_INDEX},
// TPML_DIGEST_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_DIGEST, digests)),
Type19_MARSHAL_REF,
TPM2B_DIGEST_ARRAY_MARSHAL_INDEX},
// TPML_DIGEST_VALUES_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_DIGEST_VALUES, digests)),
Type20_MARSHAL_REF,
TPMT_HA_ARRAY_MARSHAL_INDEX},
// TPML_PCR_SELECTION_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_PCR_SELECTION, pcrSelections)),
Type20_MARSHAL_REF,
TPMS_PCR_SELECTION_ARRAY_MARSHAL_INDEX},
// TPML_ALG_PROPERTY_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_ALG_PROPERTY, algProperties)),
Type22_MARSHAL_REF,
TPMS_ALG_PROPERTY_ARRAY_MARSHAL_INDEX},
// TPML_TAGGED_TPM_PROPERTY_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_TAGGED_TPM_PROPERTY, tpmProperty)),
Type23_MARSHAL_REF,
TPMS_TAGGED_PROPERTY_ARRAY_MARSHAL_INDEX},
// TPML_TAGGED_PCR_PROPERTY_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_TAGGED_PCR_PROPERTY, pcrProperty)),
Type24_MARSHAL_REF,
TPMS_TAGGED_PCR_SELECT_ARRAY_MARSHAL_INDEX},
// TPML_ECC_CURVE_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_ECC_CURVE, eccCurves)),
Type25_MARSHAL_REF,
TPM_ECC_CURVE_ARRAY_MARSHAL_INDEX},
// TPML_TAGGED_POLICY_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_TAGGED_POLICY, policies)),
Type26_MARSHAL_REF,
TPMS_TAGGED_POLICY_ARRAY_MARSHAL_INDEX},
// TPML_ACT_DATA_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_ACT_DATA, actData)),
Type27_MARSHAL_REF,
TPMS_ACT_DATA_ARRAY_MARSHAL_INDEX},
// TPMU_CAPABILITIES_DATA
{11, 0, (UINT16)(offsetof(TPMU_CAPABILITIES_mst, marshalingTypes)),
{(UINT32)TPM_CAP_ALGS, (UINT32)TPM_CAP_HANDLES,
(UINT32)TPM_CAP_COMMANDS, (UINT32)TPM_CAP_PP_COMMANDS,
(UINT32)TPM_CAP_AUDIT_COMMANDS, (UINT32)TPM_CAP_PCRS,
(UINT32)TPM_CAP_TPM_PROPERTIES, (UINT32)TPM_CAP_PCR_PROPERTIES,
(UINT32)TPM_CAP_ECC_CURVES, (UINT32)TPM_CAP_AUTH_POLICIES,
(UINT32)TPM_CAP_ACT},
{(UINT16)(TPML_ALG_PROPERTY_MARSHAL_REF),
(UINT16)(TPML_HANDLE_MARSHAL_REF),
(UINT16)(TPML_CCA_MARSHAL_REF),
(UINT16)(TPML_CC_MARSHAL_REF),
(UINT16)(TPML_CC_MARSHAL_REF),
(UINT16)(TPML_PCR_SELECTION_MARSHAL_REF),
(UINT16)(TPML_TAGGED_TPM_PROPERTY_MARSHAL_REF),
(UINT16)(TPML_TAGGED_PCR_PROPERTY_MARSHAL_REF),
(UINT16)(TPML_ECC_CURVE_MARSHAL_REF),
(UINT16)(TPML_TAGGED_POLICY_MARSHAL_REF),
(UINT16)(TPML_ACT_DATA_MARSHAL_REF)}
},
// TPMS_CAPABILITY_DATA_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPM_CAP_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CAPABILITY_DATA, capability)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_CAPABILITIES_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CAPABILITY_DATA, data))}},
// TPMS_CLOCK_INFO_DATA
{STRUCTURE_MTYPE, 4, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(EIGHT_BYTES),
UINT64_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CLOCK_INFO, clock)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
UINT32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CLOCK_INFO, resetCount)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
UINT32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CLOCK_INFO, restartCount)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(ONE_BYTES),
TPMI_YES_NO_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CLOCK_INFO, safe))}},
// TPMS_TIME_INFO_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(EIGHT_BYTES),
UINT64_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TIME_INFO, time)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMS_CLOCK_INFO_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TIME_INFO, clockInfo))}},
// TPMS_TIME_ATTEST_INFO_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMS_TIME_INFO_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TIME_ATTEST_INFO, time)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(EIGHT_BYTES),
UINT64_MARSHAL_REF,
(UINT16)(offsetof(TPMS_TIME_ATTEST_INFO, firmwareVersion))}},
// TPMS_CERTIFY_INFO_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NAME_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CERTIFY_INFO, name)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NAME_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CERTIFY_INFO, qualifiedName))}},
// TPMS_QUOTE_INFO_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPML_PCR_SELECTION_MARSHAL_REF,
(UINT16)(offsetof(TPMS_QUOTE_INFO, pcrSelect)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_QUOTE_INFO, pcrDigest))}},
// TPMS_COMMAND_AUDIT_INFO_DATA
{STRUCTURE_MTYPE, 4, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(EIGHT_BYTES),
UINT64_MARSHAL_REF,
(UINT16)(offsetof(TPMS_COMMAND_AUDIT_INFO, auditCounter)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPM_ALG_ID_MARSHAL_REF,
(UINT16)(offsetof(TPMS_COMMAND_AUDIT_INFO, digestAlg)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_COMMAND_AUDIT_INFO, auditDigest)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_COMMAND_AUDIT_INFO, commandDigest))}},
// TPMS_SESSION_AUDIT_INFO_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(ONE_BYTES),
TPMI_YES_NO_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SESSION_AUDIT_INFO, exclusiveSession)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SESSION_AUDIT_INFO, sessionDigest))}},
// TPMS_CREATION_INFO_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NAME_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_INFO, objectName)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_INFO, creationHash))}},
// TPMS_NV_CERTIFY_INFO_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NAME_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_CERTIFY_INFO, indexName)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
UINT16_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_CERTIFY_INFO, offset)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_MAX_NV_BUFFER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_CERTIFY_INFO, nvContents))}},
// TPMS_NV_DIGEST_CERTIFY_INFO_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NAME_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_DIGEST_CERTIFY_INFO, indexName)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_DIGEST_CERTIFY_INFO, nvDigest))}},
// TPMI_ST_ATTEST_DATA
{VALUES_MTYPE, TWO_BYTES, (UINT8)TPM_RC_VALUE, 1, 1,
{RANGE(TPM_ST_ATTEST_NV, TPM_ST_ATTEST_CREATION, UINT16),
TPM_ST_ATTEST_NV_DIGEST}},
// TPMU_ATTEST_DATA
{8, 0, (UINT16)(offsetof(TPMU_ATTEST_mst, marshalingTypes)),
{(UINT32)TPM_ST_ATTEST_CERTIFY, (UINT32)TPM_ST_ATTEST_CREATION,
(UINT32)TPM_ST_ATTEST_QUOTE, (UINT32)TPM_ST_ATTEST_COMMAND_AUDIT,
(UINT32)TPM_ST_ATTEST_SESSION_AUDIT, (UINT32)TPM_ST_ATTEST_TIME,
(UINT32)TPM_ST_ATTEST_NV, (UINT32)TPM_ST_ATTEST_NV_DIGEST},
{(UINT16)(TPMS_CERTIFY_INFO_MARSHAL_REF),
(UINT16)(TPMS_CREATION_INFO_MARSHAL_REF),
(UINT16)(TPMS_QUOTE_INFO_MARSHAL_REF),
(UINT16)(TPMS_COMMAND_AUDIT_INFO_MARSHAL_REF),
(UINT16)(TPMS_SESSION_AUDIT_INFO_MARSHAL_REF),
(UINT16)(TPMS_TIME_ATTEST_INFO_MARSHAL_REF),
(UINT16)(TPMS_NV_CERTIFY_INFO_MARSHAL_REF),
(UINT16)(TPMS_NV_DIGEST_CERTIFY_INFO_MARSHAL_REF)}
},
// TPMS_ATTEST_DATA
{STRUCTURE_MTYPE, 7, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPM_CONSTANTS32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ATTEST, magic)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ST_ATTEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ATTEST, type)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NAME_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ATTEST, qualifiedSigner)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DATA_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ATTEST, extraData)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMS_CLOCK_INFO_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ATTEST, clockInfo)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(EIGHT_BYTES),
UINT64_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ATTEST, firmwareVersion)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(1),
TPMU_ATTEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ATTEST, attested))}},
// TPM2B_ATTEST_DATA
{TPM2B_MTYPE, Type28_MARSHAL_REF},
// TPMS_AUTH_COMMAND_DATA
{STRUCTURE_MTYPE, 4, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMI_SH_AUTH_SESSION_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_AUTH_COMMAND, sessionHandle)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NONCE_MARSHAL_REF,
(UINT16)(offsetof(TPMS_AUTH_COMMAND, nonce)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(ONE_BYTES),
TPMA_SESSION_MARSHAL_REF,
(UINT16)(offsetof(TPMS_AUTH_COMMAND, sessionAttributes)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_AUTH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_AUTH_COMMAND, hmac))}},
// TPMS_AUTH_RESPONSE_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NONCE_MARSHAL_REF,
(UINT16)(offsetof(TPMS_AUTH_RESPONSE, nonce)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(ONE_BYTES),
TPMA_SESSION_MARSHAL_REF,
(UINT16)(offsetof(TPMS_AUTH_RESPONSE, sessionAttributes)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_AUTH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_AUTH_RESPONSE, hmac))}},
// TPMI_TDES_KEY_BITS_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_VALUE, 1,
{128*TDES_128}},
// TPMI_AES_KEY_BITS_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_VALUE, 3,
{192*AES_192, 128*AES_128, 256*AES_256}},
// TPMI_SM4_KEY_BITS_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_VALUE, 1,
{128*SM4_128}},
// TPMI_CAMELLIA_KEY_BITS_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_VALUE, 3,
{192*CAMELLIA_192, 128*CAMELLIA_128, 256*CAMELLIA_256}},
// TPMU_SYM_KEY_BITS_DATA
{6, 0, (UINT16)(offsetof(TPMU_SYM_KEY_BITS_mst, marshalingTypes)),
{(UINT32)TPM_ALG_TDES, (UINT32)TPM_ALG_AES, (UINT32)TPM_ALG_SM4,
(UINT32)TPM_ALG_CAMELLIA, (UINT32)TPM_ALG_XOR, (UINT32)TPM_ALG_NULL},
{(UINT16)(TPMI_TDES_KEY_BITS_MARSHAL_REF),
(UINT16)(TPMI_AES_KEY_BITS_MARSHAL_REF),
(UINT16)(TPMI_SM4_KEY_BITS_MARSHAL_REF),
(UINT16)(TPMI_CAMELLIA_KEY_BITS_MARSHAL_REF),
(UINT16)(TPMI_ALG_HASH_MARSHAL_REF),
(UINT16)(UINT0_MARSHAL_REF)}
},
// TPMU_SYM_MODE_DATA
{6, 0, (UINT16)(offsetof(TPMU_SYM_MODE_mst, marshalingTypes)),
{(UINT32)TPM_ALG_TDES, (UINT32)TPM_ALG_AES, (UINT32)TPM_ALG_SM4,
(UINT32)TPM_ALG_CAMELLIA, (UINT32)TPM_ALG_XOR, (UINT32)TPM_ALG_NULL},
{(UINT16)(TPMI_ALG_SYM_MODE_MARSHAL_REF|NULL_FLAG),
(UINT16)(TPMI_ALG_SYM_MODE_MARSHAL_REF|NULL_FLAG),
(UINT16)(TPMI_ALG_SYM_MODE_MARSHAL_REF|NULL_FLAG),
(UINT16)(TPMI_ALG_SYM_MODE_MARSHAL_REF|NULL_FLAG),
(UINT16)(UINT0_MARSHAL_REF),
(UINT16)(UINT0_MARSHAL_REF)}
},
// TPMT_SYM_DEF_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_SYM_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SYM_DEF, algorithm)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_SYM_KEY_BITS_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SYM_DEF, keyBits)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_SYM_MODE_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SYM_DEF, mode))}},
// TPMT_SYM_DEF_OBJECT_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_SYM_OBJECT_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SYM_DEF_OBJECT, algorithm)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_SYM_KEY_BITS_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SYM_DEF_OBJECT, keyBits)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_SYM_MODE_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SYM_DEF_OBJECT, mode))}},
// TPM2B_SYM_KEY_DATA
{TPM2B_MTYPE, Type29_MARSHAL_REF},
// TPMS_SYMCIPHER_PARMS_DATA
{STRUCTURE_MTYPE, 1, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_SYM_DEF_OBJECT_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SYMCIPHER_PARMS, sym))}},
// TPM2B_LABEL_DATA
{TPM2B_MTYPE, Type30_MARSHAL_REF},
// TPMS_DERIVE_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_LABEL_MARSHAL_REF,
(UINT16)(offsetof(TPMS_DERIVE, label)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_LABEL_MARSHAL_REF,
(UINT16)(offsetof(TPMS_DERIVE, context))}},
// TPM2B_DERIVE_DATA
{TPM2B_MTYPE, Type31_MARSHAL_REF},
// TPM2B_SENSITIVE_DATA_DATA
{TPM2B_MTYPE, Type32_MARSHAL_REF},
// TPMS_SENSITIVE_CREATE_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_AUTH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SENSITIVE_CREATE, userAuth)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_SENSITIVE_DATA_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SENSITIVE_CREATE, data))}},
// TPM2B_SENSITIVE_CREATE_DATA
{TPM2BS_MTYPE,
(UINT8)(offsetof(TPM2B_SENSITIVE_CREATE, sensitive))|SIZE_EQUAL,
UINT16_MARSHAL_REF,
TPMS_SENSITIVE_CREATE_MARSHAL_REF},
// TPMS_SCHEME_HASH_DATA
{STRUCTURE_MTYPE, 1, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SCHEME_HASH, hashAlg))}},
// TPMS_SCHEME_ECDAA_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SCHEME_ECDAA, hashAlg)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
UINT16_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SCHEME_ECDAA, count))}},
// TPMI_ALG_KEYEDHASH_SCHEME_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_VALUE,
{TPM_ALG_NULL,
RANGE(5, 10, UINT16),
(UINT32)((ALG_HMAC << 0)|(ALG_XOR << 5))}},
// TPMS_SCHEME_XOR_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SCHEME_XOR, hashAlg)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_KDF_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_SCHEME_XOR, kdf))}},
// TPMU_SCHEME_KEYEDHASH_DATA
{3, 0, (UINT16)(offsetof(TPMU_SCHEME_KEYEDHASH_mst, marshalingTypes)),
{(UINT32)TPM_ALG_HMAC, (UINT32)TPM_ALG_XOR, (UINT32)TPM_ALG_NULL},
{(UINT16)(TPMS_SCHEME_HMAC_MARSHAL_REF),
(UINT16)(TPMS_SCHEME_XOR_MARSHAL_REF),
(UINT16)(UINT0_MARSHAL_REF)}
},
// TPMT_KEYEDHASH_SCHEME_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_KEYEDHASH_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_KEYEDHASH_SCHEME, scheme)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_SCHEME_KEYEDHASH_MARSHAL_REF,
(UINT16)(offsetof(TPMT_KEYEDHASH_SCHEME, details))}},
// TPMU_SIG_SCHEME_DATA
{8, 0, (UINT16)(offsetof(TPMU_SIG_SCHEME_mst, marshalingTypes)),
{(UINT32)TPM_ALG_ECDAA, (UINT32)TPM_ALG_RSASSA,
(UINT32)TPM_ALG_RSAPSS, (UINT32)TPM_ALG_ECDSA,
(UINT32)TPM_ALG_SM2, (UINT32)TPM_ALG_ECSCHNORR,
(UINT32)TPM_ALG_HMAC, (UINT32)TPM_ALG_NULL},
{(UINT16)(TPMS_SIG_SCHEME_ECDAA_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_RSASSA_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_RSAPSS_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_ECDSA_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_SM2_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_ECSCHNORR_MARSHAL_REF),
(UINT16)(TPMS_SCHEME_HMAC_MARSHAL_REF),
(UINT16)(UINT0_MARSHAL_REF)}
},
// TPMT_SIG_SCHEME_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_SIG_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SIG_SCHEME, scheme)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_SIG_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SIG_SCHEME, details))}},
// TPMU_KDF_SCHEME_DATA
{5, 0, (UINT16)(offsetof(TPMU_KDF_SCHEME_mst, marshalingTypes)),
{(UINT32)TPM_ALG_MGF1, (UINT32)TPM_ALG_KDF1_SP800_56A,
(UINT32)TPM_ALG_KDF2, (UINT32)TPM_ALG_KDF1_SP800_108,
(UINT32)TPM_ALG_NULL},
{(UINT16)(TPMS_KDF_SCHEME_MGF1_MARSHAL_REF),
(UINT16)(TPMS_KDF_SCHEME_KDF1_SP800_56A_MARSHAL_REF),
(UINT16)(TPMS_KDF_SCHEME_KDF2_MARSHAL_REF),
(UINT16)(TPMS_KDF_SCHEME_KDF1_SP800_108_MARSHAL_REF),
(UINT16)(UINT0_MARSHAL_REF)}
},
// TPMT_KDF_SCHEME_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_KDF_MARSHAL_REF,
(UINT16)(offsetof(TPMT_KDF_SCHEME, scheme)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_KDF_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_KDF_SCHEME, details))}},
// TPMI_ALG_ASYM_SCHEME_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_VALUE,
{TPM_ALG_NULL,
RANGE(20, 29, UINT16),
(UINT32)((ALG_RSASSA << 0) | (ALG_RSAES << 1) | (ALG_RSAPSS << 2) |
(ALG_OAEP << 3) | (ALG_ECDSA << 4) | (ALG_ECDH << 5) |
(ALG_ECDAA << 6) | (ALG_SM2 << 7) | (ALG_ECSCHNORR << 8) |
(ALG_ECMQV << 9))}},
// TPMU_ASYM_SCHEME_DATA
{11, 0, (UINT16)(offsetof(TPMU_ASYM_SCHEME_mst, marshalingTypes)),
{(UINT32)TPM_ALG_ECDH, (UINT32)TPM_ALG_ECMQV,
(UINT32)TPM_ALG_ECDAA, (UINT32)TPM_ALG_RSASSA,
(UINT32)TPM_ALG_RSAPSS, (UINT32)TPM_ALG_ECDSA,
(UINT32)TPM_ALG_SM2, (UINT32)TPM_ALG_ECSCHNORR,
(UINT32)TPM_ALG_RSAES, (UINT32)TPM_ALG_OAEP,
(UINT32)TPM_ALG_NULL},
{(UINT16)(TPMS_KEY_SCHEME_ECDH_MARSHAL_REF),
(UINT16)(TPMS_KEY_SCHEME_ECMQV_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_ECDAA_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_RSASSA_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_RSAPSS_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_ECDSA_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_SM2_MARSHAL_REF),
(UINT16)(TPMS_SIG_SCHEME_ECSCHNORR_MARSHAL_REF),
(UINT16)(TPMS_ENC_SCHEME_RSAES_MARSHAL_REF),
(UINT16)(TPMS_ENC_SCHEME_OAEP_MARSHAL_REF),
(UINT16)(UINT0_MARSHAL_REF)}
},
// TPMI_ALG_RSA_SCHEME_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_VALUE,
{TPM_ALG_NULL,
RANGE(20, 23, UINT16),
(UINT32)((ALG_RSASSA << 0)|(ALG_RSAES << 1)|(ALG_RSAPSS << 2)|(ALG_OAEP << 3))}},
// TPMT_RSA_SCHEME_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_RSA_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_RSA_SCHEME, scheme)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_ASYM_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_RSA_SCHEME, details))}},
// TPMI_ALG_RSA_DECRYPT_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_VALUE,
{TPM_ALG_NULL,
RANGE(21, 23, UINT16),
(UINT32)((ALG_RSAES << 0)|(ALG_OAEP << 2))}},
// TPMT_RSA_DECRYPT_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_RSA_DECRYPT_MARSHAL_REF,
(UINT16)(offsetof(TPMT_RSA_DECRYPT, scheme)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_ASYM_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_RSA_DECRYPT, details))}},
// TPM2B_PUBLIC_KEY_RSA_DATA
{TPM2B_MTYPE, Type33_MARSHAL_REF},
// TPMI_RSA_KEY_BITS_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_VALUE, 3,
{3072*RSA_3072, 1024*RSA_1024, 2048*RSA_2048}},
// TPM2B_PRIVATE_KEY_RSA_DATA
{TPM2B_MTYPE, Type34_MARSHAL_REF},
// TPM2B_ECC_PARAMETER_DATA
{TPM2B_MTYPE, Type35_MARSHAL_REF},
// TPMS_ECC_POINT_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ECC_POINT, x)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ECC_POINT, y))}},
// TPM2B_ECC_POINT_DATA
{TPM2BS_MTYPE,
(UINT8)(offsetof(TPM2B_ECC_POINT, point))|SIZE_EQUAL,
UINT16_MARSHAL_REF,
TPMS_ECC_POINT_MARSHAL_REF},
// TPMI_ALG_ECC_SCHEME_DATA
{MIN_MAX_MTYPE, TWO_BYTES|TAKES_NULL|HAS_BITS, (UINT8)TPM_RC_SCHEME,
{TPM_ALG_NULL,
RANGE(24, 29, UINT16),
(UINT32)((ALG_ECDSA << 0) | (ALG_ECDH << 1) | (ALG_ECDAA << 2) |
(ALG_SM2 << 3) | (ALG_ECSCHNORR << 4) | (ALG_ECMQV << 5))}},
// TPMI_ECC_CURVE_DATA
{MIN_MAX_MTYPE, TWO_BYTES|HAS_BITS, (UINT8)TPM_RC_CURVE,
{RANGE(1, 32, UINT16),
(UINT32)((ECC_NIST_P192 << 0) | (ECC_NIST_P224 << 1) | (ECC_NIST_P256 << 2) |
(ECC_NIST_P384 << 3) | (ECC_NIST_P521 << 4) | (ECC_BN_P256 << 15) |
(ECC_BN_P638 << 16) | (ECC_SM2_P256 << 31))}},
// TPMT_ECC_SCHEME_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_ECC_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_ECC_SCHEME, scheme)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_ASYM_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_ECC_SCHEME, details))}},
// TPMS_ALGORITHM_DETAIL_ECC_DATA
{STRUCTURE_MTYPE, 11, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPM_ECC_CURVE_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, curveID)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
UINT16_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, keySize)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_KDF_SCHEME_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, kdf)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_ECC_SCHEME_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, sign)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, p)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, a)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, b)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, gX)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, gY)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, n)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ALGORITHM_DETAIL_ECC, h))}},
// TPMS_SIGNATURE_RSA_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SIGNATURE_RSA, hash)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_PUBLIC_KEY_RSA_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SIGNATURE_RSA, sig))}},
// TPMS_SIGNATURE_ECC_DATA
{STRUCTURE_MTYPE, 3, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SIGNATURE_ECC, hash)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SIGNATURE_ECC, signatureR)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_ECC_PARAMETER_MARSHAL_REF,
(UINT16)(offsetof(TPMS_SIGNATURE_ECC, signatureS))}},
// TPMU_SIGNATURE_DATA
{8, 0, (UINT16)(offsetof(TPMU_SIGNATURE_mst, marshalingTypes)),
{(UINT32)TPM_ALG_ECDAA, (UINT32)TPM_ALG_RSASSA,
(UINT32)TPM_ALG_RSAPSS, (UINT32)TPM_ALG_ECDSA,
(UINT32)TPM_ALG_SM2, (UINT32)TPM_ALG_ECSCHNORR,
(UINT32)TPM_ALG_HMAC, (UINT32)TPM_ALG_NULL},
{(UINT16)(TPMS_SIGNATURE_ECDAA_MARSHAL_REF),
(UINT16)(TPMS_SIGNATURE_RSASSA_MARSHAL_REF),
(UINT16)(TPMS_SIGNATURE_RSAPSS_MARSHAL_REF),
(UINT16)(TPMS_SIGNATURE_ECDSA_MARSHAL_REF),
(UINT16)(TPMS_SIGNATURE_SM2_MARSHAL_REF),
(UINT16)(TPMS_SIGNATURE_ECSCHNORR_MARSHAL_REF),
(UINT16)(TPMT_HA_MARSHAL_REF),
(UINT16)(UINT0_MARSHAL_REF)}
},
// TPMT_SIGNATURE_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_SIG_SCHEME_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SIGNATURE, sigAlg)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_SIGNATURE_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SIGNATURE, signature))}},
// TPMU_ENCRYPTED_SECRET_DATA
{4, IS_ARRAY_UNION, (UINT16)(offsetof(TPMU_ENCRYPTED_SECRET_mst, marshalingTypes)),
{(UINT32)TPM_ALG_ECC, (UINT32)TPM_ALG_RSA,
(UINT32)TPM_ALG_SYMCIPHER, (UINT32)TPM_ALG_KEYEDHASH},
{(UINT16)(sizeof(TPMS_ECC_POINT)), (UINT16)(MAX_RSA_KEY_BYTES),
(UINT16)(sizeof(TPM2B_DIGEST)), (UINT16)(sizeof(TPM2B_DIGEST))}
},
// TPM2B_ENCRYPTED_SECRET_DATA
{TPM2B_MTYPE, Type36_MARSHAL_REF},
// TPMI_ALG_PUBLIC_DATA
{MIN_MAX_MTYPE, TWO_BYTES|HAS_BITS, (UINT8)TPM_RC_TYPE,
{RANGE(1, 37, UINT16),
(UINT32)((ALG_RSA << 0)|(ALG_KEYEDHASH << 7)),
(UINT32)((ALG_ECC << 2)|(ALG_SYMCIPHER << 4))}},
// TPMU_PUBLIC_ID_DATA
{4, 0, (UINT16)(offsetof(TPMU_PUBLIC_ID_mst, marshalingTypes)),
{(UINT32)TPM_ALG_KEYEDHASH, (UINT32)TPM_ALG_SYMCIPHER,
(UINT32)TPM_ALG_RSA, (UINT32)TPM_ALG_ECC},
{(UINT16)(TPM2B_DIGEST_MARSHAL_REF),
(UINT16)(TPM2B_DIGEST_MARSHAL_REF),
(UINT16)(TPM2B_PUBLIC_KEY_RSA_MARSHAL_REF),
(UINT16)(TPMS_ECC_POINT_MARSHAL_REF)}
},
// TPMS_KEYEDHASH_PARMS_DATA
{STRUCTURE_MTYPE, 1, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_KEYEDHASH_SCHEME_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_KEYEDHASH_PARMS, scheme))}},
// TPMS_RSA_PARMS_DATA
{STRUCTURE_MTYPE, 4, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_SYM_DEF_OBJECT_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_RSA_PARMS, symmetric)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_RSA_SCHEME_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_RSA_PARMS, scheme)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_RSA_KEY_BITS_MARSHAL_REF,
(UINT16)(offsetof(TPMS_RSA_PARMS, keyBits)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
UINT32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_RSA_PARMS, exponent))}},
// TPMS_ECC_PARMS_DATA
{STRUCTURE_MTYPE, 4, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_SYM_DEF_OBJECT_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_ECC_PARMS, symmetric)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_ECC_SCHEME_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_ECC_PARMS, scheme)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ECC_CURVE_MARSHAL_REF,
(UINT16)(offsetof(TPMS_ECC_PARMS, curveID)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPMT_KDF_SCHEME_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_ECC_PARMS, kdf))}},
// TPMU_PUBLIC_PARMS_DATA
{4, 0, (UINT16)(offsetof(TPMU_PUBLIC_PARMS_mst, marshalingTypes)),
{(UINT32)TPM_ALG_KEYEDHASH, (UINT32)TPM_ALG_SYMCIPHER,
(UINT32)TPM_ALG_RSA, (UINT32)TPM_ALG_ECC},
{(UINT16)(TPMS_KEYEDHASH_PARMS_MARSHAL_REF),
(UINT16)(TPMS_SYMCIPHER_PARMS_MARSHAL_REF),
(UINT16)(TPMS_RSA_PARMS_MARSHAL_REF),
(UINT16)(TPMS_ECC_PARMS_MARSHAL_REF)}
},
// TPMT_PUBLIC_PARMS_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_PUBLIC_MARSHAL_REF,
(UINT16)(offsetof(TPMT_PUBLIC_PARMS, type)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_PUBLIC_PARMS_MARSHAL_REF,
(UINT16)(offsetof(TPMT_PUBLIC_PARMS, parameters))}},
// TPMT_PUBLIC_DATA
{STRUCTURE_MTYPE, 6, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_PUBLIC_MARSHAL_REF,
(UINT16)(offsetof(TPMT_PUBLIC, type)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES)|ELEMENT_PROPAGATE,
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMT_PUBLIC, nameAlg)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMA_OBJECT_MARSHAL_REF,
(UINT16)(offsetof(TPMT_PUBLIC, objectAttributes)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMT_PUBLIC, authPolicy)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_PUBLIC_PARMS_MARSHAL_REF,
(UINT16)(offsetof(TPMT_PUBLIC, parameters)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_PUBLIC_ID_MARSHAL_REF,
(UINT16)(offsetof(TPMT_PUBLIC, unique))}},
// TPM2B_PUBLIC_DATA
{TPM2BS_MTYPE,
(UINT8)(offsetof(TPM2B_PUBLIC, publicArea))|SIZE_EQUAL|ELEMENT_PROPAGATE,
UINT16_MARSHAL_REF,
TPMT_PUBLIC_MARSHAL_REF},
// TPM2B_TEMPLATE_DATA
{TPM2B_MTYPE, Type37_MARSHAL_REF},
// TPM2B_PRIVATE_VENDOR_SPECIFIC_DATA
{TPM2B_MTYPE, Type38_MARSHAL_REF},
// TPMU_SENSITIVE_COMPOSITE_DATA
{4, 0, (UINT16)(offsetof(TPMU_SENSITIVE_COMPOSITE_mst, marshalingTypes)),
{(UINT32)TPM_ALG_RSA, (UINT32)TPM_ALG_ECC,
(UINT32)TPM_ALG_KEYEDHASH, (UINT32)TPM_ALG_SYMCIPHER},
{(UINT16)(TPM2B_PRIVATE_KEY_RSA_MARSHAL_REF),
(UINT16)(TPM2B_ECC_PARAMETER_MARSHAL_REF),
(UINT16)(TPM2B_SENSITIVE_DATA_MARSHAL_REF),
(UINT16)(TPM2B_SYM_KEY_MARSHAL_REF)}
},
// TPMT_SENSITIVE_DATA
{STRUCTURE_MTYPE, 4, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_PUBLIC_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SENSITIVE, sensitiveType)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_AUTH_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SENSITIVE, authValue)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SENSITIVE, seedValue)),
SET_ELEMENT_TYPE(UNION_STYPE)|SET_ELEMENT_NUMBER(0),
TPMU_SENSITIVE_COMPOSITE_MARSHAL_REF,
(UINT16)(offsetof(TPMT_SENSITIVE, sensitive))}},
// TPM2B_SENSITIVE_DATA
{TPM2BS_MTYPE,
(UINT8)(offsetof(TPM2B_SENSITIVE, sensitiveArea)),
UINT16_MARSHAL_REF,
TPMT_SENSITIVE_MARSHAL_REF},
// TPM2B_PRIVATE_DATA
{TPM2B_MTYPE, Type39_MARSHAL_REF},
// TPM2B_ID_OBJECT_DATA
{TPM2B_MTYPE, Type40_MARSHAL_REF},
// TPMS_NV_PIN_COUNTER_PARAMETERS_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
UINT32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_PIN_COUNTER_PARAMETERS, pinCount)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
UINT32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_PIN_COUNTER_PARAMETERS, pinLimit))}},
// TPMA_NV_DATA
{ATTRIBUTES_MTYPE, FOUR_BYTES, 0x01F00300},
// TPMS_NV_PUBLIC_DATA
{STRUCTURE_MTYPE, 5, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMI_RH_NV_INDEX_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_PUBLIC, nvIndex)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPMI_ALG_HASH_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_PUBLIC, nameAlg)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMA_NV_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_PUBLIC, attributes)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_PUBLIC, authPolicy)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
Type41_MARSHAL_REF,
(UINT16)(offsetof(TPMS_NV_PUBLIC, dataSize))}},
// TPM2B_NV_PUBLIC_DATA
{TPM2BS_MTYPE,
(UINT8)(offsetof(TPM2B_NV_PUBLIC, nvPublic))|SIZE_EQUAL,
UINT16_MARSHAL_REF,
TPMS_NV_PUBLIC_MARSHAL_REF},
// TPM2B_CONTEXT_SENSITIVE_DATA
{TPM2B_MTYPE, Type42_MARSHAL_REF},
// TPMS_CONTEXT_DATA_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CONTEXT_DATA, integrity)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_CONTEXT_SENSITIVE_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CONTEXT_DATA, encrypted))}},
// TPM2B_CONTEXT_DATA_DATA
{TPM2B_MTYPE, Type43_MARSHAL_REF},
// TPMS_CONTEXT_DATA
{STRUCTURE_MTYPE, 4, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(EIGHT_BYTES),
UINT64_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CONTEXT, sequence)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMI_DH_SAVED_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CONTEXT, savedHandle)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPMI_RH_HIERARCHY_MARSHAL_REF|NULL_FLAG,
(UINT16)(offsetof(TPMS_CONTEXT, hierarchy)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_CONTEXT_DATA_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CONTEXT, contextBlob))}},
// TPMS_CREATION_DATA_DATA
{STRUCTURE_MTYPE, 7, {
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPML_PCR_SELECTION_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_DATA, pcrSelect)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DIGEST_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_DATA, pcrDigest)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(ONE_BYTES),
TPMA_LOCALITY_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_DATA, locality)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(TWO_BYTES),
TPM_ALG_ID_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_DATA, parentNameAlg)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NAME_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_DATA, parentName)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_NAME_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_DATA, parentQualifiedName)),
SET_ELEMENT_TYPE(SIMPLE_STYPE),
TPM2B_DATA_MARSHAL_REF,
(UINT16)(offsetof(TPMS_CREATION_DATA, outsideInfo))}},
// TPM2B_CREATION_DATA_DATA
{TPM2BS_MTYPE,
(UINT8)(offsetof(TPM2B_CREATION_DATA, creationData))|SIZE_EQUAL,
UINT16_MARSHAL_REF,
TPMS_CREATION_DATA_MARSHAL_REF},
// TPM_AT_DATA
{TABLE_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_VALUE, 4,
{TPM_AT_ANY, TPM_AT_ERROR, TPM_AT_PV1, TPM_AT_VEND}},
// TPMS_AC_OUTPUT_DATA
{STRUCTURE_MTYPE, 2, {
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
TPM_AT_MARSHAL_REF,
(UINT16)(offsetof(TPMS_AC_OUTPUT, tag)),
SET_ELEMENT_TYPE(SIMPLE_STYPE)|SET_ELEMENT_SIZE(FOUR_BYTES),
UINT32_MARSHAL_REF,
(UINT16)(offsetof(TPMS_AC_OUTPUT, data))}},
// TPML_AC_CAPABILITIES_DATA
{LIST_MTYPE,
(UINT8)(offsetof(TPML_AC_CAPABILITIES, acCapabilities)),
Type44_MARSHAL_REF,
TPMS_AC_OUTPUT_ARRAY_MARSHAL_INDEX},
// Type00_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMU_HA), UINT16)}},
// Type01_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMT_HA), UINT16)}},
// Type02_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, 1024, UINT16)}},
// Type03_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_DIGEST_BUFFER, UINT16)}},
// Type04_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_NV_BUFFER_SIZE, UINT16)}},
// Type05_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(UINT64), UINT16)}},
// Type06_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_SYM_BLOCK_SIZE, UINT16)}},
// Type07_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMU_NAME), UINT16)}},
// Type08_DATA
{MIN_MAX_MTYPE, ONE_BYTES, (UINT8)TPM_RC_VALUE,
{RANGE(PCR_SELECT_MIN, PCR_SELECT_MAX, UINT8)}},
// Type10_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_TAG, 1,
{TPM_ST_CREATION}},
// Type11_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_TAG, 1,
{TPM_ST_VERIFIED}},
// Type12_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_TAG, 2,
{TPM_ST_AUTH_SECRET, TPM_ST_AUTH_SIGNED}},
// Type13_DATA
{TABLE_MTYPE, TWO_BYTES, (UINT8)TPM_RC_TAG, 1,
{TPM_ST_HASHCHECK}},
// Type15_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_CAP_CC, UINT32)}},
// Type17_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_ALG_LIST_SIZE, UINT32)}},
// Type18_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_CAP_HANDLES, UINT32)}},
// Type19_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(2, 8, UINT32)}},
// Type20_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, HASH_COUNT, UINT32)}},
// Type22_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_CAP_ALGS, UINT32)}},
// Type23_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_TPM_PROPERTIES, UINT32)}},
// Type24_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_PCR_PROPERTIES, UINT32)}},
// Type25_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_ECC_CURVES, UINT32)}},
// Type26_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_TAGGED_POLICIES, UINT32)}},
// Type27_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_ACT_DATA, UINT32)}},
// Type28_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMS_ATTEST), UINT16)}},
// Type29_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_SYM_KEY_BYTES, UINT16)}},
// Type30_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, LABEL_MAX_BUFFER, UINT16)}},
// Type31_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMS_DERIVE), UINT16)}},
// Type32_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMU_SENSITIVE_CREATE), UINT16)}},
// Type33_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_RSA_KEY_BYTES, UINT16)}},
// Type34_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, RSA_PRIVATE_SIZE, UINT16)}},
// Type35_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_ECC_KEY_BYTES, UINT16)}},
// Type36_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMU_ENCRYPTED_SECRET), UINT16)}},
// Type37_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMT_PUBLIC), UINT16)}},
// Type38_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, PRIVATE_VENDOR_SPECIFIC_BYTES, UINT16)}},
// Type39_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(_PRIVATE), UINT16)}},
// Type40_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMS_ID_OBJECT), UINT16)}},
// Type41_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_NV_INDEX_SIZE, UINT16)}},
// Type42_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_CONTEXT_SIZE, UINT16)}},
// Type43_DATA
{MIN_MAX_MTYPE, TWO_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, sizeof(TPMS_CONTEXT_DATA), UINT16)}},
// Type44_DATA
{MIN_MAX_MTYPE, FOUR_BYTES, (UINT8)TPM_RC_SIZE,
{RANGE(0, MAX_AC_CAPABILITIES, UINT32)}}
};
#endif // TABLE_DRIVEN_MARSHAL