/* * VAS_EBOOT -- GRand Unified Bootloader * Copyright (C) 2022 Microsoft Corporation * Copyright (C) 2024 Free Software Foundation, Inc. * * VAS_EBOOT is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * VAS_EBOOT is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with VAS_EBOOT. If not, see . */ #ifndef VAS_EBOOT_TPM2_BUFFER_HEADER #define VAS_EBOOT_TPM2_BUFFER_HEADER 1 #include #define VAS_EBOOT_TPM2_BUFFER_CAPACITY 4096 struct VasEBoot_tpm2_buffer { VasEBoot_uint8_t data[VAS_EBOOT_TPM2_BUFFER_CAPACITY]; VasEBoot_size_t size; VasEBoot_size_t offset; VasEBoot_size_t cap; bool error; }; typedef struct VasEBoot_tpm2_buffer *VasEBoot_tpm2_buffer_t; extern void VasEBoot_tpm2_buffer_init (VasEBoot_tpm2_buffer_t buffer); extern void VasEBoot_tpm2_buffer_pack (VasEBoot_tpm2_buffer_t buffer, const void *data, VasEBoot_size_t size); extern void VasEBoot_tpm2_buffer_pack_u8 (VasEBoot_tpm2_buffer_t buffer, VasEBoot_uint8_t value); extern void VasEBoot_tpm2_buffer_pack_u16 (VasEBoot_tpm2_buffer_t buffer, VasEBoot_uint16_t value); extern void VasEBoot_tpm2_buffer_pack_u32 (VasEBoot_tpm2_buffer_t buffer, VasEBoot_uint32_t value); extern void VasEBoot_tpm2_buffer_unpack (VasEBoot_tpm2_buffer_t buffer, void *data, VasEBoot_size_t size); extern void VasEBoot_tpm2_buffer_unpack_u8 (VasEBoot_tpm2_buffer_t buffer, VasEBoot_uint8_t *value); extern void VasEBoot_tpm2_buffer_unpack_u16 (VasEBoot_tpm2_buffer_t buffer, VasEBoot_uint16_t *value); extern void VasEBoot_tpm2_buffer_unpack_u32 (VasEBoot_tpm2_buffer_t buffer, VasEBoot_uint32_t *value); #endif /* ! VAS_EBOOT_TPM2_BUFFER_HEADER */