tpm2_pcr_read_outRegular
4.4: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[20];
};
4.8: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[20];
};
4.10: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[20];
};
4.13: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
4.15: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
4.18: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
5.0: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
5.3: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
5.4: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
5.8: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
5.11: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
5.13: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
5.15: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
5.19: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
6.2: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
6.5: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
6.8: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
arm64: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
armhf: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
ppc64el: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
riscv64: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
aws: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
azure: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
gcp: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
lowlatency: ✅struct tpm2_pcr_read_out {
__be32 update_cnt;
__be32 pcr_selects_cnt;
__be16 hash_alg;
u8 pcr_select_size;
u8 pcr_select[3];
__be32 digests_cnt;
__be16 digest_size;
u8 digest[0];
};
Regular
4.4 and 4.8 ✅
4.8 and 4.10 ✅
4.10 and 4.13 ⚠️u8 digest[20] ➡️ u8 digest[0]
4.13 and 4.15 ✅
4.15 and 4.18 ✅
4.18 and 5.0 ✅
5.0 and 5.3 ✅
5.3 and 5.4 ✅
5.4 and 5.8 ✅
5.8 and 5.11 ✅
5.11 and 5.13 ✅
5.13 and 5.15 ✅
5.15 and 5.19 ✅
5.19 and 6.2 ✅
6.2 and 6.5 ✅
6.5 and 6.8 ✅
amd64 and arm64 ✅
amd64 and armhf ✅
amd64 and ppc64el ✅
amd64 and riscv64 ✅
generic and aws ✅
generic and azure ✅
generic and gcp ✅
generic and lowlatency ✅