2019-08-22 07:42:33 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
|
|
/*
|
|
|
|
* Copyright 2018-2019 NXP
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __CONTAINER_HEADER_H_
|
|
|
|
#define __CONTAINER_HEADER_H_
|
|
|
|
|
|
|
|
#include <linux/sizes.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
|
|
|
#define IV_MAX_LEN 32
|
|
|
|
#define HASH_MAX_LEN 64
|
|
|
|
|
|
|
|
#define CONTAINER_HDR_ALIGNMENT 0x400
|
|
|
|
#define CONTAINER_HDR_EMMC_OFFSET 0
|
|
|
|
#define CONTAINER_HDR_MMCSD_OFFSET SZ_32K
|
|
|
|
#define CONTAINER_HDR_QSPI_OFFSET SZ_4K
|
|
|
|
#define CONTAINER_HDR_NAND_OFFSET SZ_128M
|
|
|
|
|
|
|
|
struct container_hdr {
|
|
|
|
u8 version;
|
|
|
|
u8 length_lsb;
|
|
|
|
u8 length_msb;
|
|
|
|
u8 tag;
|
|
|
|
u32 flags;
|
|
|
|
u16 sw_version;
|
|
|
|
u8 fuse_version;
|
|
|
|
u8 num_images;
|
|
|
|
u16 sig_blk_offset;
|
|
|
|
u16 reserved;
|
|
|
|
} __packed;
|
|
|
|
|
|
|
|
struct boot_img_t {
|
|
|
|
u32 offset;
|
|
|
|
u32 size;
|
|
|
|
u64 dst;
|
|
|
|
u64 entry;
|
|
|
|
u32 hab_flags;
|
|
|
|
u32 meta;
|
|
|
|
u8 hash[HASH_MAX_LEN];
|
|
|
|
u8 iv[IV_MAX_LEN];
|
|
|
|
} __packed;
|
|
|
|
|
|
|
|
struct signature_block_hdr {
|
|
|
|
u8 version;
|
|
|
|
u8 length_lsb;
|
|
|
|
u8 length_msb;
|
|
|
|
u8 tag;
|
|
|
|
u16 srk_table_offset;
|
|
|
|
u16 cert_offset;
|
|
|
|
u16 blob_offset;
|
|
|
|
u16 signature_offset;
|
|
|
|
u32 reserved;
|
|
|
|
} __packed;
|
2021-03-25 09:30:34 +00:00
|
|
|
|
|
|
|
struct generate_key_blob_hdr {
|
|
|
|
u8 version;
|
|
|
|
u8 length_lsb;
|
|
|
|
u8 length_msb;
|
|
|
|
u8 tag;
|
|
|
|
u8 flags;
|
|
|
|
u8 size;
|
|
|
|
u8 algorithm;
|
|
|
|
u8 mode;
|
|
|
|
} __packed;
|
2021-08-07 08:00:39 +00:00
|
|
|
|
|
|
|
int get_container_size(ulong addr, u16 *header_length);
|
2019-08-22 07:42:33 +00:00
|
|
|
#endif
|