blob: e3c72ab42c6eb46884d778c5a0970d5940bfa6c5 [file] [log] [blame]
// Copyright 2015 The Chromium OS Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// THIS CODE IS GENERATED - DO NOT MODIFY!
#include "tpm_generated.h"
UINT16 uint8_t_Marshal(uint8_t* source, BYTE** buffer, INT32* size) {
uint8_t value_net = *source;
if (!size || *size < sizeof(uint8_t)) {
return 0; // Nothing has been marshaled.
}
switch (sizeof(uint8_t)) {
case 2:
value_net = htobe16(*source);
break;
case 4:
value_net = htobe32(*source);
break;
case 8:
value_net = htobe64(*source);
break;
default:
break;
}
memcpy(*buffer, &value_net, sizeof(uint8_t));
*buffer += sizeof(uint8_t);
*size -= sizeof(uint8_t);
return sizeof(uint8_t);
}
TPM_RC uint8_t_Unmarshal(uint8_t* target, BYTE** buffer, INT32* size) {
uint8_t value_net = 0;
if (!size || *size < sizeof(uint8_t)) {
return TPM_RC_INSUFFICIENT;
}
memcpy(&value_net, *buffer, sizeof(uint8_t));
switch (sizeof(uint8_t)) {
case 2:
*target = be16toh(value_net);
break;
case 4:
*target = be32toh(value_net);
break;
case 8:
*target = be64toh(value_net);
break;
default:
*target = value_net;
}
*buffer += sizeof(uint8_t);
*size -= sizeof(uint8_t);
return TPM_RC_SUCCESS;
}
UINT16 int8_t_Marshal(int8_t* source, BYTE** buffer, INT32* size) {
int8_t value_net = *source;
if (!size || *size < sizeof(int8_t)) {
return 0; // Nothing has been marshaled.
}
switch (sizeof(int8_t)) {
case 2:
value_net = htobe16(*source);
break;
case 4:
value_net = htobe32(*source);
break;
case 8:
value_net = htobe64(*source);
break;
default:
break;
}
memcpy(*buffer, &value_net, sizeof(int8_t));
*buffer += sizeof(int8_t);
*size -= sizeof(int8_t);
return sizeof(int8_t);
}
TPM_RC int8_t_Unmarshal(int8_t* target, BYTE** buffer, INT32* size) {
int8_t value_net = 0;
if (!size || *size < sizeof(int8_t)) {
return TPM_RC_INSUFFICIENT;
}
memcpy(&value_net, *buffer, sizeof(int8_t));
switch (sizeof(int8_t)) {
case 2:
*target = be16toh(value_net);
break;
case 4:
*target = be32toh(value_net);
break;
case 8:
*target = be64toh(value_net);
break;
default:
*target = value_net;
}
*buffer += sizeof(int8_t);
*size -= sizeof(int8_t);
return TPM_RC_SUCCESS;
}
UINT16 uint16_t_Marshal(uint16_t* source, BYTE** buffer, INT32* size) {
uint16_t value_net = *source;
if (!size || *size < sizeof(uint16_t)) {
return 0; // Nothing has been marshaled.
}
switch (sizeof(uint16_t)) {
case 2:
value_net = htobe16(*source);
break;
case 4:
value_net = htobe32(*source);
break;
case 8:
value_net = htobe64(*source);
break;
default:
break;
}
memcpy(*buffer, &value_net, sizeof(uint16_t));
*buffer += sizeof(uint16_t);
*size -= sizeof(uint16_t);
return sizeof(uint16_t);
}
TPM_RC uint16_t_Unmarshal(uint16_t* target, BYTE** buffer, INT32* size) {
uint16_t value_net = 0;
if (!size || *size < sizeof(uint16_t)) {
return TPM_RC_INSUFFICIENT;
}
memcpy(&value_net, *buffer, sizeof(uint16_t));
switch (sizeof(uint16_t)) {
case 2:
*target = be16toh(value_net);
break;
case 4:
*target = be32toh(value_net);
break;
case 8:
*target = be64toh(value_net);
break;
default:
*target = value_net;
}
*buffer += sizeof(uint16_t);
*size -= sizeof(uint16_t);
return TPM_RC_SUCCESS;
}
UINT16 int16_t_Marshal(int16_t* source, BYTE** buffer, INT32* size) {
int16_t value_net = *source;
if (!size || *size < sizeof(int16_t)) {
return 0; // Nothing has been marshaled.
}
switch (sizeof(int16_t)) {
case 2:
value_net = htobe16(*source);
break;
case 4:
value_net = htobe32(*source);
break;
case 8:
value_net = htobe64(*source);
break;
default:
break;
}
memcpy(*buffer, &value_net, sizeof(int16_t));
*buffer += sizeof(int16_t);
*size -= sizeof(int16_t);
return sizeof(int16_t);
}
TPM_RC int16_t_Unmarshal(int16_t* target, BYTE** buffer, INT32* size) {
int16_t value_net = 0;
if (!size || *size < sizeof(int16_t)) {
return TPM_RC_INSUFFICIENT;
}
memcpy(&value_net, *buffer, sizeof(int16_t));
switch (sizeof(int16_t)) {
case 2:
*target = be16toh(value_net);
break;
case 4:
*target = be32toh(value_net);
break;
case 8:
*target = be64toh(value_net);
break;
default:
*target = value_net;
}
*buffer += sizeof(int16_t);
*size -= sizeof(int16_t);
return TPM_RC_SUCCESS;
}
UINT16 uint32_t_Marshal(uint32_t* source, BYTE** buffer, INT32* size) {
uint32_t value_net = *source;
if (!size || *size < sizeof(uint32_t)) {
return 0; // Nothing has been marshaled.
}
switch (sizeof(uint32_t)) {
case 2:
value_net = htobe16(*source);
break;
case 4:
value_net = htobe32(*source);
break;
case 8:
value_net = htobe64(*source);
break;
default:
break;
}
memcpy(*buffer, &value_net, sizeof(uint32_t));
*buffer += sizeof(uint32_t);
*size -= sizeof(uint32_t);
return sizeof(uint32_t);
}
TPM_RC uint32_t_Unmarshal(uint32_t* target, BYTE** buffer, INT32* size) {
uint32_t value_net = 0;
if (!size || *size < sizeof(uint32_t)) {
return TPM_RC_INSUFFICIENT;
}
memcpy(&value_net, *buffer, sizeof(uint32_t));
switch (sizeof(uint32_t)) {
case 2:
*target = be16toh(value_net);
break;
case 4:
*target = be32toh(value_net);
break;
case 8:
*target = be64toh(value_net);
break;
default:
*target = value_net;
}
*buffer += sizeof(uint32_t);
*size -= sizeof(uint32_t);
return TPM_RC_SUCCESS;
}
UINT16 int32_t_Marshal(int32_t* source, BYTE** buffer, INT32* size) {
int32_t value_net = *source;
if (!size || *size < sizeof(int32_t)) {
return 0; // Nothing has been marshaled.
}
switch (sizeof(int32_t)) {
case 2:
value_net = htobe16(*source);
break;
case 4:
value_net = htobe32(*source);
break;
case 8:
value_net = htobe64(*source);
break;
default:
break;
}
memcpy(*buffer, &value_net, sizeof(int32_t));
*buffer += sizeof(int32_t);
*size -= sizeof(int32_t);
return sizeof(int32_t);
}
TPM_RC int32_t_Unmarshal(int32_t* target, BYTE** buffer, INT32* size) {
int32_t value_net = 0;
if (!size || *size < sizeof(int32_t)) {
return TPM_RC_INSUFFICIENT;
}
memcpy(&value_net, *buffer, sizeof(int32_t));
switch (sizeof(int32_t)) {
case 2:
*target = be16toh(value_net);
break;
case 4:
*target = be32toh(value_net);
break;
case 8:
*target = be64toh(value_net);
break;
default:
*target = value_net;
}
*buffer += sizeof(int32_t);
*size -= sizeof(int32_t);
return TPM_RC_SUCCESS;
}
UINT16 uint64_t_Marshal(uint64_t* source, BYTE** buffer, INT32* size) {
uint64_t value_net = *source;
if (!size || *size < sizeof(uint64_t)) {
return 0; // Nothing has been marshaled.
}
switch (sizeof(uint64_t)) {
case 2:
value_net = htobe16(*source);
break;
case 4:
value_net = htobe32(*source);
break;
case 8:
value_net = htobe64(*source);
break;
default:
break;
}
memcpy(*buffer, &value_net, sizeof(uint64_t));
*buffer += sizeof(uint64_t);
*size -= sizeof(uint64_t);
return sizeof(uint64_t);
}
TPM_RC uint64_t_Unmarshal(uint64_t* target, BYTE** buffer, INT32* size) {
uint64_t value_net = 0;
if (!size || *size < sizeof(uint64_t)) {
return TPM_RC_INSUFFICIENT;
}
memcpy(&value_net, *buffer, sizeof(uint64_t));
switch (sizeof(uint64_t)) {
case 2:
*target = be16toh(value_net);
break;
case 4:
*target = be32toh(value_net);
break;
case 8:
*target = be64toh(value_net);
break;
default:
*target = value_net;
}
*buffer += sizeof(uint64_t);
*size -= sizeof(uint64_t);
return TPM_RC_SUCCESS;
}
UINT16 int64_t_Marshal(int64_t* source, BYTE** buffer, INT32* size) {
int64_t value_net = *source;
if (!size || *size < sizeof(int64_t)) {
return 0; // Nothing has been marshaled.
}
switch (sizeof(int64_t)) {
case 2:
value_net = htobe16(*source);
break;
case 4:
value_net = htobe32(*source);
break;
case 8:
value_net = htobe64(*source);
break;
default:
break;
}
memcpy(*buffer, &value_net, sizeof(int64_t));
*buffer += sizeof(int64_t);
*size -= sizeof(int64_t);
return sizeof(int64_t);
}
TPM_RC int64_t_Unmarshal(int64_t* target, BYTE** buffer, INT32* size) {
int64_t value_net = 0;
if (!size || *size < sizeof(int64_t)) {
return TPM_RC_INSUFFICIENT;
}
memcpy(&value_net, *buffer, sizeof(int64_t));
switch (sizeof(int64_t)) {
case 2:
*target = be16toh(value_net);
break;
case 4:
*target = be32toh(value_net);
break;
case 8:
*target = be64toh(value_net);
break;
default:
*target = value_net;
}
*buffer += sizeof(int64_t);
*size -= sizeof(int64_t);
return TPM_RC_SUCCESS;
}
UINT16 BYTE_Marshal(BYTE* source, BYTE** buffer, INT32* size) {
return uint8_t_Marshal(source, buffer, size);
}
TPM_RC BYTE_Unmarshal(BYTE* target, BYTE** buffer, INT32* size) {
return uint8_t_Unmarshal(target, buffer, size);
}
UINT16 INT16_Marshal(INT16* source, BYTE** buffer, INT32* size) {
return int16_t_Marshal(source, buffer, size);
}
TPM_RC INT16_Unmarshal(INT16* target, BYTE** buffer, INT32* size) {
return int16_t_Unmarshal(target, buffer, size);
}
UINT16 INT32_Marshal(INT32* source, BYTE** buffer, INT32* size) {
return int32_t_Marshal(source, buffer, size);
}
TPM_RC INT32_Unmarshal(INT32* target, BYTE** buffer, INT32* size) {
return int32_t_Unmarshal(target, buffer, size);
}
UINT16 INT64_Marshal(INT64* source, BYTE** buffer, INT32* size) {
return int64_t_Marshal(source, buffer, size);
}
TPM_RC INT64_Unmarshal(INT64* target, BYTE** buffer, INT32* size) {
return int64_t_Unmarshal(target, buffer, size);
}
UINT16 INT8_Marshal(INT8* source, BYTE** buffer, INT32* size) {
return int8_t_Marshal(source, buffer, size);
}
TPM_RC INT8_Unmarshal(INT8* target, BYTE** buffer, INT32* size) {
return int8_t_Unmarshal(target, buffer, size);
}
UINT16 UINT16_Marshal(UINT16* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC UINT16_Unmarshal(UINT16* target, BYTE** buffer, INT32* size) {
return uint16_t_Unmarshal(target, buffer, size);
}
UINT16 TPM2B_ATTEST_Marshal(TPM2B_ATTEST* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.attestationData[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_ATTEST_Unmarshal(TPM2B_ATTEST* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(TPMS_ATTEST)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.attestationData[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_DIGEST_Marshal(TPM2B_DIGEST* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_DIGEST_Unmarshal(TPM2B_DIGEST* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(TPMU_HA)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_AUTH_Marshal(TPM2B_AUTH* source, BYTE** buffer, INT32* size) {
return TPM2B_DIGEST_Marshal(source, buffer, size);
}
TPM_RC TPM2B_AUTH_Unmarshal(TPM2B_AUTH* target, BYTE** buffer, INT32* size) {
return TPM2B_DIGEST_Unmarshal(target, buffer, size);
}
UINT16 TPM2B_CONTEXT_DATA_Marshal(TPM2B_CONTEXT_DATA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_CONTEXT_DATA_Unmarshal(TPM2B_CONTEXT_DATA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(TPMS_CONTEXT_DATA)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_CONTEXT_SENSITIVE_Marshal(TPM2B_CONTEXT_SENSITIVE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_CONTEXT_SENSITIVE_Unmarshal(TPM2B_CONTEXT_SENSITIVE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_CONTEXT_SIZE) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM_ALG_ID_Marshal(TPM_ALG_ID* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPM_ALG_ID_Unmarshal(TPM_ALG_ID* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint16_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
#ifdef TPM_ALG_ERROR
if (*target == TPM_ALG_ERROR) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_RSA
if (*target == TPM_ALG_RSA) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SHA
if (*target == TPM_ALG_SHA) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SHA1
if (*target == TPM_ALG_SHA1) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_HMAC
if (*target == TPM_ALG_HMAC) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_AES
if (*target == TPM_ALG_AES) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_MGF1
if (*target == TPM_ALG_MGF1) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_KEYEDHASH
if (*target == TPM_ALG_KEYEDHASH) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_XOR
if (*target == TPM_ALG_XOR) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SHA256
if (*target == TPM_ALG_SHA256) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SHA384
if (*target == TPM_ALG_SHA384) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SHA512
if (*target == TPM_ALG_SHA512) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_NULL
if (*target == TPM_ALG_NULL) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SM3_256
if (*target == TPM_ALG_SM3_256) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SM4
if (*target == TPM_ALG_SM4) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_RSASSA
if (*target == TPM_ALG_RSASSA) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_RSAES
if (*target == TPM_ALG_RSAES) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_RSAPSS
if (*target == TPM_ALG_RSAPSS) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_OAEP
if (*target == TPM_ALG_OAEP) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_ECDSA
if (*target == TPM_ALG_ECDSA) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_ECDH
if (*target == TPM_ALG_ECDH) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_ECDAA
if (*target == TPM_ALG_ECDAA) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SM2
if (*target == TPM_ALG_SM2) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_ECSCHNORR
if (*target == TPM_ALG_ECSCHNORR) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_ECMQV
if (*target == TPM_ALG_ECMQV) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_KDF1_SP800_56A
if (*target == TPM_ALG_KDF1_SP800_56A) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_KDF2
if (*target == TPM_ALG_KDF2) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_KDF1_SP800_108
if (*target == TPM_ALG_KDF1_SP800_108) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_ECC
if (*target == TPM_ALG_ECC) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_SYMCIPHER
if (*target == TPM_ALG_SYMCIPHER) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_CAMELLIA
if (*target == TPM_ALG_CAMELLIA) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_CTR
if (*target == TPM_ALG_CTR) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_OFB
if (*target == TPM_ALG_OFB) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_CBC
if (*target == TPM_ALG_CBC) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_CFB
if (*target == TPM_ALG_CFB) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_ALG_ECB
if (*target == TPM_ALG_ECB) {
return TPM_RC_SUCCESS;
}
#endif
return TPM_RC_VALUE;
}
UINT16 TPM2B_DATA_Marshal(TPM2B_DATA* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_DATA_Unmarshal(TPM2B_DATA* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(TPMT_HA)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_LOCALITY_Marshal(TPMA_LOCALITY* source,
BYTE** buffer,
INT32* size) {
return uint8_t_Marshal((uint8_t*)source, buffer, size);
}
TPM_RC TPMA_LOCALITY_Unmarshal(TPMA_LOCALITY* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = uint8_t_Unmarshal((uint8_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_NAME_Marshal(TPM2B_NAME* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.name[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_NAME_Unmarshal(TPM2B_NAME* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(TPMU_NAME)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.name[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_HASH_Marshal(TPMI_ALG_HASH* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_HASH_Unmarshal(TPMI_ALG_HASH* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_HASH;
}
switch (*target) {
#ifdef TPM_ALG_SHA
case TPM_ALG_SHA:
#endif
#ifdef TPM_ALG_SHA1
case TPM_ALG_SHA1:
#endif
#ifdef TPM_ALG_SHA256
case TPM_ALG_SHA256:
#endif
#ifdef TPM_ALG_SHA384
case TPM_ALG_SHA384:
#endif
#ifdef TPM_ALG_SHA512
case TPM_ALG_SHA512:
#endif
#ifdef TPM_ALG_SM3_256
case TPM_ALG_SM3_256:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_HASH;
}
return TPM_RC_SUCCESS;
}
UINT16 UINT8_Marshal(UINT8* source, BYTE** buffer, INT32* size) {
return uint8_t_Marshal(source, buffer, size);
}
TPM_RC UINT8_Unmarshal(UINT8* target, BYTE** buffer, INT32* size) {
return uint8_t_Unmarshal(target, buffer, size);
}
UINT16 TPMS_PCR_SELECTION_Marshal(TPMS_PCR_SELECTION* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += TPMI_ALG_HASH_Marshal(&source->hash, buffer, size);
total_size += UINT8_Marshal(&source->sizeofSelect, buffer, size);
for (i = 0; i < source->sizeofSelect; ++i) {
total_size += BYTE_Marshal(&source->pcrSelect[i], buffer, size);
}
return total_size;
}
TPM_RC TPMS_PCR_SELECTION_Unmarshal(TPMS_PCR_SELECTION* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = TPMI_ALG_HASH_Unmarshal(&target->hash, buffer, size, FALSE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT8_Unmarshal(&target->sizeofSelect, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->sizeofSelect > PCR_SELECT_MAX) {
return TPM_RC_VALUE;
}
if (target->sizeofSelect < PCR_SELECT_MIN) {
return TPM_RC_VALUE;
}
for (i = 0; i < target->sizeofSelect; ++i) {
result = BYTE_Unmarshal(&target->pcrSelect[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 UINT32_Marshal(UINT32* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC UINT32_Unmarshal(UINT32* target, BYTE** buffer, INT32* size) {
return uint32_t_Unmarshal(target, buffer, size);
}
UINT16 TPML_PCR_SELECTION_Marshal(TPML_PCR_SELECTION* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size +=
TPMS_PCR_SELECTION_Marshal(&source->pcrSelections[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_PCR_SELECTION_Unmarshal(TPML_PCR_SELECTION* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > HASH_COUNT) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result =
TPMS_PCR_SELECTION_Unmarshal(&target->pcrSelections[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_CREATION_DATA_Marshal(TPMS_CREATION_DATA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPML_PCR_SELECTION_Marshal(&source->pcrSelect, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->pcrDigest, buffer, size);
total_size += TPMA_LOCALITY_Marshal(&source->locality, buffer, size);
total_size += TPM_ALG_ID_Marshal(&source->parentNameAlg, buffer, size);
total_size += TPM2B_NAME_Marshal(&source->parentName, buffer, size);
total_size += TPM2B_NAME_Marshal(&source->parentQualifiedName, buffer, size);
total_size += TPM2B_DATA_Marshal(&source->outsideInfo, buffer, size);
return total_size;
}
TPM_RC TPMS_CREATION_DATA_Unmarshal(TPMS_CREATION_DATA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPML_PCR_SELECTION_Unmarshal(&target->pcrSelect, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->pcrDigest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMA_LOCALITY_Unmarshal(&target->locality, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM_ALG_ID_Unmarshal(&target->parentNameAlg, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_NAME_Unmarshal(&target->parentName, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_NAME_Unmarshal(&target->parentQualifiedName, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DATA_Unmarshal(&target->outsideInfo, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_CREATION_DATA_Marshal(TPM2B_CREATION_DATA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
total_size +=
TPMS_CREATION_DATA_Marshal(&source->t.creationData, buffer, size);
{
BYTE* size_location = *buffer - total_size;
INT32 size_field_size = sizeof(UINT16);
UINT16 payload_size = total_size - (UINT16)size_field_size;
UINT16_Marshal(&payload_size, &size_location, &size_field_size);
}
return total_size;
}
TPM_RC TPM2B_CREATION_DATA_Unmarshal(TPM2B_CREATION_DATA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
UINT32 start_size = *size;
UINT32 struct_size;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SIZE;
}
result = TPMS_CREATION_DATA_Unmarshal(&target->t.creationData, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
struct_size = start_size - *size - sizeof(target->t.size);
if (struct_size != target->t.size) {
return TPM_RC_SIZE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_DIGEST_VALUES_Marshal(TPM2B_DIGEST_VALUES* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_DIGEST_VALUES_Unmarshal(TPM2B_DIGEST_VALUES* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(TPML_DIGEST_VALUES)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_ECC_PARAMETER_Marshal(TPM2B_ECC_PARAMETER* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_ECC_PARAMETER_Unmarshal(TPM2B_ECC_PARAMETER* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_ECC_KEY_BYTES) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_ECC_POINT_Marshal(TPMS_ECC_POINT* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->x, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->y, buffer, size);
return total_size;
}
TPM_RC TPMS_ECC_POINT_Unmarshal(TPMS_ECC_POINT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->x, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->y, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_ECC_POINT_Marshal(TPM2B_ECC_POINT* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
total_size += TPMS_ECC_POINT_Marshal(&source->t.point, buffer, size);
{
BYTE* size_location = *buffer - total_size;
INT32 size_field_size = sizeof(UINT16);
UINT16 payload_size = total_size - (UINT16)size_field_size;
UINT16_Marshal(&payload_size, &size_location, &size_field_size);
}
return total_size;
}
TPM_RC TPM2B_ECC_POINT_Unmarshal(TPM2B_ECC_POINT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
UINT32 start_size = *size;
UINT32 struct_size;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SIZE;
}
result = TPMS_ECC_POINT_Unmarshal(&target->t.point, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
struct_size = start_size - *size - sizeof(target->t.size);
if (struct_size != target->t.size) {
return TPM_RC_SIZE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_ENCRYPTED_SECRET_Marshal(TPM2B_ENCRYPTED_SECRET* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.secret[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_ENCRYPTED_SECRET_Unmarshal(TPM2B_ENCRYPTED_SECRET* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(TPMU_ENCRYPTED_SECRET)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.secret[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_EVENT_Marshal(TPM2B_EVENT* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_EVENT_Unmarshal(TPM2B_EVENT* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > 1024) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_ID_OBJECT_Marshal(TPM2B_ID_OBJECT* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.credential[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_ID_OBJECT_Unmarshal(TPM2B_ID_OBJECT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(_ID_OBJECT)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.credential[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_IV_Marshal(TPM2B_IV* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_IV_Unmarshal(TPM2B_IV* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_SYM_BLOCK_SIZE) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_MAX_BUFFER_Marshal(TPM2B_MAX_BUFFER* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_MAX_BUFFER_Unmarshal(TPM2B_MAX_BUFFER* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_DIGEST_BUFFER) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_MAX_NV_BUFFER_Marshal(TPM2B_MAX_NV_BUFFER* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_MAX_NV_BUFFER_Unmarshal(TPM2B_MAX_NV_BUFFER* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_NV_BUFFER_SIZE) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_NONCE_Marshal(TPM2B_NONCE* source, BYTE** buffer, INT32* size) {
return TPM2B_DIGEST_Marshal(source, buffer, size);
}
TPM_RC TPM2B_NONCE_Unmarshal(TPM2B_NONCE* target, BYTE** buffer, INT32* size) {
return TPM2B_DIGEST_Unmarshal(target, buffer, size);
}
UINT16 TPMI_RH_NV_INDEX_Marshal(TPMI_RH_NV_INDEX* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_NV_INDEX_Unmarshal(TPMI_RH_NV_INDEX* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if ((*target >= NV_INDEX_FIRST) && (*target <= NV_INDEX_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_NV_Marshal(TPMA_NV* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal((uint32_t*)source, buffer, size);
}
TPM_RC TPMA_NV_Unmarshal(TPMA_NV* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal((uint32_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->reserved7_9 != 0) {
return TPM_RC_RESERVED_BITS;
}
if (target->reserved20_24 != 0) {
return TPM_RC_RESERVED_BITS;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_NV_PUBLIC_Marshal(TPMS_NV_PUBLIC* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_RH_NV_INDEX_Marshal(&source->nvIndex, buffer, size);
total_size += TPMI_ALG_HASH_Marshal(&source->nameAlg, buffer, size);
total_size += TPMA_NV_Marshal(&source->attributes, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->authPolicy, buffer, size);
total_size += UINT16_Marshal(&source->dataSize, buffer, size);
return total_size;
}
TPM_RC TPMS_NV_PUBLIC_Unmarshal(TPMS_NV_PUBLIC* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_RH_NV_INDEX_Unmarshal(&target->nvIndex, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_ALG_HASH_Unmarshal(&target->nameAlg, buffer, size, FALSE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMA_NV_Unmarshal(&target->attributes, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->authPolicy, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT16_Unmarshal(&target->dataSize, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->dataSize > MAX_NV_INDEX_SIZE) {
return TPM_RC_SIZE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_NV_PUBLIC_Marshal(TPM2B_NV_PUBLIC* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
total_size += TPMS_NV_PUBLIC_Marshal(&source->t.nvPublic, buffer, size);
{
BYTE* size_location = *buffer - total_size;
INT32 size_field_size = sizeof(UINT16);
UINT16 payload_size = total_size - (UINT16)size_field_size;
UINT16_Marshal(&payload_size, &size_location, &size_field_size);
}
return total_size;
}
TPM_RC TPM2B_NV_PUBLIC_Unmarshal(TPM2B_NV_PUBLIC* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
UINT32 start_size = *size;
UINT32 struct_size;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SIZE;
}
result = TPMS_NV_PUBLIC_Unmarshal(&target->t.nvPublic, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
struct_size = start_size - *size - sizeof(target->t.size);
if (struct_size != target->t.size) {
return TPM_RC_SIZE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_OPERAND_Marshal(TPM2B_OPERAND* source,
BYTE** buffer,
INT32* size) {
return TPM2B_DIGEST_Marshal(source, buffer, size);
}
TPM_RC TPM2B_OPERAND_Unmarshal(TPM2B_OPERAND* target,
BYTE** buffer,
INT32* size) {
return TPM2B_DIGEST_Unmarshal(target, buffer, size);
}
UINT16 TPM2B_PRIVATE_Marshal(TPM2B_PRIVATE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_PRIVATE_Unmarshal(TPM2B_PRIVATE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(_PRIVATE)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_PRIVATE_KEY_RSA_Marshal(TPM2B_PRIVATE_KEY_RSA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_PRIVATE_KEY_RSA_Unmarshal(TPM2B_PRIVATE_KEY_RSA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_RSA_KEY_BYTES / 2) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_PRIVATE_VENDOR_SPECIFIC_Marshal(
TPM2B_PRIVATE_VENDOR_SPECIFIC* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_PRIVATE_VENDOR_SPECIFIC_Unmarshal(
TPM2B_PRIVATE_VENDOR_SPECIFIC* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > PRIVATE_VENDOR_SPECIFIC_BYTES) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_OBJECT_Marshal(TPMA_OBJECT* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal((uint32_t*)source, buffer, size);
}
TPM_RC TPMA_OBJECT_Unmarshal(TPMA_OBJECT* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal((uint32_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->reserved0 != 0) {
return TPM_RC_RESERVED_BITS;
}
if (target->reserved3 != 0) {
return TPM_RC_RESERVED_BITS;
}
if (target->reserved8_9 != 0) {
return TPM_RC_RESERVED_BITS;
}
if (target->reserved12_15 != 0) {
return TPM_RC_RESERVED_BITS;
}
if (target->reserved19_31 != 0) {
return TPM_RC_RESERVED_BITS;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_PUBLIC_Marshal(TPMI_ALG_PUBLIC* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_PUBLIC_Unmarshal(TPMI_ALG_PUBLIC* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
#ifdef TPM_ALG_RSA
case TPM_ALG_RSA:
#endif
#ifdef TPM_ALG_KEYEDHASH
case TPM_ALG_KEYEDHASH:
#endif
#ifdef TPM_ALG_ECC
case TPM_ALG_ECC:
#endif
#ifdef TPM_ALG_SYMCIPHER
case TPM_ALG_SYMCIPHER:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_TYPE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_PUBLIC_KEY_RSA_Marshal(TPM2B_PUBLIC_KEY_RSA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_PUBLIC_KEY_RSA_Unmarshal(TPM2B_PUBLIC_KEY_RSA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_RSA_KEY_BYTES) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_PUBLIC_ID_Marshal(TPMU_PUBLIC_ID* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_KEYEDHASH
case TPM_ALG_KEYEDHASH:
return TPM2B_DIGEST_Marshal((TPM2B_DIGEST*)&source->keyedHash, buffer,
size);
#endif
#ifdef TPM_ALG_SYMCIPHER
case TPM_ALG_SYMCIPHER:
return TPM2B_DIGEST_Marshal((TPM2B_DIGEST*)&source->sym, buffer, size);
#endif
#ifdef TPM_ALG_RSA
case TPM_ALG_RSA:
return TPM2B_PUBLIC_KEY_RSA_Marshal((TPM2B_PUBLIC_KEY_RSA*)&source->rsa,
buffer, size);
#endif
#ifdef TPM_ALG_ECC
case TPM_ALG_ECC:
return TPMS_ECC_POINT_Marshal((TPMS_ECC_POINT*)&source->ecc, buffer,
size);
#endif
}
return 0;
}
TPM_RC TPMU_PUBLIC_ID_Unmarshal(TPMU_PUBLIC_ID* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_KEYEDHASH
case TPM_ALG_KEYEDHASH:
return TPM2B_DIGEST_Unmarshal((TPM2B_DIGEST*)&target->keyedHash, buffer,
size);
#endif
#ifdef TPM_ALG_SYMCIPHER
case TPM_ALG_SYMCIPHER:
return TPM2B_DIGEST_Unmarshal((TPM2B_DIGEST*)&target->sym, buffer, size);
#endif
#ifdef TPM_ALG_RSA
case TPM_ALG_RSA:
return TPM2B_PUBLIC_KEY_RSA_Unmarshal((TPM2B_PUBLIC_KEY_RSA*)&target->rsa,
buffer, size);
#endif
#ifdef TPM_ALG_ECC
case TPM_ALG_ECC:
return TPMS_ECC_POINT_Unmarshal((TPMS_ECC_POINT*)&target->ecc, buffer,
size);
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPM_KEY_BITS_Marshal(TPM_KEY_BITS* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPM_KEY_BITS_Unmarshal(TPM_KEY_BITS* target,
BYTE** buffer,
INT32* size) {
return uint16_t_Unmarshal(target, buffer, size);
}
UINT16 TPMI_AES_KEY_BITS_Marshal(TPMI_AES_KEY_BITS* source,
BYTE** buffer,
INT32* size) {
return TPM_KEY_BITS_Marshal(source, buffer, size);
}
TPM_RC TPMI_AES_KEY_BITS_Unmarshal(TPMI_AES_KEY_BITS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
uint16_t supported_values[] = AES_KEY_SIZES_BITS;
size_t length = sizeof(supported_values) / sizeof(supported_values[0]);
size_t i;
BOOL is_supported_value = FALSE;
result = TPM_KEY_BITS_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
for (i = 0; i < length; ++i) {
if (*target == supported_values[i]) {
is_supported_value = TRUE;
break;
}
}
if (!is_supported_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_SM4_KEY_BITS_Marshal(TPMI_SM4_KEY_BITS* source,
BYTE** buffer,
INT32* size) {
return TPM_KEY_BITS_Marshal(source, buffer, size);
}
TPM_RC TPMI_SM4_KEY_BITS_Unmarshal(TPMI_SM4_KEY_BITS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
uint16_t supported_values[] = SM4_KEY_SIZES_BITS;
size_t length = sizeof(supported_values) / sizeof(supported_values[0]);
size_t i;
BOOL is_supported_value = FALSE;
result = TPM_KEY_BITS_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
for (i = 0; i < length; ++i) {
if (*target == supported_values[i]) {
is_supported_value = TRUE;
break;
}
}
if (!is_supported_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_CAMELLIA_KEY_BITS_Marshal(TPMI_CAMELLIA_KEY_BITS* source,
BYTE** buffer,
INT32* size) {
return TPM_KEY_BITS_Marshal(source, buffer, size);
}
TPM_RC TPMI_CAMELLIA_KEY_BITS_Unmarshal(TPMI_CAMELLIA_KEY_BITS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
uint16_t supported_values[] = CAMELLIA_KEY_SIZES_BITS;
size_t length = sizeof(supported_values) / sizeof(supported_values[0]);
size_t i;
BOOL is_supported_value = FALSE;
result = TPM_KEY_BITS_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
for (i = 0; i < length; ++i) {
if (*target == supported_values[i]) {
is_supported_value = TRUE;
break;
}
}
if (!is_supported_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_SYM_KEY_BITS_Marshal(TPMU_SYM_KEY_BITS* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_AES
case TPM_ALG_AES:
return TPMI_AES_KEY_BITS_Marshal((TPMI_AES_KEY_BITS*)&source->aes, buffer,
size);
#endif
#ifdef TPM_ALG_SM4
case TPM_ALG_SM4:
return TPMI_SM4_KEY_BITS_Marshal((TPMI_SM4_KEY_BITS*)&source->sm4, buffer,
size);
#endif
#ifdef TPM_ALG_CAMELLIA
case TPM_ALG_CAMELLIA:
return TPMI_CAMELLIA_KEY_BITS_Marshal(
(TPMI_CAMELLIA_KEY_BITS*)&source->camellia, buffer, size);
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
return TPMI_ALG_HASH_Marshal((TPMI_ALG_HASH*)&source->xor_, buffer, size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_SYM_KEY_BITS_Unmarshal(TPMU_SYM_KEY_BITS* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_AES
case TPM_ALG_AES:
return TPMI_AES_KEY_BITS_Unmarshal((TPMI_AES_KEY_BITS*)&target->aes,
buffer, size);
#endif
#ifdef TPM_ALG_SM4
case TPM_ALG_SM4:
return TPMI_SM4_KEY_BITS_Unmarshal((TPMI_SM4_KEY_BITS*)&target->sm4,
buffer, size);
#endif
#ifdef TPM_ALG_CAMELLIA
case TPM_ALG_CAMELLIA:
return TPMI_CAMELLIA_KEY_BITS_Unmarshal(
(TPMI_CAMELLIA_KEY_BITS*)&target->camellia, buffer, size);
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
return TPMI_ALG_HASH_Unmarshal(&target->xor_, buffer, size, FALSE);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMI_ALG_SYM_MODE_Marshal(TPMI_ALG_SYM_MODE* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_SYM_MODE_Unmarshal(TPMI_ALG_SYM_MODE* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_MODE;
}
switch (*target) {
#ifdef TPM_ALG_CTR
case TPM_ALG_CTR:
#endif
#ifdef TPM_ALG_OFB
case TPM_ALG_OFB:
#endif
#ifdef TPM_ALG_CBC
case TPM_ALG_CBC:
#endif
#ifdef TPM_ALG_CFB
case TPM_ALG_CFB:
#endif
#ifdef TPM_ALG_ECB
case TPM_ALG_ECB:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_MODE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_SYM_MODE_Marshal(TPMU_SYM_MODE* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_AES
case TPM_ALG_AES:
return TPMI_ALG_SYM_MODE_Marshal((TPMI_ALG_SYM_MODE*)&source->aes, buffer,
size);
#endif
#ifdef TPM_ALG_SM4
case TPM_ALG_SM4:
return TPMI_ALG_SYM_MODE_Marshal((TPMI_ALG_SYM_MODE*)&source->sm4, buffer,
size);
#endif
#ifdef TPM_ALG_CAMELLIA
case TPM_ALG_CAMELLIA:
return TPMI_ALG_SYM_MODE_Marshal((TPMI_ALG_SYM_MODE*)&source->camellia,
buffer, size);
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
return 0;
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_SYM_MODE_Unmarshal(TPMU_SYM_MODE* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_AES
case TPM_ALG_AES:
return TPMI_ALG_SYM_MODE_Unmarshal(&target->aes, buffer, size, FALSE);
#endif
#ifdef TPM_ALG_SM4
case TPM_ALG_SM4:
return TPMI_ALG_SYM_MODE_Unmarshal(&target->sm4, buffer, size, FALSE);
#endif
#ifdef TPM_ALG_CAMELLIA
case TPM_ALG_CAMELLIA:
return TPMI_ALG_SYM_MODE_Unmarshal(&target->camellia, buffer, size,
FALSE);
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMI_ALG_SYM_OBJECT_Marshal(TPMI_ALG_SYM_OBJECT* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_SYM_OBJECT_Unmarshal(TPMI_ALG_SYM_OBJECT* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_SYMMETRIC;
}
switch (*target) {
#ifdef TPM_ALG_AES
case TPM_ALG_AES:
#endif
#ifdef TPM_ALG_SM4
case TPM_ALG_SM4:
#endif
#ifdef TPM_ALG_CAMELLIA
case TPM_ALG_CAMELLIA:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_SYMMETRIC;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMT_SYM_DEF_OBJECT_Marshal(TPMT_SYM_DEF_OBJECT* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_SYM_OBJECT_Marshal(&source->algorithm, buffer, size);
total_size += TPMU_SYM_KEY_BITS_Marshal(&source->keyBits, buffer, size,
source->algorithm);
total_size +=
TPMU_SYM_MODE_Marshal(&source->mode, buffer, size, source->algorithm);
return total_size;
}
TPM_RC TPMT_SYM_DEF_OBJECT_Unmarshal(TPMT_SYM_DEF_OBJECT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result =
TPMI_ALG_SYM_OBJECT_Unmarshal(&target->algorithm, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_SYM_KEY_BITS_Unmarshal(&target->keyBits, buffer, size,
target->algorithm);
if (result != TPM_RC_SUCCESS) {
return result;
}
result =
TPMU_SYM_MODE_Unmarshal(&target->mode, buffer, size, target->algorithm);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_RSA_SCHEME_Marshal(TPMI_ALG_RSA_SCHEME* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_RSA_SCHEME_Unmarshal(TPMI_ALG_RSA_SCHEME* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
#ifdef TPM_ALG_RSAES
case TPM_ALG_RSAES:
#endif
#ifdef TPM_ALG_OAEP
case TPM_ALG_OAEP:
#endif
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SCHEME_HASH_Marshal(TPMS_SCHEME_HASH* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_HASH_Marshal(&source->hashAlg, buffer, size);
return total_size;
}
TPM_RC TPMS_SCHEME_HASH_Unmarshal(TPMS_SCHEME_HASH* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_HASH_Unmarshal(&target->hashAlg, buffer, size, FALSE);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SIG_SCHEME_RSAPSS_Marshal(TPMS_SIG_SCHEME_RSAPSS* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIG_SCHEME_RSAPSS_Unmarshal(TPMS_SIG_SCHEME_RSAPSS* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIG_SCHEME_SM2_Marshal(TPMS_SIG_SCHEME_SM2* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIG_SCHEME_SM2_Unmarshal(TPMS_SIG_SCHEME_SM2* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIG_SCHEME_ECSCHNORR_Marshal(TPMS_SIG_SCHEME_ECSCHNORR* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIG_SCHEME_ECSCHNORR_Unmarshal(TPMS_SIG_SCHEME_ECSCHNORR* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SCHEME_ECDAA_Marshal(TPMS_SCHEME_ECDAA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_HASH_Marshal(&source->hashAlg, buffer, size);
total_size += UINT16_Marshal(&source->count, buffer, size);
return total_size;
}
TPM_RC TPMS_SCHEME_ECDAA_Unmarshal(TPMS_SCHEME_ECDAA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_HASH_Unmarshal(&target->hashAlg, buffer, size, FALSE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT16_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SIG_SCHEME_ECDAA_Marshal(TPMS_SIG_SCHEME_ECDAA* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_ECDAA_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIG_SCHEME_ECDAA_Unmarshal(TPMS_SIG_SCHEME_ECDAA* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_ECDAA_Unmarshal(target, buffer, size);
}
UINT16 TPMS_KEY_SCHEME_ECDH_Marshal(TPMS_KEY_SCHEME_ECDH* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_KEY_SCHEME_ECDH_Unmarshal(TPMS_KEY_SCHEME_ECDH* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_KEY_SCHEME_ECMQV_Marshal(TPMS_KEY_SCHEME_ECMQV* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_KEY_SCHEME_ECMQV_Unmarshal(TPMS_KEY_SCHEME_ECMQV* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIG_SCHEME_RSASSA_Marshal(TPMS_SIG_SCHEME_RSASSA* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIG_SCHEME_RSASSA_Unmarshal(TPMS_SIG_SCHEME_RSASSA* target,
BYTE** buffer,
INT32* size) {
#if defined(SUPPORT_PADDING_ONLY_RSASSA) && SUPPORT_PADDING_ONLY_RSASSA == YES
return TPMI_ALG_HASH_Unmarshal(&target->hashAlg, buffer, size, TRUE);
#else
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
#endif
}
UINT16 TPMS_ENC_SCHEME_OAEP_Marshal(TPMS_ENC_SCHEME_OAEP* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_ENC_SCHEME_OAEP_Unmarshal(TPMS_ENC_SCHEME_OAEP* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_EMPTY_Marshal(TPMS_EMPTY* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
return total_size;
}
TPM_RC TPMS_EMPTY_Unmarshal(TPMS_EMPTY* target, BYTE** buffer, INT32* size) {
TPM_RC result;
(void)result;
return TPM_RC_SUCCESS;
}
UINT16 TPMS_ENC_SCHEME_RSAES_Marshal(TPMS_ENC_SCHEME_RSAES* source,
BYTE** buffer,
INT32* size) {
return TPMS_EMPTY_Marshal(source, buffer, size);
}
TPM_RC TPMS_ENC_SCHEME_RSAES_Unmarshal(TPMS_ENC_SCHEME_RSAES* target,
BYTE** buffer,
INT32* size) {
return TPMS_EMPTY_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIG_SCHEME_ECDSA_Marshal(TPMS_SIG_SCHEME_ECDSA* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIG_SCHEME_ECDSA_Unmarshal(TPMS_SIG_SCHEME_ECDSA* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMU_ASYM_SCHEME_Marshal(TPMU_ASYM_SCHEME* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_ECDH
case TPM_ALG_ECDH:
return TPMS_KEY_SCHEME_ECDH_Marshal((TPMS_KEY_SCHEME_ECDH*)&source->ecdh,
buffer, size);
#endif
#ifdef TPM_ALG_ECMQV
case TPM_ALG_ECMQV:
return TPMS_KEY_SCHEME_ECMQV_Marshal(
(TPMS_KEY_SCHEME_ECMQV*)&source->ecmqv, buffer, size);
#endif
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
return TPMS_SIG_SCHEME_RSASSA_Marshal(
(TPMS_SIG_SCHEME_RSASSA*)&source->rsassa, buffer, size);
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
return TPMS_SIG_SCHEME_RSAPSS_Marshal(
(TPMS_SIG_SCHEME_RSAPSS*)&source->rsapss, buffer, size);
#endif
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
return TPMS_SIG_SCHEME_ECDSA_Marshal(
(TPMS_SIG_SCHEME_ECDSA*)&source->ecdsa, buffer, size);
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
return TPMS_SIG_SCHEME_ECDAA_Marshal(
(TPMS_SIG_SCHEME_ECDAA*)&source->ecdaa, buffer, size);
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
return TPMS_SIG_SCHEME_SM2_Marshal((TPMS_SIG_SCHEME_SM2*)&source->sm2,
buffer, size);
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
return TPMS_SIG_SCHEME_ECSCHNORR_Marshal(
(TPMS_SIG_SCHEME_ECSCHNORR*)&source->ecschnorr, buffer, size);
#endif
#ifdef TPM_ALG_RSAES
case TPM_ALG_RSAES:
return TPMS_ENC_SCHEME_RSAES_Marshal(
(TPMS_ENC_SCHEME_RSAES*)&source->rsaes, buffer, size);
#endif
#ifdef TPM_ALG_OAEP
case TPM_ALG_OAEP:
return TPMS_ENC_SCHEME_OAEP_Marshal((TPMS_ENC_SCHEME_OAEP*)&source->oaep,
buffer, size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_ASYM_SCHEME_Unmarshal(TPMU_ASYM_SCHEME* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_ECDH
case TPM_ALG_ECDH:
return TPMS_KEY_SCHEME_ECDH_Unmarshal(
(TPMS_KEY_SCHEME_ECDH*)&target->ecdh, buffer, size);
#endif
#ifdef TPM_ALG_ECMQV
case TPM_ALG_ECMQV:
return TPMS_KEY_SCHEME_ECMQV_Unmarshal(
(TPMS_KEY_SCHEME_ECMQV*)&target->ecmqv, buffer, size);
#endif
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
return TPMS_SIG_SCHEME_RSASSA_Unmarshal(
(TPMS_SIG_SCHEME_RSASSA*)&target->rsassa, buffer, size);
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
return TPMS_SIG_SCHEME_RSAPSS_Unmarshal(
(TPMS_SIG_SCHEME_RSAPSS*)&target->rsapss, buffer, size);
#endif
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
return TPMS_SIG_SCHEME_ECDSA_Unmarshal(
(TPMS_SIG_SCHEME_ECDSA*)&target->ecdsa, buffer, size);
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
return TPMS_SIG_SCHEME_ECDAA_Unmarshal(
(TPMS_SIG_SCHEME_ECDAA*)&target->ecdaa, buffer, size);
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
return TPMS_SIG_SCHEME_SM2_Unmarshal((TPMS_SIG_SCHEME_SM2*)&target->sm2,
buffer, size);
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
return TPMS_SIG_SCHEME_ECSCHNORR_Unmarshal(
(TPMS_SIG_SCHEME_ECSCHNORR*)&target->ecschnorr, buffer, size);
#endif
#ifdef TPM_ALG_RSAES
case TPM_ALG_RSAES:
return TPMS_ENC_SCHEME_RSAES_Unmarshal(
(TPMS_ENC_SCHEME_RSAES*)&target->rsaes, buffer, size);
#endif
#ifdef TPM_ALG_OAEP
case TPM_ALG_OAEP:
return TPMS_ENC_SCHEME_OAEP_Unmarshal(
(TPMS_ENC_SCHEME_OAEP*)&target->oaep, buffer, size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMT_RSA_SCHEME_Marshal(TPMT_RSA_SCHEME* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_RSA_SCHEME_Marshal(&source->scheme, buffer, size);
total_size +=
TPMU_ASYM_SCHEME_Marshal(&source->details, buffer, size, source->scheme);
return total_size;
}
TPM_RC TPMT_RSA_SCHEME_Unmarshal(TPMT_RSA_SCHEME* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_RSA_SCHEME_Unmarshal(&target->scheme, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_ASYM_SCHEME_Unmarshal(&target->details, buffer, size,
target->scheme);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RSA_KEY_BITS_Marshal(TPMI_RSA_KEY_BITS* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RSA_KEY_BITS_Unmarshal(TPMI_RSA_KEY_BITS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
uint16_t supported_values[] = RSA_KEY_SIZES_BITS;
size_t length = sizeof(supported_values) / sizeof(supported_values[0]);
size_t i;
BOOL is_supported_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
for (i = 0; i < length; ++i) {
if (*target == supported_values[i]) {
is_supported_value = TRUE;
break;
}
}
if (!is_supported_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_RSA_PARMS_Marshal(TPMS_RSA_PARMS* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMT_SYM_DEF_OBJECT_Marshal(&source->symmetric, buffer, size);
total_size += TPMT_RSA_SCHEME_Marshal(&source->scheme, buffer, size);
total_size += TPMI_RSA_KEY_BITS_Marshal(&source->keyBits, buffer, size);
total_size += UINT32_Marshal(&source->exponent, buffer, size);
return total_size;
}
TPM_RC TPMS_RSA_PARMS_Unmarshal(TPMS_RSA_PARMS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMT_SYM_DEF_OBJECT_Unmarshal(&target->symmetric, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMT_RSA_SCHEME_Unmarshal(&target->scheme, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_RSA_KEY_BITS_Unmarshal(&target->keyBits, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT32_Unmarshal(&target->exponent, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SYMCIPHER_PARMS_Marshal(TPMS_SYMCIPHER_PARMS* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMT_SYM_DEF_OBJECT_Marshal(&source->sym, buffer, size);
return total_size;
}
TPM_RC TPMS_SYMCIPHER_PARMS_Unmarshal(TPMS_SYMCIPHER_PARMS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMT_SYM_DEF_OBJECT_Unmarshal(&target->sym, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_ASYM_SCHEME_Marshal(TPMI_ALG_ASYM_SCHEME* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_ASYM_SCHEME_Unmarshal(TPMI_ALG_ASYM_SCHEME* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
#ifdef TPM_ALG_ECDH
case TPM_ALG_ECDH:
#endif
#ifdef TPM_ALG_ECMQV
case TPM_ALG_ECMQV:
#endif
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
#endif
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
#endif
#ifdef TPM_ALG_RSAES
case TPM_ALG_RSAES:
#endif
#ifdef TPM_ALG_OAEP
case TPM_ALG_OAEP:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMT_ASYM_SCHEME_Marshal(TPMT_ASYM_SCHEME* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_ASYM_SCHEME_Marshal(&source->scheme, buffer, size);
total_size +=
TPMU_ASYM_SCHEME_Marshal(&source->details, buffer, size, source->scheme);
return total_size;
}
TPM_RC TPMT_ASYM_SCHEME_Unmarshal(TPMT_ASYM_SCHEME* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_ASYM_SCHEME_Unmarshal(&target->scheme, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_ASYM_SCHEME_Unmarshal(&target->details, buffer, size,
target->scheme);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_ASYM_PARMS_Marshal(TPMS_ASYM_PARMS* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMT_SYM_DEF_OBJECT_Marshal(&source->symmetric, buffer, size);
total_size += TPMT_ASYM_SCHEME_Marshal(&source->scheme, buffer, size);
return total_size;
}
TPM_RC TPMS_ASYM_PARMS_Unmarshal(TPMS_ASYM_PARMS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMT_SYM_DEF_OBJECT_Unmarshal(&target->symmetric, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMT_ASYM_SCHEME_Unmarshal(&target->scheme, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_KDF_Marshal(TPMI_ALG_KDF* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_KDF_Unmarshal(TPMI_ALG_KDF* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_KDF;
}
switch (*target) {
#ifdef TPM_ALG_MGF1
case TPM_ALG_MGF1:
#endif
#ifdef TPM_ALG_KDF1_SP800_56A
case TPM_ALG_KDF1_SP800_56A:
#endif
#ifdef TPM_ALG_KDF2
case TPM_ALG_KDF2:
#endif
#ifdef TPM_ALG_KDF1_SP800_108
case TPM_ALG_KDF1_SP800_108:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_KDF;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SCHEME_KDF1_SP800_108_Marshal(TPMS_SCHEME_KDF1_SP800_108* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SCHEME_KDF1_SP800_108_Unmarshal(TPMS_SCHEME_KDF1_SP800_108* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SCHEME_KDF2_Marshal(TPMS_SCHEME_KDF2* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SCHEME_KDF2_Unmarshal(TPMS_SCHEME_KDF2* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SCHEME_KDF1_SP800_56A_Marshal(TPMS_SCHEME_KDF1_SP800_56A* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SCHEME_KDF1_SP800_56A_Unmarshal(TPMS_SCHEME_KDF1_SP800_56A* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SCHEME_MGF1_Marshal(TPMS_SCHEME_MGF1* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SCHEME_MGF1_Unmarshal(TPMS_SCHEME_MGF1* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMU_KDF_SCHEME_Marshal(TPMU_KDF_SCHEME* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_MGF1
case TPM_ALG_MGF1:
return TPMS_SCHEME_MGF1_Marshal((TPMS_SCHEME_MGF1*)&source->mgf1, buffer,
size);
#endif
#ifdef TPM_ALG_KDF1_SP800_56A
case TPM_ALG_KDF1_SP800_56A:
return TPMS_SCHEME_KDF1_SP800_56A_Marshal(
(TPMS_SCHEME_KDF1_SP800_56A*)&source->kdf1_sp800_56a, buffer, size);
#endif
#ifdef TPM_ALG_KDF2
case TPM_ALG_KDF2:
return TPMS_SCHEME_KDF2_Marshal((TPMS_SCHEME_KDF2*)&source->kdf2, buffer,
size);
#endif
#ifdef TPM_ALG_KDF1_SP800_108
case TPM_ALG_KDF1_SP800_108:
return TPMS_SCHEME_KDF1_SP800_108_Marshal(
(TPMS_SCHEME_KDF1_SP800_108*)&source->kdf1_sp800_108, buffer, size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_KDF_SCHEME_Unmarshal(TPMU_KDF_SCHEME* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_MGF1
case TPM_ALG_MGF1:
return TPMS_SCHEME_MGF1_Unmarshal((TPMS_SCHEME_MGF1*)&target->mgf1,
buffer, size);
#endif
#ifdef TPM_ALG_KDF1_SP800_56A
case TPM_ALG_KDF1_SP800_56A:
return TPMS_SCHEME_KDF1_SP800_56A_Unmarshal(
(TPMS_SCHEME_KDF1_SP800_56A*)&target->kdf1_sp800_56a, buffer, size);
#endif
#ifdef TPM_ALG_KDF2
case TPM_ALG_KDF2:
return TPMS_SCHEME_KDF2_Unmarshal((TPMS_SCHEME_KDF2*)&target->kdf2,
buffer, size);
#endif
#ifdef TPM_ALG_KDF1_SP800_108
case TPM_ALG_KDF1_SP800_108:
return TPMS_SCHEME_KDF1_SP800_108_Unmarshal(
(TPMS_SCHEME_KDF1_SP800_108*)&target->kdf1_sp800_108, buffer, size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMT_KDF_SCHEME_Marshal(TPMT_KDF_SCHEME* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_KDF_Marshal(&source->scheme, buffer, size);
total_size +=
TPMU_KDF_SCHEME_Marshal(&source->details, buffer, size, source->scheme);
return total_size;
}
TPM_RC TPMT_KDF_SCHEME_Unmarshal(TPMT_KDF_SCHEME* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_KDF_Unmarshal(&target->scheme, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result =
TPMU_KDF_SCHEME_Unmarshal(&target->details, buffer, size, target->scheme);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_ECC_SCHEME_Marshal(TPMI_ALG_ECC_SCHEME* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_ECC_SCHEME_Unmarshal(TPMI_ALG_ECC_SCHEME* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_SCHEME;
}
switch (*target) {
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
#endif
#ifdef TPM_ALG_ECDH
case TPM_ALG_ECDH:
#endif
#ifdef TPM_ALG_ECMQV
case TPM_ALG_ECMQV:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_SCHEME;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMT_ECC_SCHEME_Marshal(TPMT_ECC_SCHEME* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_ECC_SCHEME_Marshal(&source->scheme, buffer, size);
total_size +=
TPMU_ASYM_SCHEME_Marshal(&source->details, buffer, size, source->scheme);
return total_size;
}
TPM_RC TPMT_ECC_SCHEME_Unmarshal(TPMT_ECC_SCHEME* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_ECC_SCHEME_Unmarshal(&target->scheme, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_ASYM_SCHEME_Unmarshal(&target->details, buffer, size,
target->scheme);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ECC_CURVE_Marshal(TPMI_ECC_CURVE* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ECC_CURVE_Unmarshal(TPMI_ECC_CURVE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
uint16_t supported_values[] = ECC_CURVES;
size_t length = sizeof(supported_values) / sizeof(supported_values[0]);
size_t i;
BOOL is_supported_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
for (i = 0; i < length; ++i) {
if (*target == supported_values[i]) {
is_supported_value = TRUE;
break;
}
}
if (!is_supported_value) {
return TPM_RC_CURVE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_ECC_PARMS_Marshal(TPMS_ECC_PARMS* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMT_SYM_DEF_OBJECT_Marshal(&source->symmetric, buffer, size);
total_size += TPMT_ECC_SCHEME_Marshal(&source->scheme, buffer, size);
total_size += TPMI_ECC_CURVE_Marshal(&source->curveID, buffer, size);
total_size += TPMT_KDF_SCHEME_Marshal(&source->kdf, buffer, size);
return total_size;
}
TPM_RC TPMS_ECC_PARMS_Unmarshal(TPMS_ECC_PARMS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMT_SYM_DEF_OBJECT_Unmarshal(&target->symmetric, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMT_ECC_SCHEME_Unmarshal(&target->scheme, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_ECC_CURVE_Unmarshal(&target->curveID, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMT_KDF_SCHEME_Unmarshal(&target->kdf, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_KEYEDHASH_SCHEME_Marshal(TPMI_ALG_KEYEDHASH_SCHEME* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_KEYEDHASH_SCHEME_Unmarshal(TPMI_ALG_KEYEDHASH_SCHEME* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
#ifdef TPM_ALG_HMAC
case TPM_ALG_HMAC:
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SCHEME_HMAC_Marshal(TPMS_SCHEME_HMAC* source,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Marshal(source, buffer, size);
}
TPM_RC TPMS_SCHEME_HMAC_Unmarshal(TPMS_SCHEME_HMAC* target,
BYTE** buffer,
INT32* size) {
return TPMS_SCHEME_HASH_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SCHEME_XOR_Marshal(TPMS_SCHEME_XOR* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_HASH_Marshal(&source->hashAlg, buffer, size);
total_size += TPMI_ALG_KDF_Marshal(&source->kdf, buffer, size);
return total_size;
}
TPM_RC TPMS_SCHEME_XOR_Unmarshal(TPMS_SCHEME_XOR* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_HASH_Unmarshal(&target->hashAlg, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_ALG_KDF_Unmarshal(&target->kdf, buffer, size, FALSE);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_SCHEME_KEYEDHASH_Marshal(TPMU_SCHEME_KEYEDHASH* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_HMAC
case TPM_ALG_HMAC:
return TPMS_SCHEME_HMAC_Marshal((TPMS_SCHEME_HMAC*)&source->hmac, buffer,
size);
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
return TPMS_SCHEME_XOR_Marshal((TPMS_SCHEME_XOR*)&source->xor_, buffer,
size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_SCHEME_KEYEDHASH_Unmarshal(TPMU_SCHEME_KEYEDHASH* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_HMAC
case TPM_ALG_HMAC:
return TPMS_SCHEME_HMAC_Unmarshal((TPMS_SCHEME_HMAC*)&target->hmac,
buffer, size);
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
return TPMS_SCHEME_XOR_Unmarshal((TPMS_SCHEME_XOR*)&target->xor_, buffer,
size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMT_KEYEDHASH_SCHEME_Marshal(TPMT_KEYEDHASH_SCHEME* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size +=
TPMI_ALG_KEYEDHASH_SCHEME_Marshal(&source->scheme, buffer, size);
total_size += TPMU_SCHEME_KEYEDHASH_Marshal(&source->details, buffer, size,
source->scheme);
return total_size;
}
TPM_RC TPMT_KEYEDHASH_SCHEME_Unmarshal(TPMT_KEYEDHASH_SCHEME* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result =
TPMI_ALG_KEYEDHASH_SCHEME_Unmarshal(&target->scheme, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_SCHEME_KEYEDHASH_Unmarshal(&target->details, buffer, size,
target->scheme);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_KEYEDHASH_PARMS_Marshal(TPMS_KEYEDHASH_PARMS* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMT_KEYEDHASH_SCHEME_Marshal(&source->scheme, buffer, size);
return total_size;
}
TPM_RC TPMS_KEYEDHASH_PARMS_Unmarshal(TPMS_KEYEDHASH_PARMS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMT_KEYEDHASH_SCHEME_Unmarshal(&target->scheme, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_PUBLIC_PARMS_Marshal(TPMU_PUBLIC_PARMS* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_KEYEDHASH
case TPM_ALG_KEYEDHASH:
return TPMS_KEYEDHASH_PARMS_Marshal(
(TPMS_KEYEDHASH_PARMS*)&source->keyedHashDetail, buffer, size);
#endif
#ifdef TPM_ALG_SYMCIPHER
case TPM_ALG_SYMCIPHER:
return TPMS_SYMCIPHER_PARMS_Marshal(
(TPMS_SYMCIPHER_PARMS*)&source->symDetail, buffer, size);
#endif
#ifdef TPM_ALG_RSA
case TPM_ALG_RSA:
return TPMS_RSA_PARMS_Marshal((TPMS_RSA_PARMS*)&source->rsaDetail, buffer,
size);
#endif
#ifdef TPM_ALG_ECC
case TPM_ALG_ECC:
return TPMS_ECC_PARMS_Marshal((TPMS_ECC_PARMS*)&source->eccDetail, buffer,
size);
#endif
}
return 0;
}
TPM_RC TPMU_PUBLIC_PARMS_Unmarshal(TPMU_PUBLIC_PARMS* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_KEYEDHASH
case TPM_ALG_KEYEDHASH:
return TPMS_KEYEDHASH_PARMS_Unmarshal(
(TPMS_KEYEDHASH_PARMS*)&target->keyedHashDetail, buffer, size);
#endif
#ifdef TPM_ALG_SYMCIPHER
case TPM_ALG_SYMCIPHER:
return TPMS_SYMCIPHER_PARMS_Unmarshal(
(TPMS_SYMCIPHER_PARMS*)&target->symDetail, buffer, size);
#endif
#ifdef TPM_ALG_RSA
case TPM_ALG_RSA:
return TPMS_RSA_PARMS_Unmarshal((TPMS_RSA_PARMS*)&target->rsaDetail,
buffer, size);
#endif
#ifdef TPM_ALG_ECC
case TPM_ALG_ECC:
return TPMS_ECC_PARMS_Unmarshal((TPMS_ECC_PARMS*)&target->eccDetail,
buffer, size);
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMT_PUBLIC_Marshal(TPMT_PUBLIC* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_PUBLIC_Marshal(&source->type, buffer, size);
total_size += TPMI_ALG_HASH_Marshal(&source->nameAlg, buffer, size);
total_size += TPMA_OBJECT_Marshal(&source->objectAttributes, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->authPolicy, buffer, size);
total_size += TPMU_PUBLIC_PARMS_Marshal(&source->parameters, buffer, size,
source->type);
total_size +=
TPMU_PUBLIC_ID_Marshal(&source->unique, buffer, size, source->type);
return total_size;
}
TPM_RC TPMT_PUBLIC_Unmarshal(TPMT_PUBLIC* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = TPMI_ALG_PUBLIC_Unmarshal(&target->type, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_ALG_HASH_Unmarshal(&target->nameAlg, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMA_OBJECT_Unmarshal(&target->objectAttributes, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->authPolicy, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_PUBLIC_PARMS_Unmarshal(&target->parameters, buffer, size,
target->type);
if (result != TPM_RC_SUCCESS) {
return result;
}
result =
TPMU_PUBLIC_ID_Unmarshal(&target->unique, buffer, size, target->type);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_PUBLIC_Marshal(TPM2B_PUBLIC* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
total_size += TPMT_PUBLIC_Marshal(&source->t.publicArea, buffer, size);
{
BYTE* size_location = *buffer - total_size;
INT32 size_field_size = sizeof(UINT16);
UINT16 payload_size = total_size - (UINT16)size_field_size;
UINT16_Marshal(&payload_size, &size_location, &size_field_size);
}
return total_size;
}
TPM_RC TPM2B_PUBLIC_Unmarshal(TPM2B_PUBLIC* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
UINT32 start_size = *size;
UINT32 struct_size;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SIZE;
}
result = TPMT_PUBLIC_Unmarshal(&target->t.publicArea, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
struct_size = start_size - *size - sizeof(target->t.size);
if (struct_size != target->t.size) {
return TPM_RC_SIZE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_SENSITIVE_DATA_Marshal(TPM2B_SENSITIVE_DATA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_SENSITIVE_DATA_Unmarshal(TPM2B_SENSITIVE_DATA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_SYM_DATA) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_SYM_KEY_Marshal(TPM2B_SYM_KEY* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_SYM_KEY_Unmarshal(TPM2B_SYM_KEY* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > MAX_SYM_KEY_BYTES) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_SENSITIVE_COMPOSITE_Marshal(TPMU_SENSITIVE_COMPOSITE* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_RSA
case TPM_ALG_RSA:
return TPM2B_PRIVATE_KEY_RSA_Marshal((TPM2B_PRIVATE_KEY_RSA*)&source->rsa,
buffer, size);
#endif
#ifdef TPM_ALG_ECC
case TPM_ALG_ECC:
return TPM2B_ECC_PARAMETER_Marshal((TPM2B_ECC_PARAMETER*)&source->ecc,
buffer, size);
#endif
#ifdef TPM_ALG_KEYEDHASH
case TPM_ALG_KEYEDHASH:
return TPM2B_SENSITIVE_DATA_Marshal((TPM2B_SENSITIVE_DATA*)&source->bits,
buffer, size);
#endif
#ifdef TPM_ALG_SYMCIPHER
case TPM_ALG_SYMCIPHER:
return TPM2B_SYM_KEY_Marshal((TPM2B_SYM_KEY*)&source->sym, buffer, size);
#endif
}
return 0;
}
TPM_RC TPMU_SENSITIVE_COMPOSITE_Unmarshal(TPMU_SENSITIVE_COMPOSITE* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_RSA
case TPM_ALG_RSA:
return TPM2B_PRIVATE_KEY_RSA_Unmarshal(
(TPM2B_PRIVATE_KEY_RSA*)&target->rsa, buffer, size);
#endif
#ifdef TPM_ALG_ECC
case TPM_ALG_ECC:
return TPM2B_ECC_PARAMETER_Unmarshal((TPM2B_ECC_PARAMETER*)&target->ecc,
buffer, size);
#endif
#ifdef TPM_ALG_KEYEDHASH
case TPM_ALG_KEYEDHASH:
return TPM2B_SENSITIVE_DATA_Unmarshal(
(TPM2B_SENSITIVE_DATA*)&target->bits, buffer, size);
#endif
#ifdef TPM_ALG_SYMCIPHER
case TPM_ALG_SYMCIPHER:
return TPM2B_SYM_KEY_Unmarshal((TPM2B_SYM_KEY*)&target->sym, buffer,
size);
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMT_SENSITIVE_Marshal(TPMT_SENSITIVE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_PUBLIC_Marshal(&source->sensitiveType, buffer, size);
total_size += TPM2B_AUTH_Marshal(&source->authValue, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->seedValue, buffer, size);
total_size += TPMU_SENSITIVE_COMPOSITE_Marshal(&source->sensitive, buffer,
size, source->sensitiveType);
return total_size;
}
TPM_RC TPMT_SENSITIVE_Unmarshal(TPMT_SENSITIVE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_PUBLIC_Unmarshal(&target->sensitiveType, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_AUTH_Unmarshal(&target->authValue, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->seedValue, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_SENSITIVE_COMPOSITE_Unmarshal(&target->sensitive, buffer, size,
target->sensitiveType);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_SENSITIVE_Marshal(TPM2B_SENSITIVE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
total_size += TPMT_SENSITIVE_Marshal(&source->t.sensitiveArea, buffer, size);
return total_size;
}
TPM_RC TPM2B_SENSITIVE_Unmarshal(TPM2B_SENSITIVE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
result = TPMT_SENSITIVE_Unmarshal(&target->t.sensitiveArea, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SENSITIVE_CREATE_Marshal(TPMS_SENSITIVE_CREATE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_AUTH_Marshal(&source->userAuth, buffer, size);
total_size += TPM2B_SENSITIVE_DATA_Marshal(&source->data, buffer, size);
return total_size;
}
TPM_RC TPMS_SENSITIVE_CREATE_Unmarshal(TPMS_SENSITIVE_CREATE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM2B_AUTH_Unmarshal(&target->userAuth, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_SENSITIVE_DATA_Unmarshal(&target->data, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_SENSITIVE_CREATE_Marshal(TPM2B_SENSITIVE_CREATE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
total_size +=
TPMS_SENSITIVE_CREATE_Marshal(&source->t.sensitive, buffer, size);
{
BYTE* size_location = *buffer - total_size;
INT32 size_field_size = sizeof(UINT16);
UINT16 payload_size = total_size - (UINT16)size_field_size;
UINT16_Marshal(&payload_size, &size_location, &size_field_size);
}
return total_size;
}
TPM_RC TPM2B_SENSITIVE_CREATE_Unmarshal(TPM2B_SENSITIVE_CREATE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
UINT32 start_size = *size;
UINT32 struct_size;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SIZE;
}
result = TPMS_SENSITIVE_CREATE_Unmarshal(&target->t.sensitive, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
struct_size = start_size - *size - sizeof(target->t.size);
if (struct_size != target->t.size) {
return TPM_RC_SIZE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM2B_TIMEOUT_Marshal(TPM2B_TIMEOUT* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT16_Marshal(&source->t.size, buffer, size);
for (i = 0; i < source->t.size; ++i) {
total_size += BYTE_Marshal(&source->t.buffer[i], buffer, size);
}
return total_size;
}
TPM_RC TPM2B_TIMEOUT_Unmarshal(TPM2B_TIMEOUT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT16_Unmarshal(&target->t.size, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->t.size == 0) {
return TPM_RC_SUCCESS;
}
if (target->t.size > sizeof(UINT64)) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->t.size; ++i) {
result = BYTE_Unmarshal(&target->t.buffer[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_ALGORITHM_Marshal(TPMA_ALGORITHM* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal((uint32_t*)source, buffer, size);
}
TPM_RC TPMA_ALGORITHM_Unmarshal(TPMA_ALGORITHM* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal((uint32_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->reserved4_7 != 0) {
return TPM_RC_RESERVED_BITS;
}
if (target->reserved11_31 != 0) {
return TPM_RC_RESERVED_BITS;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_CC_Marshal(TPMA_CC* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal((uint32_t*)source, buffer, size);
}
TPM_RC TPMA_CC_Unmarshal(TPMA_CC* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal((uint32_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->reserved16_21 != 0) {
return TPM_RC_RESERVED_BITS;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_MEMORY_Marshal(TPMA_MEMORY* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal((uint32_t*)source, buffer, size);
}
TPM_RC TPMA_MEMORY_Unmarshal(TPMA_MEMORY* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal((uint32_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->reserved3_31 != 0) {
return TPM_RC_RESERVED_BITS;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_PERMANENT_Marshal(TPMA_PERMANENT* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal((uint32_t*)source, buffer, size);
}
TPM_RC TPMA_PERMANENT_Unmarshal(TPMA_PERMANENT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal((uint32_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->reserved3_7 != 0) {
return TPM_RC_RESERVED_BITS;
}
if (target->reserved11_31 != 0) {
return TPM_RC_RESERVED_BITS;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_SESSION_Marshal(TPMA_SESSION* source, BYTE** buffer, INT32* size) {
return uint8_t_Marshal((uint8_t*)source, buffer, size);
}
TPM_RC TPMA_SESSION_Unmarshal(TPMA_SESSION* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = uint8_t_Unmarshal((uint8_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->reserved3_4 != 0) {
return TPM_RC_RESERVED_BITS;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMA_STARTUP_CLEAR_Marshal(TPMA_STARTUP_CLEAR* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal((uint32_t*)source, buffer, size);
}
TPM_RC TPMA_STARTUP_CLEAR_Unmarshal(TPMA_STARTUP_CLEAR* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal((uint32_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->reserved4_30 != 0) {
return TPM_RC_RESERVED_BITS;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_ASYM_Marshal(TPMI_ALG_ASYM* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_ASYM_Unmarshal(TPMI_ALG_ASYM* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_ASYMMETRIC;
}
switch (*target) {
#ifdef TPM_ALG_RSA
case TPM_ALG_RSA:
#endif
#ifdef TPM_ALG_ECC
case TPM_ALG_ECC:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_ASYMMETRIC;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_RSA_DECRYPT_Marshal(TPMI_ALG_RSA_DECRYPT* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_RSA_DECRYPT_Unmarshal(TPMI_ALG_RSA_DECRYPT* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
#ifdef TPM_ALG_RSAES
case TPM_ALG_RSAES:
#endif
#ifdef TPM_ALG_OAEP
case TPM_ALG_OAEP:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_SIG_SCHEME_Marshal(TPMI_ALG_SIG_SCHEME* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_SIG_SCHEME_Unmarshal(TPMI_ALG_SIG_SCHEME* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_SCHEME;
}
switch (*target) {
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
#endif
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
#endif
#ifdef TPM_ALG_HMAC
case TPM_ALG_HMAC:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_SCHEME;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ALG_SYM_Marshal(TPMI_ALG_SYM* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ALG_SYM_Unmarshal(TPMI_ALG_SYM* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_SYMMETRIC;
}
switch (*target) {
#ifdef TPM_ALG_AES
case TPM_ALG_AES:
#endif
#ifdef TPM_ALG_SM4
case TPM_ALG_SM4:
#endif
#ifdef TPM_ALG_CAMELLIA
case TPM_ALG_CAMELLIA:
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_SYMMETRIC;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_DH_CONTEXT_Marshal(TPMI_DH_CONTEXT* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_DH_CONTEXT_Unmarshal(TPMI_DH_CONTEXT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if ((*target >= HMAC_SESSION_FIRST) && (*target <= HMAC_SESSION_LAST)) {
has_valid_value = TRUE;
}
if ((*target >= POLICY_SESSION_FIRST) && (*target <= POLICY_SESSION_LAST)) {
has_valid_value = TRUE;
}
if ((*target >= TRANSIENT_FIRST) && (*target <= TRANSIENT_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_DH_ENTITY_Marshal(TPMI_DH_ENTITY* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_DH_ENTITY_Unmarshal(TPMI_DH_ENTITY* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_RH_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
case TPM_RH_OWNER:
case TPM_RH_ENDORSEMENT:
case TPM_RH_PLATFORM:
case TPM_RH_LOCKOUT:
has_valid_value = TRUE;
break;
}
if ((*target >= TRANSIENT_FIRST) && (*target <= TRANSIENT_LAST)) {
has_valid_value = TRUE;
}
if ((*target >= PERSISTENT_FIRST) && (*target <= PERSISTENT_LAST)) {
has_valid_value = TRUE;
}
if ((*target >= NV_INDEX_FIRST) && (*target <= NV_INDEX_LAST)) {
has_valid_value = TRUE;
}
if ((*target >= PCR_FIRST) && (*target <= PCR_LAST)) {
has_valid_value = TRUE;
}
if ((*target >= TPM_RH_AUTH_00) && (*target <= TPM_RH_AUTH_FF)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_DH_OBJECT_Marshal(TPMI_DH_OBJECT* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_DH_OBJECT_Unmarshal(TPMI_DH_OBJECT* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_RH_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
if ((*target >= TRANSIENT_FIRST) && (*target <= TRANSIENT_LAST)) {
has_valid_value = TRUE;
}
if ((*target >= PERSISTENT_FIRST) && (*target <= PERSISTENT_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_DH_PCR_Marshal(TPMI_DH_PCR* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_DH_PCR_Unmarshal(TPMI_DH_PCR* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_RH_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
if ((*target >= PCR_FIRST) && (*target <= PCR_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_DH_PERSISTENT_Marshal(TPMI_DH_PERSISTENT* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_DH_PERSISTENT_Unmarshal(TPMI_DH_PERSISTENT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if ((*target >= PERSISTENT_FIRST) && (*target <= PERSISTENT_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ECC_KEY_EXCHANGE_Marshal(TPMI_ECC_KEY_EXCHANGE* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ECC_KEY_EXCHANGE_Unmarshal(TPMI_ECC_KEY_EXCHANGE* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_ALG_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_SCHEME;
}
switch (*target) {
#ifdef TPM_ALG_ECDH
case TPM_ALG_ECDH:
#endif
#ifdef TPM_ALG_ECMQV
case TPM_ALG_ECMQV:
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
#endif
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_SCHEME;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_CLEAR_Marshal(TPMI_RH_CLEAR* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_CLEAR_Unmarshal(TPMI_RH_CLEAR* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case TPM_RH_LOCKOUT:
case TPM_RH_PLATFORM:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_ENABLES_Marshal(TPMI_RH_ENABLES* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_ENABLES_Unmarshal(TPMI_RH_ENABLES* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_RH_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
case TPM_RH_OWNER:
case TPM_RH_PLATFORM:
case TPM_RH_ENDORSEMENT:
case TPM_RH_PLATFORM_NV:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_ENDORSEMENT_Marshal(TPMI_RH_ENDORSEMENT* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_ENDORSEMENT_Unmarshal(TPMI_RH_ENDORSEMENT* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_RH_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
case TPM_RH_ENDORSEMENT:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_HIERARCHY_Marshal(TPMI_RH_HIERARCHY* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_HIERARCHY_Unmarshal(TPMI_RH_HIERARCHY* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_RH_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
case TPM_RH_OWNER:
case TPM_RH_PLATFORM:
case TPM_RH_ENDORSEMENT:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_HIERARCHY_AUTH_Marshal(TPMI_RH_HIERARCHY_AUTH* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_HIERARCHY_AUTH_Unmarshal(TPMI_RH_HIERARCHY_AUTH* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case TPM_RH_OWNER:
case TPM_RH_PLATFORM:
case TPM_RH_ENDORSEMENT:
case TPM_RH_LOCKOUT:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_LOCKOUT_Marshal(TPMI_RH_LOCKOUT* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_LOCKOUT_Unmarshal(TPMI_RH_LOCKOUT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case TPM_RH_LOCKOUT:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_NV_AUTH_Marshal(TPMI_RH_NV_AUTH* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_NV_AUTH_Unmarshal(TPMI_RH_NV_AUTH* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case TPM_RH_PLATFORM:
case TPM_RH_OWNER:
has_valid_value = TRUE;
break;
}
if ((*target >= NV_INDEX_FIRST) && (*target <= NV_INDEX_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_OWNER_Marshal(TPMI_RH_OWNER* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_OWNER_Unmarshal(TPMI_RH_OWNER* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_RH_NULL) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
switch (*target) {
case TPM_RH_OWNER:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_PLATFORM_Marshal(TPMI_RH_PLATFORM* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_PLATFORM_Unmarshal(TPMI_RH_PLATFORM* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case TPM_RH_PLATFORM:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_RH_PROVISION_Marshal(TPMI_RH_PROVISION* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_RH_PROVISION_Unmarshal(TPMI_RH_PROVISION* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case TPM_RH_OWNER:
case TPM_RH_PLATFORM:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_SH_AUTH_SESSION_Marshal(TPMI_SH_AUTH_SESSION* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_SH_AUTH_SESSION_Unmarshal(TPMI_SH_AUTH_SESSION* target,
BYTE** buffer,
INT32* size,
BOOL allow_conditional_value) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if (*target == TPM_RS_PW) {
return allow_conditional_value ? TPM_RC_SUCCESS : TPM_RC_VALUE;
}
if ((*target >= HMAC_SESSION_FIRST) && (*target <= HMAC_SESSION_LAST)) {
has_valid_value = TRUE;
}
if ((*target >= POLICY_SESSION_FIRST) && (*target <= POLICY_SESSION_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_SH_HMAC_Marshal(TPMI_SH_HMAC* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_SH_HMAC_Unmarshal(TPMI_SH_HMAC* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if ((*target >= HMAC_SESSION_FIRST) && (*target <= HMAC_SESSION_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_SH_POLICY_Marshal(TPMI_SH_POLICY* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_SH_POLICY_Unmarshal(TPMI_SH_POLICY* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint32_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
if ((*target >= POLICY_SESSION_FIRST) && (*target <= POLICY_SESSION_LAST)) {
has_valid_value = TRUE;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ST_ATTEST_Marshal(TPMI_ST_ATTEST* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ST_ATTEST_Unmarshal(TPMI_ST_ATTEST* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case TPM_ST_ATTEST_CERTIFY:
case TPM_ST_ATTEST_QUOTE:
case TPM_ST_ATTEST_SESSION_AUDIT:
case TPM_ST_ATTEST_COMMAND_AUDIT:
case TPM_ST_ATTEST_TIME:
case TPM_ST_ATTEST_CREATION:
case TPM_ST_ATTEST_NV:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_ST_COMMAND_TAG_Marshal(TPMI_ST_COMMAND_TAG* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_ST_COMMAND_TAG_Unmarshal(TPMI_ST_COMMAND_TAG* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint16_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case TPM_ST_NO_SESSIONS:
case TPM_ST_SESSIONS:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_BAD_TAG;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMI_YES_NO_Marshal(TPMI_YES_NO* source, BYTE** buffer, INT32* size) {
return uint8_t_Marshal(source, buffer, size);
}
TPM_RC TPMI_YES_NO_Unmarshal(TPMI_YES_NO* target, BYTE** buffer, INT32* size) {
TPM_RC result;
BOOL has_valid_value = FALSE;
result = uint8_t_Unmarshal(target, buffer, size);
if ((result != TPM_RC_VALUE) && (result != TPM_RC_SUCCESS)) {
return result;
}
switch (*target) {
case NO:
case YES:
has_valid_value = TRUE;
break;
}
if (!has_valid_value) {
return TPM_RC_VALUE;
}
return TPM_RC_SUCCESS;
}
UINT16 TPML_ALG_Marshal(TPML_ALG* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size += TPM_ALG_ID_Marshal(&source->algorithms[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_ALG_Unmarshal(TPML_ALG* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > MAX_ALG_LIST_SIZE) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result = TPM_ALG_ID_Unmarshal(&target->algorithms[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_ALG_PROPERTY_Marshal(TPMS_ALG_PROPERTY* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM_ALG_ID_Marshal(&source->alg, buffer, size);
total_size += TPMA_ALGORITHM_Marshal(&source->algProperties, buffer, size);
return total_size;
}
TPM_RC TPMS_ALG_PROPERTY_Unmarshal(TPMS_ALG_PROPERTY* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_ALG_ID_Unmarshal(&target->alg, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMA_ALGORITHM_Unmarshal(&target->algProperties, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPML_ALG_PROPERTY_Marshal(TPML_ALG_PROPERTY* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size +=
TPMS_ALG_PROPERTY_Marshal(&source->algProperties[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_ALG_PROPERTY_Unmarshal(TPML_ALG_PROPERTY* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > MAX_CAP_ALGS) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result =
TPMS_ALG_PROPERTY_Unmarshal(&target->algProperties[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM_CC_Marshal(TPM_CC* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_CC_Unmarshal(TPM_CC* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
#ifdef TPM_CC_FIRST
if (*target == TPM_CC_FIRST) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PP_FIRST
if (*target == TPM_CC_PP_FIRST) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_UndefineSpaceSpecial
if (*target == TPM_CC_NV_UndefineSpaceSpecial) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_EvictControl
if (*target == TPM_CC_EvictControl) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_HierarchyControl
if (*target == TPM_CC_HierarchyControl) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_UndefineSpace
if (*target == TPM_CC_NV_UndefineSpace) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ChangeEPS
if (*target == TPM_CC_ChangeEPS) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ChangePPS
if (*target == TPM_CC_ChangePPS) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Clear
if (*target == TPM_CC_Clear) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ClearControl
if (*target == TPM_CC_ClearControl) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ClockSet
if (*target == TPM_CC_ClockSet) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_HierarchyChangeAuth
if (*target == TPM_CC_HierarchyChangeAuth) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_DefineSpace
if (*target == TPM_CC_NV_DefineSpace) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PCR_Allocate
if (*target == TPM_CC_PCR_Allocate) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PCR_SetAuthPolicy
if (*target == TPM_CC_PCR_SetAuthPolicy) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PP_Commands
if (*target == TPM_CC_PP_Commands) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_SetPrimaryPolicy
if (*target == TPM_CC_SetPrimaryPolicy) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_FieldUpgradeStart
if (*target == TPM_CC_FieldUpgradeStart) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ClockRateAdjust
if (*target == TPM_CC_ClockRateAdjust) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_CreatePrimary
if (*target == TPM_CC_CreatePrimary) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_GlobalWriteLock
if (*target == TPM_CC_NV_GlobalWriteLock) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PP_LAST
if (*target == TPM_CC_PP_LAST) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_GetCommandAuditDigest
if (*target == TPM_CC_GetCommandAuditDigest) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_Increment
if (*target == TPM_CC_NV_Increment) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_SetBits
if (*target == TPM_CC_NV_SetBits) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_Extend
if (*target == TPM_CC_NV_Extend) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_Write
if (*target == TPM_CC_NV_Write) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_WriteLock
if (*target == TPM_CC_NV_WriteLock) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_DictionaryAttackLockReset
if (*target == TPM_CC_DictionaryAttackLockReset) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_DictionaryAttackParameters
if (*target == TPM_CC_DictionaryAttackParameters) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_ChangeAuth
if (*target == TPM_CC_NV_ChangeAuth) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PCR_Event
if (*target == TPM_CC_PCR_Event) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PCR_Reset
if (*target == TPM_CC_PCR_Reset) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_SequenceComplete
if (*target == TPM_CC_SequenceComplete) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_SetAlgorithmSet
if (*target == TPM_CC_SetAlgorithmSet) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_SetCommandCodeAuditStatus
if (*target == TPM_CC_SetCommandCodeAuditStatus) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_FieldUpgradeData
if (*target == TPM_CC_FieldUpgradeData) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_IncrementalSelfTest
if (*target == TPM_CC_IncrementalSelfTest) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_SelfTest
if (*target == TPM_CC_SelfTest) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Startup
if (*target == TPM_CC_Startup) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Shutdown
if (*target == TPM_CC_Shutdown) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_StirRandom
if (*target == TPM_CC_StirRandom) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ActivateCredential
if (*target == TPM_CC_ActivateCredential) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Certify
if (*target == TPM_CC_Certify) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyNV
if (*target == TPM_CC_PolicyNV) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_CertifyCreation
if (*target == TPM_CC_CertifyCreation) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Duplicate
if (*target == TPM_CC_Duplicate) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_GetTime
if (*target == TPM_CC_GetTime) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_GetSessionAuditDigest
if (*target == TPM_CC_GetSessionAuditDigest) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_Read
if (*target == TPM_CC_NV_Read) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_ReadLock
if (*target == TPM_CC_NV_ReadLock) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ObjectChangeAuth
if (*target == TPM_CC_ObjectChangeAuth) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicySecret
if (*target == TPM_CC_PolicySecret) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Rewrap
if (*target == TPM_CC_Rewrap) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Create
if (*target == TPM_CC_Create) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ECDH_ZGen
if (*target == TPM_CC_ECDH_ZGen) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_HMAC
if (*target == TPM_CC_HMAC) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Import
if (*target == TPM_CC_Import) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Load
if (*target == TPM_CC_Load) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Quote
if (*target == TPM_CC_Quote) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_RSA_Decrypt
if (*target == TPM_CC_RSA_Decrypt) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_HMAC_Start
if (*target == TPM_CC_HMAC_Start) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_SequenceUpdate
if (*target == TPM_CC_SequenceUpdate) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Sign
if (*target == TPM_CC_Sign) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Unseal
if (*target == TPM_CC_Unseal) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicySigned
if (*target == TPM_CC_PolicySigned) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ContextLoad
if (*target == TPM_CC_ContextLoad) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ContextSave
if (*target == TPM_CC_ContextSave) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ECDH_KeyGen
if (*target == TPM_CC_ECDH_KeyGen) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_EncryptDecrypt
if (*target == TPM_CC_EncryptDecrypt) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_FlushContext
if (*target == TPM_CC_FlushContext) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_LoadExternal
if (*target == TPM_CC_LoadExternal) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_MakeCredential
if (*target == TPM_CC_MakeCredential) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_ReadPublic
if (*target == TPM_CC_NV_ReadPublic) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyAuthorize
if (*target == TPM_CC_PolicyAuthorize) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyAuthValue
if (*target == TPM_CC_PolicyAuthValue) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyCommandCode
if (*target == TPM_CC_PolicyCommandCode) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyCounterTimer
if (*target == TPM_CC_PolicyCounterTimer) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyCpHash
if (*target == TPM_CC_PolicyCpHash) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyLocality
if (*target == TPM_CC_PolicyLocality) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyNameHash
if (*target == TPM_CC_PolicyNameHash) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyOR
if (*target == TPM_CC_PolicyOR) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyTicket
if (*target == TPM_CC_PolicyTicket) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ReadPublic
if (*target == TPM_CC_ReadPublic) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_RSA_Encrypt
if (*target == TPM_CC_RSA_Encrypt) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_StartAuthSession
if (*target == TPM_CC_StartAuthSession) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_VerifySignature
if (*target == TPM_CC_VerifySignature) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ECC_Parameters
if (*target == TPM_CC_ECC_Parameters) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_FirmwareRead
if (*target == TPM_CC_FirmwareRead) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_GetCapability
if (*target == TPM_CC_GetCapability) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_GetRandom
if (*target == TPM_CC_GetRandom) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_GetTestResult
if (*target == TPM_CC_GetTestResult) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Hash
if (*target == TPM_CC_Hash) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PCR_Read
if (*target == TPM_CC_PCR_Read) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyPCR
if (*target == TPM_CC_PolicyPCR) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyRestart
if (*target == TPM_CC_PolicyRestart) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ReadClock
if (*target == TPM_CC_ReadClock) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PCR_Extend
if (*target == TPM_CC_PCR_Extend) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PCR_SetAuthValue
if (*target == TPM_CC_PCR_SetAuthValue) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_NV_Certify
if (*target == TPM_CC_NV_Certify) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_EventSequenceComplete
if (*target == TPM_CC_EventSequenceComplete) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_HashSequenceStart
if (*target == TPM_CC_HashSequenceStart) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyPhysicalPresence
if (*target == TPM_CC_PolicyPhysicalPresence) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyDuplicationSelect
if (*target == TPM_CC_PolicyDuplicationSelect) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyGetDigest
if (*target == TPM_CC_PolicyGetDigest) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_TestParms
if (*target == TPM_CC_TestParms) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_Commit
if (*target == TPM_CC_Commit) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyPassword
if (*target == TPM_CC_PolicyPassword) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_ZGen_2Phase
if (*target == TPM_CC_ZGen_2Phase) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_EC_Ephemeral
if (*target == TPM_CC_EC_Ephemeral) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_PolicyNvWritten
if (*target == TPM_CC_PolicyNvWritten) {
return TPM_RC_SUCCESS;
}
#endif
#ifdef TPM_CC_LAST
if (*target == TPM_CC_LAST) {
return TPM_RC_SUCCESS;
}
#endif
return TPM_RC_COMMAND_CODE;
}
UINT16 TPML_CC_Marshal(TPML_CC* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size += TPM_CC_Marshal(&source->commandCodes[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_CC_Unmarshal(TPML_CC* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > MAX_CAP_CC) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result = TPM_CC_Unmarshal(&target->commandCodes[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPML_CCA_Marshal(TPML_CCA* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size += TPMA_CC_Marshal(&source->commandAttributes[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_CCA_Unmarshal(TPML_CCA* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > MAX_CAP_CC) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result = TPMA_CC_Unmarshal(&target->commandAttributes[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPML_DIGEST_Marshal(TPML_DIGEST* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size += TPM2B_DIGEST_Marshal(&source->digests[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_DIGEST_Unmarshal(TPML_DIGEST* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > 8) {
return TPM_RC_SIZE;
}
if (target->count < 2) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result = TPM2B_DIGEST_Unmarshal(&target->digests[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_HA_Marshal(TPMU_HA* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
INT32 i;
UINT16 total_size = 0;
switch (selector) {
#ifdef TPM_ALG_SHA
case TPM_ALG_SHA:
for (i = 0; i < SHA_DIGEST_SIZE; ++i) {
total_size += BYTE_Marshal(&source->sha[i], buffer, size);
}
return total_size;
#endif
#ifdef TPM_ALG_SHA1
case TPM_ALG_SHA1:
for (i = 0; i < SHA1_DIGEST_SIZE; ++i) {
total_size += BYTE_Marshal(&source->sha1[i], buffer, size);
}
return total_size;
#endif
#ifdef TPM_ALG_SHA256
case TPM_ALG_SHA256:
for (i = 0; i < SHA256_DIGEST_SIZE; ++i) {
total_size += BYTE_Marshal(&source->sha256[i], buffer, size);
}
return total_size;
#endif
#ifdef TPM_ALG_SHA384
case TPM_ALG_SHA384:
for (i = 0; i < SHA384_DIGEST_SIZE; ++i) {
total_size += BYTE_Marshal(&source->sha384[i], buffer, size);
}
return total_size;
#endif
#ifdef TPM_ALG_SHA512
case TPM_ALG_SHA512:
for (i = 0; i < SHA512_DIGEST_SIZE; ++i) {
total_size += BYTE_Marshal(&source->sha512[i], buffer, size);
}
return total_size;
#endif
#ifdef TPM_ALG_SM3_256
case TPM_ALG_SM3_256:
for (i = 0; i < SM3_256_DIGEST_SIZE; ++i) {
total_size += BYTE_Marshal(&source->sm3_256[i], buffer, size);
}
return total_size;
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_HA_Unmarshal(TPMU_HA* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
INT32 i;
TPM_RC result = TPM_RC_SUCCESS;
#ifdef TPM_ALG_SHA
case TPM_ALG_SHA:
for (i = 0; i < SHA_DIGEST_SIZE; ++i) {
result = BYTE_Unmarshal(&target->sha[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_SHA1
case TPM_ALG_SHA1:
for (i = 0; i < SHA1_DIGEST_SIZE; ++i) {
result = BYTE_Unmarshal(&target->sha1[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_SHA256
case TPM_ALG_SHA256:
for (i = 0; i < SHA256_DIGEST_SIZE; ++i) {
result = BYTE_Unmarshal(&target->sha256[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_SHA384
case TPM_ALG_SHA384:
for (i = 0; i < SHA384_DIGEST_SIZE; ++i) {
result = BYTE_Unmarshal(&target->sha384[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_SHA512
case TPM_ALG_SHA512:
for (i = 0; i < SHA512_DIGEST_SIZE; ++i) {
result = BYTE_Unmarshal(&target->sha512[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_SM3_256
case TPM_ALG_SM3_256:
for (i = 0; i < SM3_256_DIGEST_SIZE; ++i) {
result = BYTE_Unmarshal(&target->sm3_256[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMT_HA_Marshal(TPMT_HA* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_HASH_Marshal(&source->hashAlg, buffer, size);
total_size += TPMU_HA_Marshal(&source->digest, buffer, size, source->hashAlg);
return total_size;
}
TPM_RC TPMT_HA_Unmarshal(TPMT_HA* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = TPMI_ALG_HASH_Unmarshal(&target->hashAlg, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_HA_Unmarshal(&target->digest, buffer, size, target->hashAlg);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPML_DIGEST_VALUES_Marshal(TPML_DIGEST_VALUES* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size += TPMT_HA_Marshal(&source->digests[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_DIGEST_VALUES_Unmarshal(TPML_DIGEST_VALUES* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > HASH_COUNT) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result = TPMT_HA_Unmarshal(&target->digests[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM_ECC_CURVE_Marshal(TPM_ECC_CURVE* source,
BYTE** buffer,
INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPM_ECC_CURVE_Unmarshal(TPM_ECC_CURVE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = uint16_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_ECC_NONE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ECC_NIST_P192) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ECC_NIST_P224) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ECC_NIST_P256) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ECC_NIST_P384) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ECC_NIST_P521) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ECC_BN_P256) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ECC_BN_P638) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ECC_SM2_P256) {
return TPM_RC_SUCCESS;
}
return TPM_RC_CURVE;
}
UINT16 TPML_ECC_CURVE_Marshal(TPML_ECC_CURVE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size += TPM_ECC_CURVE_Marshal(&source->eccCurves[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_ECC_CURVE_Unmarshal(TPML_ECC_CURVE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > MAX_ECC_CURVES) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result = TPM_ECC_CURVE_Unmarshal(&target->eccCurves[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM_HANDLE_Marshal(TPM_HANDLE* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_HANDLE_Unmarshal(TPM_HANDLE* target, BYTE** buffer, INT32* size) {
return uint32_t_Unmarshal(target, buffer, size);
}
UINT16 TPML_HANDLE_Marshal(TPML_HANDLE* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size += TPM_HANDLE_Marshal(&source->handle[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_HANDLE_Unmarshal(TPML_HANDLE* target, BYTE** buffer, INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > MAX_CAP_HANDLES) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result = TPM_HANDLE_Unmarshal(&target->handle[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPM_PT_Marshal(TPM_PT* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_PT_Unmarshal(TPM_PT* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_PT_NONE) {
return TPM_RC_SUCCESS;
}
if (*target == PT_GROUP) {
return TPM_RC_SUCCESS;
}
if (*target == PT_FIXED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_FAMILY_INDICATOR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_LEVEL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_REVISION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_DAY_OF_YEAR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_YEAR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_MANUFACTURER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_VENDOR_STRING_1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_VENDOR_STRING_2) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_VENDOR_STRING_3) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_VENDOR_STRING_4) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_VENDOR_TPM_TYPE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_FIRMWARE_VERSION_1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_FIRMWARE_VERSION_2) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_INPUT_BUFFER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_TRANSIENT_MIN) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_PERSISTENT_MIN) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_LOADED_MIN) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_ACTIVE_SESSIONS_MAX) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_COUNT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_SELECT_MIN) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_CONTEXT_GAP_MAX) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_NV_COUNTERS_MAX) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_NV_INDEX_MAX) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_MEMORY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_CLOCK_UPDATE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_CONTEXT_HASH) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_CONTEXT_SYM) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_CONTEXT_SYM_SIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_ORDERLY_COUNT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_MAX_COMMAND_SIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_MAX_RESPONSE_SIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_MAX_DIGEST) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_MAX_OBJECT_CONTEXT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_MAX_SESSION_CONTEXT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PS_FAMILY_INDICATOR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PS_LEVEL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PS_REVISION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PS_DAY_OF_YEAR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PS_YEAR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_SPLIT_MAX) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_TOTAL_COMMANDS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_LIBRARY_COMMANDS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_VENDOR_COMMANDS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_NV_BUFFER_MAX) {
return TPM_RC_SUCCESS;
}
if (*target == PT_VAR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PERMANENT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_STARTUP_CLEAR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_NV_INDEX) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_LOADED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_LOADED_AVAIL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_ACTIVE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_ACTIVE_AVAIL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_TRANSIENT_AVAIL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_PERSISTENT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_HR_PERSISTENT_AVAIL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_NV_COUNTERS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_NV_COUNTERS_AVAIL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_ALGORITHM_SET) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_LOADED_CURVES) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_LOCKOUT_COUNTER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_MAX_AUTH_FAIL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_LOCKOUT_INTERVAL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_LOCKOUT_RECOVERY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_NV_WRITE_RECOVERY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_AUDIT_COUNTER_0) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_AUDIT_COUNTER_1) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPMS_TAGGED_PCR_SELECT_Marshal(TPMS_TAGGED_PCR_SELECT* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += TPM_PT_Marshal(&source->tag, buffer, size);
total_size += UINT8_Marshal(&source->sizeofSelect, buffer, size);
for (i = 0; i < source->sizeofSelect; ++i) {
total_size += BYTE_Marshal(&source->pcrSelect[i], buffer, size);
}
return total_size;
}
TPM_RC TPMS_TAGGED_PCR_SELECT_Unmarshal(TPMS_TAGGED_PCR_SELECT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = TPM_PT_Unmarshal(&target->tag, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT8_Unmarshal(&target->sizeofSelect, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->sizeofSelect > PCR_SELECT_MAX) {
return TPM_RC_VALUE;
}
if (target->sizeofSelect < PCR_SELECT_MIN) {
return TPM_RC_VALUE;
}
for (i = 0; i < target->sizeofSelect; ++i) {
result = BYTE_Unmarshal(&target->pcrSelect[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPML_TAGGED_PCR_PROPERTY_Marshal(TPML_TAGGED_PCR_PROPERTY* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size +=
TPMS_TAGGED_PCR_SELECT_Marshal(&source->pcrProperty[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_TAGGED_PCR_PROPERTY_Unmarshal(TPML_TAGGED_PCR_PROPERTY* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > MAX_PCR_PROPERTIES) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result =
TPMS_TAGGED_PCR_SELECT_Unmarshal(&target->pcrProperty[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_TAGGED_PROPERTY_Marshal(TPMS_TAGGED_PROPERTY* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM_PT_Marshal(&source->property, buffer, size);
total_size += UINT32_Marshal(&source->value, buffer, size);
return total_size;
}
TPM_RC TPMS_TAGGED_PROPERTY_Unmarshal(TPMS_TAGGED_PROPERTY* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_PT_Unmarshal(&target->property, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT32_Unmarshal(&target->value, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPML_TAGGED_TPM_PROPERTY_Marshal(TPML_TAGGED_TPM_PROPERTY* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT32_Marshal(&source->count, buffer, size);
for (i = 0; i < source->count; ++i) {
total_size +=
TPMS_TAGGED_PROPERTY_Marshal(&source->tpmProperty[i], buffer, size);
}
return total_size;
}
TPM_RC TPML_TAGGED_TPM_PROPERTY_Unmarshal(TPML_TAGGED_TPM_PROPERTY* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT32_Unmarshal(&target->count, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->count > MAX_TPM_PROPERTIES) {
return TPM_RC_SIZE;
}
for (i = 0; i < target->count; ++i) {
result =
TPMS_TAGGED_PROPERTY_Unmarshal(&target->tpmProperty[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_ALGORITHM_DESCRIPTION_Marshal(TPMS_ALGORITHM_DESCRIPTION* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM_ALG_ID_Marshal(&source->alg, buffer, size);
total_size += TPMA_ALGORITHM_Marshal(&source->attributes, buffer, size);
return total_size;
}
TPM_RC TPMS_ALGORITHM_DESCRIPTION_Unmarshal(TPMS_ALGORITHM_DESCRIPTION* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_ALG_ID_Unmarshal(&target->alg, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMA_ALGORITHM_Unmarshal(&target->attributes, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_ALGORITHM_DETAIL_ECC_Marshal(TPMS_ALGORITHM_DETAIL_ECC* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM_ECC_CURVE_Marshal(&source->curveID, buffer, size);
total_size += UINT16_Marshal(&source->keySize, buffer, size);
total_size += TPMT_KDF_SCHEME_Marshal(&source->kdf, buffer, size);
total_size += TPMT_ECC_SCHEME_Marshal(&source->sign, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->p, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->a, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->b, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->gX, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->gY, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->n, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->h, buffer, size);
return total_size;
}
TPM_RC TPMS_ALGORITHM_DETAIL_ECC_Unmarshal(TPMS_ALGORITHM_DETAIL_ECC* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_ECC_CURVE_Unmarshal(&target->curveID, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT16_Unmarshal(&target->keySize, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMT_KDF_SCHEME_Unmarshal(&target->kdf, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMT_ECC_SCHEME_Unmarshal(&target->sign, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->p, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->a, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->b, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->gX, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->gY, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->n, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->h, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 UINT64_Marshal(UINT64* source, BYTE** buffer, INT32* size) {
return uint64_t_Marshal(source, buffer, size);
}
TPM_RC UINT64_Unmarshal(UINT64* target, BYTE** buffer, INT32* size) {
return uint64_t_Unmarshal(target, buffer, size);
}
UINT16 TPM_GENERATED_Marshal(TPM_GENERATED* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_GENERATED_Unmarshal(TPM_GENERATED* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_GENERATED_VALUE) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPMS_CREATION_INFO_Marshal(TPMS_CREATION_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_NAME_Marshal(&source->objectName, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->creationHash, buffer, size);
return total_size;
}
TPM_RC TPMS_CREATION_INFO_Unmarshal(TPMS_CREATION_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM2B_NAME_Unmarshal(&target->objectName, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->creationHash, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_COMMAND_AUDIT_INFO_Marshal(TPMS_COMMAND_AUDIT_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += UINT64_Marshal(&source->auditCounter, buffer, size);
total_size += TPM_ALG_ID_Marshal(&source->digestAlg, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->auditDigest, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->commandDigest, buffer, size);
return total_size;
}
TPM_RC TPMS_COMMAND_AUDIT_INFO_Unmarshal(TPMS_COMMAND_AUDIT_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = UINT64_Unmarshal(&target->auditCounter, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM_ALG_ID_Unmarshal(&target->digestAlg, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->auditDigest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->commandDigest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_QUOTE_INFO_Marshal(TPMS_QUOTE_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPML_PCR_SELECTION_Marshal(&source->pcrSelect, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->pcrDigest, buffer, size);
return total_size;
}
TPM_RC TPMS_QUOTE_INFO_Unmarshal(TPMS_QUOTE_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPML_PCR_SELECTION_Unmarshal(&target->pcrSelect, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->pcrDigest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_CERTIFY_INFO_Marshal(TPMS_CERTIFY_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_NAME_Marshal(&source->name, buffer, size);
total_size += TPM2B_NAME_Marshal(&source->qualifiedName, buffer, size);
return total_size;
}
TPM_RC TPMS_CERTIFY_INFO_Unmarshal(TPMS_CERTIFY_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM2B_NAME_Unmarshal(&target->name, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_NAME_Unmarshal(&target->qualifiedName, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SESSION_AUDIT_INFO_Marshal(TPMS_SESSION_AUDIT_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_YES_NO_Marshal(&source->exclusiveSession, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->sessionDigest, buffer, size);
return total_size;
}
TPM_RC TPMS_SESSION_AUDIT_INFO_Unmarshal(TPMS_SESSION_AUDIT_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_YES_NO_Unmarshal(&target->exclusiveSession, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->sessionDigest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_CLOCK_INFO_Marshal(TPMS_CLOCK_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += UINT64_Marshal(&source->clock, buffer, size);
total_size += UINT32_Marshal(&source->resetCount, buffer, size);
total_size += UINT32_Marshal(&source->restartCount, buffer, size);
total_size += TPMI_YES_NO_Marshal(&source->safe, buffer, size);
return total_size;
}
TPM_RC TPMS_CLOCK_INFO_Unmarshal(TPMS_CLOCK_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = UINT64_Unmarshal(&target->clock, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT32_Unmarshal(&target->resetCount, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT32_Unmarshal(&target->restartCount, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_YES_NO_Unmarshal(&target->safe, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_TIME_INFO_Marshal(TPMS_TIME_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += UINT64_Marshal(&source->time, buffer, size);
total_size += TPMS_CLOCK_INFO_Marshal(&source->clockInfo, buffer, size);
return total_size;
}
TPM_RC TPMS_TIME_INFO_Unmarshal(TPMS_TIME_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = UINT64_Unmarshal(&target->time, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMS_CLOCK_INFO_Unmarshal(&target->clockInfo, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_TIME_ATTEST_INFO_Marshal(TPMS_TIME_ATTEST_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMS_TIME_INFO_Marshal(&source->time, buffer, size);
total_size += UINT64_Marshal(&source->firmwareVersion, buffer, size);
return total_size;
}
TPM_RC TPMS_TIME_ATTEST_INFO_Unmarshal(TPMS_TIME_ATTEST_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMS_TIME_INFO_Unmarshal(&target->time, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT64_Unmarshal(&target->firmwareVersion, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_NV_CERTIFY_INFO_Marshal(TPMS_NV_CERTIFY_INFO* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_NAME_Marshal(&source->indexName, buffer, size);
total_size += UINT16_Marshal(&source->offset, buffer, size);
total_size += TPM2B_MAX_NV_BUFFER_Marshal(&source->nvContents, buffer, size);
return total_size;
}
TPM_RC TPMS_NV_CERTIFY_INFO_Unmarshal(TPMS_NV_CERTIFY_INFO* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM2B_NAME_Unmarshal(&target->indexName, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT16_Unmarshal(&target->offset, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_MAX_NV_BUFFER_Unmarshal(&target->nvContents, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_ATTEST_Marshal(TPMU_ATTEST* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
case TPM_ST_ATTEST_CERTIFY:
return TPMS_CERTIFY_INFO_Marshal((TPMS_CERTIFY_INFO*)&source->certify,
buffer, size);
case TPM_ST_ATTEST_CREATION:
return TPMS_CREATION_INFO_Marshal((TPMS_CREATION_INFO*)&source->creation,
buffer, size);
case TPM_ST_ATTEST_QUOTE:
return TPMS_QUOTE_INFO_Marshal((TPMS_QUOTE_INFO*)&source->quote, buffer,
size);
case TPM_ST_ATTEST_COMMAND_AUDIT:
return TPMS_COMMAND_AUDIT_INFO_Marshal(
(TPMS_COMMAND_AUDIT_INFO*)&source->commandAudit, buffer, size);
case TPM_ST_ATTEST_SESSION_AUDIT:
return TPMS_SESSION_AUDIT_INFO_Marshal(
(TPMS_SESSION_AUDIT_INFO*)&source->sessionAudit, buffer, size);
case TPM_ST_ATTEST_TIME:
return TPMS_TIME_ATTEST_INFO_Marshal(
(TPMS_TIME_ATTEST_INFO*)&source->time, buffer, size);
case TPM_ST_ATTEST_NV:
return TPMS_NV_CERTIFY_INFO_Marshal((TPMS_NV_CERTIFY_INFO*)&source->nv,
buffer, size);
}
return 0;
}
TPM_RC TPMU_ATTEST_Unmarshal(TPMU_ATTEST* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
case TPM_ST_ATTEST_CERTIFY:
return TPMS_CERTIFY_INFO_Unmarshal((TPMS_CERTIFY_INFO*)&target->certify,
buffer, size);
case TPM_ST_ATTEST_CREATION:
return TPMS_CREATION_INFO_Unmarshal(
(TPMS_CREATION_INFO*)&target->creation, buffer, size);
case TPM_ST_ATTEST_QUOTE:
return TPMS_QUOTE_INFO_Unmarshal((TPMS_QUOTE_INFO*)&target->quote, buffer,
size);
case TPM_ST_ATTEST_COMMAND_AUDIT:
return TPMS_COMMAND_AUDIT_INFO_Unmarshal(
(TPMS_COMMAND_AUDIT_INFO*)&target->commandAudit, buffer, size);
case TPM_ST_ATTEST_SESSION_AUDIT:
return TPMS_SESSION_AUDIT_INFO_Unmarshal(
(TPMS_SESSION_AUDIT_INFO*)&target->sessionAudit, buffer, size);
case TPM_ST_ATTEST_TIME:
return TPMS_TIME_ATTEST_INFO_Unmarshal(
(TPMS_TIME_ATTEST_INFO*)&target->time, buffer, size);
case TPM_ST_ATTEST_NV:
return TPMS_NV_CERTIFY_INFO_Unmarshal((TPMS_NV_CERTIFY_INFO*)&target->nv,
buffer, size);
}
return TPM_RC_SELECTOR;
}
UINT16 TPMS_ATTEST_Marshal(TPMS_ATTEST* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += TPM_GENERATED_Marshal(&source->magic, buffer, size);
total_size += TPMI_ST_ATTEST_Marshal(&source->type, buffer, size);
total_size += TPM2B_NAME_Marshal(&source->qualifiedSigner, buffer, size);
total_size += TPM2B_DATA_Marshal(&source->extraData, buffer, size);
total_size += TPMS_CLOCK_INFO_Marshal(&source->clockInfo, buffer, size);
total_size += UINT64_Marshal(&source->firmwareVersion, buffer, size);
total_size +=
TPMU_ATTEST_Marshal(&source->attested, buffer, size, source->type);
return total_size;
}
TPM_RC TPMS_ATTEST_Unmarshal(TPMS_ATTEST* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = TPM_GENERATED_Unmarshal(&target->magic, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_ST_ATTEST_Unmarshal(&target->type, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_NAME_Unmarshal(&target->qualifiedSigner, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DATA_Unmarshal(&target->extraData, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMS_CLOCK_INFO_Unmarshal(&target->clockInfo, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = UINT64_Unmarshal(&target->firmwareVersion, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_ATTEST_Unmarshal(&target->attested, buffer, size, target->type);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_AUTH_COMMAND_Marshal(TPMS_AUTH_COMMAND* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size +=
TPMI_SH_AUTH_SESSION_Marshal(&source->sessionHandle, buffer, size);
total_size += TPM2B_NONCE_Marshal(&source->nonce, buffer, size);
total_size += TPMA_SESSION_Marshal(&source->sessionAttributes, buffer, size);
total_size += TPM2B_AUTH_Marshal(&source->hmac, buffer, size);
return total_size;
}
TPM_RC TPMS_AUTH_COMMAND_Unmarshal(TPMS_AUTH_COMMAND* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_SH_AUTH_SESSION_Unmarshal(&target->sessionHandle, buffer, size,
TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_NONCE_Unmarshal(&target->nonce, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMA_SESSION_Unmarshal(&target->sessionAttributes, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_AUTH_Unmarshal(&target->hmac, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_AUTH_RESPONSE_Marshal(TPMS_AUTH_RESPONSE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_NONCE_Marshal(&source->nonce, buffer, size);
total_size += TPMA_SESSION_Marshal(&source->sessionAttributes, buffer, size);
total_size += TPM2B_AUTH_Marshal(&source->hmac, buffer, size);
return total_size;
}
TPM_RC TPMS_AUTH_RESPONSE_Unmarshal(TPMS_AUTH_RESPONSE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM2B_NONCE_Unmarshal(&target->nonce, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMA_SESSION_Unmarshal(&target->sessionAttributes, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_AUTH_Unmarshal(&target->hmac, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM_CAP_Marshal(TPM_CAP* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_CAP_Unmarshal(TPM_CAP* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_CAP_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_ALGS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_HANDLES) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_COMMANDS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_PP_COMMANDS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_AUDIT_COMMANDS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_PCRS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_TPM_PROPERTIES) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_PCR_PROPERTIES) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_ECC_CURVES) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CAP_VENDOR_PROPERTY) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPMU_CAPABILITIES_Marshal(TPMU_CAPABILITIES* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
case TPM_CAP_ALGS:
return TPML_ALG_PROPERTY_Marshal((TPML_ALG_PROPERTY*)&source->algorithms,
buffer, size);
case TPM_CAP_HANDLES:
return TPML_HANDLE_Marshal((TPML_HANDLE*)&source->handles, buffer, size);
case TPM_CAP_COMMANDS:
return TPML_CCA_Marshal((TPML_CCA*)&source->command, buffer, size);
case TPM_CAP_PP_COMMANDS:
return TPML_CC_Marshal((TPML_CC*)&source->ppCommands, buffer, size);
case TPM_CAP_AUDIT_COMMANDS:
return TPML_CC_Marshal((TPML_CC*)&source->auditCommands, buffer, size);
case TPM_CAP_PCRS:
return TPML_PCR_SELECTION_Marshal(
(TPML_PCR_SELECTION*)&source->assignedPCR, buffer, size);
case TPM_CAP_TPM_PROPERTIES:
return TPML_TAGGED_TPM_PROPERTY_Marshal(
(TPML_TAGGED_TPM_PROPERTY*)&source->tpmProperties, buffer, size);
case TPM_CAP_PCR_PROPERTIES:
return TPML_TAGGED_PCR_PROPERTY_Marshal(
(TPML_TAGGED_PCR_PROPERTY*)&source->pcrProperties, buffer, size);
case TPM_CAP_ECC_CURVES:
return TPML_ECC_CURVE_Marshal((TPML_ECC_CURVE*)&source->eccCurves, buffer,
size);
}
return 0;
}
TPM_RC TPMU_CAPABILITIES_Unmarshal(TPMU_CAPABILITIES* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
case TPM_CAP_ALGS:
return TPML_ALG_PROPERTY_Unmarshal(
(TPML_ALG_PROPERTY*)&target->algorithms, buffer, size);
case TPM_CAP_HANDLES:
return TPML_HANDLE_Unmarshal((TPML_HANDLE*)&target->handles, buffer,
size);
case TPM_CAP_COMMANDS:
return TPML_CCA_Unmarshal((TPML_CCA*)&target->command, buffer, size);
case TPM_CAP_PP_COMMANDS:
return TPML_CC_Unmarshal((TPML_CC*)&target->ppCommands, buffer, size);
case TPM_CAP_AUDIT_COMMANDS:
return TPML_CC_Unmarshal((TPML_CC*)&target->auditCommands, buffer, size);
case TPM_CAP_PCRS:
return TPML_PCR_SELECTION_Unmarshal(
(TPML_PCR_SELECTION*)&target->assignedPCR, buffer, size);
case TPM_CAP_TPM_PROPERTIES:
return TPML_TAGGED_TPM_PROPERTY_Unmarshal(
(TPML_TAGGED_TPM_PROPERTY*)&target->tpmProperties, buffer, size);
case TPM_CAP_PCR_PROPERTIES:
return TPML_TAGGED_PCR_PROPERTY_Unmarshal(
(TPML_TAGGED_PCR_PROPERTY*)&target->pcrProperties, buffer, size);
case TPM_CAP_ECC_CURVES:
return TPML_ECC_CURVE_Unmarshal((TPML_ECC_CURVE*)&target->eccCurves,
buffer, size);
}
return TPM_RC_SELECTOR;
}
UINT16 TPMS_CAPABILITY_DATA_Marshal(TPMS_CAPABILITY_DATA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM_CAP_Marshal(&source->capability, buffer, size);
total_size += TPMU_CAPABILITIES_Marshal(&source->data, buffer, size,
source->capability);
return total_size;
}
TPM_RC TPMS_CAPABILITY_DATA_Unmarshal(TPMS_CAPABILITY_DATA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_CAP_Unmarshal(&target->capability, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_CAPABILITIES_Unmarshal(&target->data, buffer, size,
target->capability);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_CONTEXT_Marshal(TPMS_CONTEXT* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += UINT64_Marshal(&source->sequence, buffer, size);
total_size += TPMI_DH_CONTEXT_Marshal(&source->savedHandle, buffer, size);
total_size += TPMI_RH_HIERARCHY_Marshal(&source->hierarchy, buffer, size);
total_size += TPM2B_CONTEXT_DATA_Marshal(&source->contextBlob, buffer, size);
return total_size;
}
TPM_RC TPMS_CONTEXT_Unmarshal(TPMS_CONTEXT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = UINT64_Unmarshal(&target->sequence, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_DH_CONTEXT_Unmarshal(&target->savedHandle, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_RH_HIERARCHY_Unmarshal(&target->hierarchy, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_CONTEXT_DATA_Unmarshal(&target->contextBlob, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_CONTEXT_DATA_Marshal(TPMS_CONTEXT_DATA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_DIGEST_Marshal(&source->integrity, buffer, size);
total_size +=
TPM2B_CONTEXT_SENSITIVE_Marshal(&source->encrypted, buffer, size);
return total_size;
}
TPM_RC TPMS_CONTEXT_DATA_Unmarshal(TPMS_CONTEXT_DATA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM2B_DIGEST_Unmarshal(&target->integrity, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_CONTEXT_SENSITIVE_Unmarshal(&target->encrypted, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_PCR_SELECT_Marshal(TPMS_PCR_SELECT* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
INT32 i;
total_size += UINT8_Marshal(&source->sizeofSelect, buffer, size);
for (i = 0; i < source->sizeofSelect; ++i) {
total_size += BYTE_Marshal(&source->pcrSelect[i], buffer, size);
}
return total_size;
}
TPM_RC TPMS_PCR_SELECT_Unmarshal(TPMS_PCR_SELECT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
INT32 i;
result = UINT8_Unmarshal(&target->sizeofSelect, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (target->sizeofSelect > PCR_SELECT_MAX) {
return TPM_RC_VALUE;
}
if (target->sizeofSelect < PCR_SELECT_MIN) {
return TPM_RC_VALUE;
}
for (i = 0; i < target->sizeofSelect; ++i) {
result = BYTE_Unmarshal(&target->pcrSelect[i], buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SIGNATURE_ECC_Marshal(TPMS_SIGNATURE_ECC* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_HASH_Marshal(&source->hash, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->signatureR, buffer, size);
total_size += TPM2B_ECC_PARAMETER_Marshal(&source->signatureS, buffer, size);
return total_size;
}
TPM_RC TPMS_SIGNATURE_ECC_Unmarshal(TPMS_SIGNATURE_ECC* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_HASH_Unmarshal(&target->hash, buffer, size, FALSE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->signatureR, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_ECC_PARAMETER_Unmarshal(&target->signatureS, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SIGNATURE_ECDAA_Marshal(TPMS_SIGNATURE_ECDAA* source,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_ECC_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIGNATURE_ECDAA_Unmarshal(TPMS_SIGNATURE_ECDAA* target,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_ECC_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIGNATURE_ECDSA_Marshal(TPMS_SIGNATURE_ECDSA* source,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_ECC_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIGNATURE_ECDSA_Unmarshal(TPMS_SIGNATURE_ECDSA* target,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_ECC_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIGNATURE_ECSCHNORR_Marshal(TPMS_SIGNATURE_ECSCHNORR* source,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_ECC_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIGNATURE_ECSCHNORR_Unmarshal(TPMS_SIGNATURE_ECSCHNORR* target,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_ECC_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIGNATURE_RSA_Marshal(TPMS_SIGNATURE_RSA* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_HASH_Marshal(&source->hash, buffer, size);
total_size += TPM2B_PUBLIC_KEY_RSA_Marshal(&source->sig, buffer, size);
return total_size;
}
TPM_RC TPMS_SIGNATURE_RSA_Unmarshal(TPMS_SIGNATURE_RSA* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_HASH_Unmarshal(&target->hash, buffer, size, FALSE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_PUBLIC_KEY_RSA_Unmarshal(&target->sig, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMS_SIGNATURE_RSAPSS_Marshal(TPMS_SIGNATURE_RSAPSS* source,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_RSA_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIGNATURE_RSAPSS_Unmarshal(TPMS_SIGNATURE_RSAPSS* target,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_RSA_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIGNATURE_RSASSA_Marshal(TPMS_SIGNATURE_RSASSA* source,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_RSA_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIGNATURE_RSASSA_Unmarshal(TPMS_SIGNATURE_RSASSA* target,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_RSA_Unmarshal(target, buffer, size);
}
UINT16 TPMS_SIGNATURE_SM2_Marshal(TPMS_SIGNATURE_SM2* source,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_ECC_Marshal(source, buffer, size);
}
TPM_RC TPMS_SIGNATURE_SM2_Unmarshal(TPMS_SIGNATURE_SM2* target,
BYTE** buffer,
INT32* size) {
return TPMS_SIGNATURE_ECC_Unmarshal(target, buffer, size);
}
UINT16 TPMT_PUBLIC_PARMS_Marshal(TPMT_PUBLIC_PARMS* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_PUBLIC_Marshal(&source->type, buffer, size);
total_size += TPMU_PUBLIC_PARMS_Marshal(&source->parameters, buffer, size,
source->type);
return total_size;
}
TPM_RC TPMT_PUBLIC_PARMS_Unmarshal(TPMT_PUBLIC_PARMS* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_PUBLIC_Unmarshal(&target->type, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_PUBLIC_PARMS_Unmarshal(&target->parameters, buffer, size,
target->type);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMT_RSA_DECRYPT_Marshal(TPMT_RSA_DECRYPT* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_RSA_DECRYPT_Marshal(&source->scheme, buffer, size);
total_size +=
TPMU_ASYM_SCHEME_Marshal(&source->details, buffer, size, source->scheme);
return total_size;
}
TPM_RC TPMT_RSA_DECRYPT_Unmarshal(TPMT_RSA_DECRYPT* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_RSA_DECRYPT_Unmarshal(&target->scheme, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_ASYM_SCHEME_Unmarshal(&target->details, buffer, size,
target->scheme);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_SIGNATURE_Marshal(TPMU_SIGNATURE* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
return TPMS_SIGNATURE_RSASSA_Marshal(
(TPMS_SIGNATURE_RSASSA*)&source->rsassa, buffer, size);
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
return TPMS_SIGNATURE_RSAPSS_Marshal(
(TPMS_SIGNATURE_RSAPSS*)&source->rsapss, buffer, size);
#endif
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
return TPMS_SIGNATURE_ECDSA_Marshal((TPMS_SIGNATURE_ECDSA*)&source->ecdsa,
buffer, size);
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
return TPMS_SIGNATURE_ECDAA_Marshal((TPMS_SIGNATURE_ECDAA*)&source->ecdaa,
buffer, size);
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
return TPMS_SIGNATURE_SM2_Marshal((TPMS_SIGNATURE_SM2*)&source->sm2,
buffer, size);
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
return TPMS_SIGNATURE_ECSCHNORR_Marshal(
(TPMS_SIGNATURE_ECSCHNORR*)&source->ecschnorr, buffer, size);
#endif
#ifdef TPM_ALG_HMAC
case TPM_ALG_HMAC:
return TPMT_HA_Marshal((TPMT_HA*)&source->hmac, buffer, size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_SIGNATURE_Unmarshal(TPMU_SIGNATURE* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
return TPMS_SIGNATURE_RSASSA_Unmarshal(
(TPMS_SIGNATURE_RSASSA*)&target->rsassa, buffer, size);
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
return TPMS_SIGNATURE_RSAPSS_Unmarshal(
(TPMS_SIGNATURE_RSAPSS*)&target->rsapss, buffer, size);
#endif
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
return TPMS_SIGNATURE_ECDSA_Unmarshal(
(TPMS_SIGNATURE_ECDSA*)&target->ecdsa, buffer, size);
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
return TPMS_SIGNATURE_ECDAA_Unmarshal(
(TPMS_SIGNATURE_ECDAA*)&target->ecdaa, buffer, size);
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
return TPMS_SIGNATURE_SM2_Unmarshal((TPMS_SIGNATURE_SM2*)&target->sm2,
buffer, size);
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
return TPMS_SIGNATURE_ECSCHNORR_Unmarshal(
(TPMS_SIGNATURE_ECSCHNORR*)&target->ecschnorr, buffer, size);
#endif
#ifdef TPM_ALG_HMAC
case TPM_ALG_HMAC:
return TPMT_HA_Unmarshal((TPMT_HA*)&target->hmac, buffer, size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMT_SIGNATURE_Marshal(TPMT_SIGNATURE* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_SIG_SCHEME_Marshal(&source->sigAlg, buffer, size);
total_size +=
TPMU_SIGNATURE_Marshal(&source->signature, buffer, size, source->sigAlg);
return total_size;
}
TPM_RC TPMT_SIGNATURE_Unmarshal(TPMT_SIGNATURE* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_SIG_SCHEME_Unmarshal(&target->sigAlg, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_SIGNATURE_Unmarshal(&target->signature, buffer, size,
target->sigAlg);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_SIG_SCHEME_Marshal(TPMU_SIG_SCHEME* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
return TPMS_SIG_SCHEME_RSASSA_Marshal(
(TPMS_SIG_SCHEME_RSASSA*)&source->rsassa, buffer, size);
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
return TPMS_SIG_SCHEME_RSAPSS_Marshal(
(TPMS_SIG_SCHEME_RSAPSS*)&source->rsapss, buffer, size);
#endif
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
return TPMS_SIG_SCHEME_ECDSA_Marshal(
(TPMS_SIG_SCHEME_ECDSA*)&source->ecdsa, buffer, size);
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
return TPMS_SIG_SCHEME_ECDAA_Marshal(
(TPMS_SIG_SCHEME_ECDAA*)&source->ecdaa, buffer, size);
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
return TPMS_SIG_SCHEME_SM2_Marshal((TPMS_SIG_SCHEME_SM2*)&source->sm2,
buffer, size);
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
return TPMS_SIG_SCHEME_ECSCHNORR_Marshal(
(TPMS_SIG_SCHEME_ECSCHNORR*)&source->ecschnorr, buffer, size);
#endif
#ifdef TPM_ALG_HMAC
case TPM_ALG_HMAC:
return TPMS_SCHEME_HMAC_Marshal((TPMS_SCHEME_HMAC*)&source->hmac, buffer,
size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_SIG_SCHEME_Unmarshal(TPMU_SIG_SCHEME* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_RSASSA
case TPM_ALG_RSASSA:
return TPMS_SIG_SCHEME_RSASSA_Unmarshal(
(TPMS_SIG_SCHEME_RSASSA*)&target->rsassa, buffer, size);
#endif
#ifdef TPM_ALG_RSAPSS
case TPM_ALG_RSAPSS:
return TPMS_SIG_SCHEME_RSAPSS_Unmarshal(
(TPMS_SIG_SCHEME_RSAPSS*)&target->rsapss, buffer, size);
#endif
#ifdef TPM_ALG_ECDSA
case TPM_ALG_ECDSA:
return TPMS_SIG_SCHEME_ECDSA_Unmarshal(
(TPMS_SIG_SCHEME_ECDSA*)&target->ecdsa, buffer, size);
#endif
#ifdef TPM_ALG_ECDAA
case TPM_ALG_ECDAA:
return TPMS_SIG_SCHEME_ECDAA_Unmarshal(
(TPMS_SIG_SCHEME_ECDAA*)&target->ecdaa, buffer, size);
#endif
#ifdef TPM_ALG_SM2
case TPM_ALG_SM2:
return TPMS_SIG_SCHEME_SM2_Unmarshal((TPMS_SIG_SCHEME_SM2*)&target->sm2,
buffer, size);
#endif
#ifdef TPM_ALG_ECSCHNORR
case TPM_ALG_ECSCHNORR:
return TPMS_SIG_SCHEME_ECSCHNORR_Unmarshal(
(TPMS_SIG_SCHEME_ECSCHNORR*)&target->ecschnorr, buffer, size);
#endif
#ifdef TPM_ALG_HMAC
case TPM_ALG_HMAC:
return TPMS_SCHEME_HMAC_Unmarshal((TPMS_SCHEME_HMAC*)&target->hmac,
buffer, size);
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPMT_SIG_SCHEME_Marshal(TPMT_SIG_SCHEME* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_SIG_SCHEME_Marshal(&source->scheme, buffer, size);
total_size +=
TPMU_SIG_SCHEME_Marshal(&source->details, buffer, size, source->scheme);
return total_size;
}
TPM_RC TPMT_SIG_SCHEME_Unmarshal(TPMT_SIG_SCHEME* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_SIG_SCHEME_Unmarshal(&target->scheme, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result =
TPMU_SIG_SCHEME_Unmarshal(&target->details, buffer, size, target->scheme);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMT_SYM_DEF_Marshal(TPMT_SYM_DEF* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += TPMI_ALG_SYM_Marshal(&source->algorithm, buffer, size);
total_size += TPMU_SYM_KEY_BITS_Marshal(&source->keyBits, buffer, size,
source->algorithm);
total_size +=
TPMU_SYM_MODE_Marshal(&source->mode, buffer, size, source->algorithm);
return total_size;
}
TPM_RC TPMT_SYM_DEF_Unmarshal(TPMT_SYM_DEF* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPMI_ALG_SYM_Unmarshal(&target->algorithm, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMU_SYM_KEY_BITS_Unmarshal(&target->keyBits, buffer, size,
target->algorithm);
if (result != TPM_RC_SUCCESS) {
return result;
}
result =
TPMU_SYM_MODE_Unmarshal(&target->mode, buffer, size, target->algorithm);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM_ST_Marshal(TPM_ST* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPM_ST_Unmarshal(TPM_ST* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint16_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_ST_RSP_COMMAND) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_NULL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_NO_SESSIONS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_SESSIONS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_ATTEST_NV) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_ATTEST_COMMAND_AUDIT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_ATTEST_SESSION_AUDIT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_ATTEST_CERTIFY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_ATTEST_QUOTE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_ATTEST_TIME) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_ATTEST_CREATION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_CREATION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_VERIFIED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_AUTH_SECRET) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_HASHCHECK) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_AUTH_SIGNED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_ST_FU_MANIFEST) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPMT_TK_AUTH_Marshal(TPMT_TK_AUTH* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += TPM_ST_Marshal(&source->tag, buffer, size);
total_size += TPMI_RH_HIERARCHY_Marshal(&source->hierarchy, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->digest, buffer, size);
return total_size;
}
TPM_RC TPMT_TK_AUTH_Unmarshal(TPMT_TK_AUTH* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_ST_Unmarshal(&target->tag, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_RH_HIERARCHY_Unmarshal(&target->hierarchy, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->digest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMT_TK_CREATION_Marshal(TPMT_TK_CREATION* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM_ST_Marshal(&source->tag, buffer, size);
total_size += TPMI_RH_HIERARCHY_Marshal(&source->hierarchy, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->digest, buffer, size);
return total_size;
}
TPM_RC TPMT_TK_CREATION_Unmarshal(TPMT_TK_CREATION* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_ST_Unmarshal(&target->tag, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_RH_HIERARCHY_Unmarshal(&target->hierarchy, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->digest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMT_TK_HASHCHECK_Marshal(TPMT_TK_HASHCHECK* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM_ST_Marshal(&source->tag, buffer, size);
total_size += TPMI_RH_HIERARCHY_Marshal(&source->hierarchy, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->digest, buffer, size);
return total_size;
}
TPM_RC TPMT_TK_HASHCHECK_Unmarshal(TPMT_TK_HASHCHECK* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_ST_Unmarshal(&target->tag, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_RH_HIERARCHY_Unmarshal(&target->hierarchy, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->digest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMT_TK_VERIFIED_Marshal(TPMT_TK_VERIFIED* source,
BYTE** buffer,
INT32* size) {
UINT16 total_size = 0;
total_size += TPM_ST_Marshal(&source->tag, buffer, size);
total_size += TPMI_RH_HIERARCHY_Marshal(&source->hierarchy, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->digest, buffer, size);
return total_size;
}
TPM_RC TPMT_TK_VERIFIED_Unmarshal(TPMT_TK_VERIFIED* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = TPM_ST_Unmarshal(&target->tag, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMI_RH_HIERARCHY_Unmarshal(&target->hierarchy, buffer, size, TRUE);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->digest, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPMU_SYM_DETAILS_Marshal(TPMU_SYM_DETAILS* source,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_AES
case TPM_ALG_AES:
return 0;
#endif
#ifdef TPM_ALG_SM4
case TPM_ALG_SM4:
return 0;
#endif
#ifdef TPM_ALG_CAMELLIA
case TPM_ALG_CAMELLIA:
return 0;
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
return 0;
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return 0;
#endif
}
return 0;
}
TPM_RC TPMU_SYM_DETAILS_Unmarshal(TPMU_SYM_DETAILS* target,
BYTE** buffer,
INT32* size,
UINT32 selector) {
switch (selector) {
#ifdef TPM_ALG_AES
case TPM_ALG_AES:
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_SM4
case TPM_ALG_SM4:
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_CAMELLIA
case TPM_ALG_CAMELLIA:
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_XOR
case TPM_ALG_XOR:
return TPM_RC_SUCCESS;
#endif
#ifdef TPM_ALG_NULL
case TPM_ALG_NULL:
return TPM_RC_SUCCESS;
#endif
}
return TPM_RC_SELECTOR;
}
UINT16 TPM_ALGORITHM_ID_Marshal(TPM_ALGORITHM_ID* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_ALGORITHM_ID_Unmarshal(TPM_ALGORITHM_ID* target,
BYTE** buffer,
INT32* size) {
return uint32_t_Unmarshal(target, buffer, size);
}
UINT16 TPM_AUTHORIZATION_SIZE_Marshal(TPM_AUTHORIZATION_SIZE* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_AUTHORIZATION_SIZE_Unmarshal(TPM_AUTHORIZATION_SIZE* target,
BYTE** buffer,
INT32* size) {
return uint32_t_Unmarshal(target, buffer, size);
}
UINT16 TPM_CLOCK_ADJUST_Marshal(TPM_CLOCK_ADJUST* source,
BYTE** buffer,
INT32* size) {
return int8_t_Marshal(source, buffer, size);
}
TPM_RC TPM_CLOCK_ADJUST_Unmarshal(TPM_CLOCK_ADJUST* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = int8_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_CLOCK_COARSE_SLOWER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CLOCK_MEDIUM_SLOWER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CLOCK_FINE_SLOWER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CLOCK_NO_CHANGE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CLOCK_FINE_FASTER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CLOCK_MEDIUM_FASTER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_CLOCK_COARSE_FASTER) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_EO_Marshal(TPM_EO* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPM_EO_Unmarshal(TPM_EO* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint16_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_EO_EQ) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_NEQ) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_SIGNED_GT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_UNSIGNED_GT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_SIGNED_LT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_UNSIGNED_LT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_SIGNED_GE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_UNSIGNED_GE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_SIGNED_LE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_UNSIGNED_LE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_BITSET) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_EO_BITCLEAR) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_HC_Marshal(TPM_HC* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_HC_Unmarshal(TPM_HC* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == HR_HANDLE_MASK) {
return TPM_RC_SUCCESS;
}
if (*target == HR_RANGE_MASK) {
return TPM_RC_SUCCESS;
}
if (*target == HR_SHIFT) {
return TPM_RC_SUCCESS;
}
if (*target == HR_PCR) {
return TPM_RC_SUCCESS;
}
if (*target == HR_HMAC_SESSION) {
return TPM_RC_SUCCESS;
}
if (*target == HR_POLICY_SESSION) {
return TPM_RC_SUCCESS;
}
if (*target == HR_TRANSIENT) {
return TPM_RC_SUCCESS;
}
if (*target == HR_PERSISTENT) {
return TPM_RC_SUCCESS;
}
if (*target == HR_NV_INDEX) {
return TPM_RC_SUCCESS;
}
if (*target == HR_PERMANENT) {
return TPM_RC_SUCCESS;
}
if (*target == PCR_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == PCR_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == HMAC_SESSION_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == HMAC_SESSION_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == LOADED_SESSION_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == LOADED_SESSION_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == POLICY_SESSION_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == POLICY_SESSION_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == TRANSIENT_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == ACTIVE_SESSION_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == ACTIVE_SESSION_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == TRANSIENT_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == PERSISTENT_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == PERSISTENT_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == PLATFORM_PERSISTENT) {
return TPM_RC_SUCCESS;
}
if (*target == NV_INDEX_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == NV_INDEX_LAST) {
return TPM_RC_SUCCESS;
}
if (*target == PERMANENT_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == PERMANENT_LAST) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_HT_Marshal(TPM_HT* source, BYTE** buffer, INT32* size) {
return uint8_t_Marshal(source, buffer, size);
}
TPM_RC TPM_HT_Unmarshal(TPM_HT* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint8_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_HT_PCR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_HT_NV_INDEX) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_HT_HMAC_SESSION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_HT_LOADED_SESSION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_HT_POLICY_SESSION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_HT_ACTIVE_SESSION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_HT_PERMANENT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_HT_TRANSIENT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_HT_PERSISTENT) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_KEY_SIZE_Marshal(TPM_KEY_SIZE* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPM_KEY_SIZE_Unmarshal(TPM_KEY_SIZE* target,
BYTE** buffer,
INT32* size) {
return uint16_t_Unmarshal(target, buffer, size);
}
UINT16 TPM_MODIFIER_INDICATOR_Marshal(TPM_MODIFIER_INDICATOR* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_MODIFIER_INDICATOR_Unmarshal(TPM_MODIFIER_INDICATOR* target,
BYTE** buffer,
INT32* size) {
return uint32_t_Unmarshal(target, buffer, size);
}
UINT16 TPM_NV_INDEX_Marshal(TPM_NV_INDEX* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal((uint32_t*)source, buffer, size);
}
TPM_RC TPM_NV_INDEX_Unmarshal(TPM_NV_INDEX* target,
BYTE** buffer,
INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal((uint32_t*)target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 TPM_PARAMETER_SIZE_Marshal(TPM_PARAMETER_SIZE* source,
BYTE** buffer,
INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_PARAMETER_SIZE_Unmarshal(TPM_PARAMETER_SIZE* target,
BYTE** buffer,
INT32* size) {
return uint32_t_Unmarshal(target, buffer, size);
}
UINT16 TPM_PS_Marshal(TPM_PS* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_PS_Unmarshal(TPM_PS* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_PS_MAIN) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_PC) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_PDA) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_CELL_PHONE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_SERVER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_PERIPHERAL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_TSS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_STORAGE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_AUTHENTICATION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_EMBEDDED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_HARDCOPY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_INFRASTRUCTURE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_VIRTUALIZATION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_TNC) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_MULTI_TENANT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PS_TC) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_PT_PCR_Marshal(TPM_PT_PCR* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_PT_PCR_Unmarshal(TPM_PT_PCR* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_PT_PCR_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_SAVE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_EXTEND_L0) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_RESET_L0) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_EXTEND_L1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_RESET_L1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_EXTEND_L2) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_RESET_L2) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_EXTEND_L3) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_RESET_L3) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_EXTEND_L4) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_RESET_L4) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_NO_INCREMENT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_DRTM_RESET) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_POLICY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_AUTH) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_PT_PCR_LAST) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_RC_Marshal(TPM_RC* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_RC_Unmarshal(TPM_RC* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_RC_SUCCESS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_BAD_TAG) {
return TPM_RC_SUCCESS;
}
if (*target == RC_VER1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_INITIALIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_FAILURE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SEQUENCE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_PRIVATE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_HMAC) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_DISABLED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_EXCLUSIVE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_AUTH_TYPE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_AUTH_MISSING) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_POLICY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_PCR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_PCR_CHANGED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_UPGRADE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_TOO_MANY_CONTEXTS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_AUTH_UNAVAILABLE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REBOOT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_UNBALANCED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_COMMAND_SIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_COMMAND_CODE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_AUTHSIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_AUTH_CONTEXT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_RANGE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_SIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_LOCKED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_AUTHORIZATION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_UNINITIALIZED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_SPACE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_DEFINED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_BAD_CONTEXT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_CPHASH) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_PARENT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NEEDS_TEST) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NO_RESULT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SENSITIVE) {
return TPM_RC_SUCCESS;
}
if (*target == RC_MAX_FM0) {
return TPM_RC_SUCCESS;
}
if (*target == RC_FMT1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_ASYMMETRIC) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_ATTRIBUTES) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_HASH) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_VALUE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_HIERARCHY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_KEY_SIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_MGF) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_MODE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_TYPE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_HANDLE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_KDF) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_RANGE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_AUTH_FAIL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NONCE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_PP) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SCHEME) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SIZE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SYMMETRIC) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_TAG) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SELECTOR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_INSUFFICIENT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SIGNATURE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_KEY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_POLICY_FAIL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_INTEGRITY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_TICKET) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_RESERVED_BITS) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_BAD_AUTH) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_EXPIRED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_POLICY_CC) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_BINDING) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_CURVE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_ECC_POINT) {
return TPM_RC_SUCCESS;
}
if (*target == RC_WARN) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_CONTEXT_GAP) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_OBJECT_MEMORY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SESSION_MEMORY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_MEMORY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_SESSION_HANDLES) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_OBJECT_HANDLES) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_LOCALITY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_YIELDED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_CANCELED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_TESTING) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_H0) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_H1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_H2) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_H3) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_H4) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_H5) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_H6) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_S0) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_S1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_S2) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_S3) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_S4) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_S5) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_REFERENCE_S6) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_RATE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_LOCKOUT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_RETRY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NV_UNAVAILABLE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_NOT_USED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_H) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_P) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_S) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_1) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_2) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_3) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_4) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_5) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_6) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_7) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_8) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_9) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_A) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_B) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_C) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_D) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_E) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_F) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RC_N_MASK) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_RH_Marshal(TPM_RH* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_RH_Unmarshal(TPM_RH* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_RH_FIRST) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_SRK) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_OWNER) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_REVOKE) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_TRANSPORT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_OPERATOR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_ADMIN) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_EK) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_NULL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_UNASSIGNED) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RS_PW) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_LOCKOUT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_ENDORSEMENT) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_PLATFORM) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_PLATFORM_NV) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_AUTH_00) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_AUTH_FF) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_RH_LAST) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_SE_Marshal(TPM_SE* source, BYTE** buffer, INT32* size) {
return uint8_t_Marshal(source, buffer, size);
}
TPM_RC TPM_SE_Unmarshal(TPM_SE* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint8_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_SE_HMAC) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_SE_POLICY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_SE_TRIAL) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_SPEC_Marshal(TPM_SPEC* source, BYTE** buffer, INT32* size) {
return uint32_t_Marshal(source, buffer, size);
}
TPM_RC TPM_SPEC_Unmarshal(TPM_SPEC* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint32_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_SPEC_FAMILY) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_SPEC_LEVEL) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_SPEC_VERSION) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_SPEC_YEAR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_SPEC_DAY_OF_YEAR) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 TPM_SU_Marshal(TPM_SU* source, BYTE** buffer, INT32* size) {
return uint16_t_Marshal(source, buffer, size);
}
TPM_RC TPM_SU_Unmarshal(TPM_SU* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = uint16_t_Unmarshal(target, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
if (*target == TPM_SU_CLEAR) {
return TPM_RC_SUCCESS;
}
if (*target == TPM_SU_STATE) {
return TPM_RC_SUCCESS;
}
return TPM_RC_VALUE;
}
UINT16 _ID_OBJECT_Marshal(_ID_OBJECT* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_DIGEST_Marshal(&source->integrityHMAC, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->encIdentity, buffer, size);
return total_size;
}
TPM_RC _ID_OBJECT_Unmarshal(_ID_OBJECT* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = TPM2B_DIGEST_Unmarshal(&target->integrityHMAC, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->encIdentity, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}
UINT16 _PRIVATE_Marshal(_PRIVATE* source, BYTE** buffer, INT32* size) {
UINT16 total_size = 0;
total_size += TPM2B_DIGEST_Marshal(&source->integrityOuter, buffer, size);
total_size += TPM2B_DIGEST_Marshal(&source->integrityInner, buffer, size);
total_size += TPMT_SENSITIVE_Marshal(&source->sensitive, buffer, size);
return total_size;
}
TPM_RC _PRIVATE_Unmarshal(_PRIVATE* target, BYTE** buffer, INT32* size) {
TPM_RC result;
result = TPM2B_DIGEST_Unmarshal(&target->integrityOuter, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPM2B_DIGEST_Unmarshal(&target->integrityInner, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
result = TPMT_SENSITIVE_Unmarshal(&target->sensitive, buffer, size);
if (result != TPM_RC_SUCCESS) {
return result;
}
return TPM_RC_SUCCESS;
}