blob: 0c432dbc2dc5b69d8a0001d4912f24b9a0620d91 [file] [log] [blame]
/*
* EIF (Enclave Image Format) related helpers
*
* Copyright (c) 2024 Dorjoy Chowdhury <dorjoychy111@gmail.com>
*
* This work is licensed under the terms of the GNU GPL, version 2 or
* (at your option) any later version. See the COPYING file in the
* top-level directory.
*/
#ifndef HW_CORE_EIF_H
#define HW_CORE_EIF_H
#define MAX_SECTIONS 32
#define EIF_HDR_ARCH_ARM64 0x1
/* members are ordered according to field order in .eif file */
typedef struct EifHeader {
uint8_t magic[4]; /* must be .eif in ascii i.e., [46, 101, 105, 102] */
uint16_t version;
uint16_t flags;
uint64_t default_memory;
uint64_t default_cpus;
uint16_t reserved;
uint16_t section_cnt;
uint64_t section_offsets[MAX_SECTIONS];
uint64_t section_sizes[MAX_SECTIONS];
uint32_t unused;
uint32_t eif_crc32;
} QEMU_PACKED EifHeader;
/* members are ordered according to field order in .eif file */
typedef struct EifSectionHeader {
/*
* 0 = invalid, 1 = kernel, 2 = cmdline, 3 = ramdisk, 4 = signature,
* 5 = metadata
*/
uint16_t section_type;
uint16_t flags;
uint64_t section_size;
} QEMU_PACKED EifSectionHeader;
enum EifSectionTypes {
EIF_SECTION_INVALID = 0,
EIF_SECTION_KERNEL = 1,
EIF_SECTION_CMDLINE = 2,
EIF_SECTION_RAMDISK = 3,
EIF_SECTION_SIGNATURE = 4,
EIF_SECTION_METADATA = 5,
EIF_SECTION_MAX = 6,
};
#define EIF_MAGIC { '.', 'e', 'i', 'f' }
bool read_eif_file(const char *eif_path, const char *machine_initrd,
char **kernel_path, char **initrd_path,
char **kernel_cmdline, uint8_t *image_sha384,
uint8_t *bootstrap_sha384, uint8_t *app_sha384,
uint8_t *fingerprint_sha384, bool *signature_found,
Error **errp);
#endif