| /* SPDX-License-Identifier: GPL-2.0+ */ |
| /* |
| * Copyright 2018 NXP |
| * |
| * Peng Fan <peng.fan@nxp.com> |
| */ |
| |
| #ifndef _IMX8IMAGE_H_ |
| #define _IMX8IMAGE_H_ |
| |
| #include <image.h> |
| #include <inttypes.h> |
| #include "imagetool.h" |
| |
| #define __packed __attribute__((packed)) |
| |
| #define IV_MAX_LEN 32 |
| #define HASH_MAX_LEN 64 |
| #define MAX_NUM_IMGS 6 |
| #define MAX_NUM_SRK_RECORDS 4 |
| |
| #define IVT_HEADER_TAG_B0 0x87 |
| #define IVT_VERSION_B0 0x00 |
| |
| #define IMG_FLAG_HASH_SHA256 0x000 |
| #define IMG_FLAG_HASH_SHA384 0x100 |
| #define IMG_FLAG_HASH_SHA512 0x200 |
| |
| #define IMG_FLAG_ENCRYPTED_MASK 0x400 |
| #define IMG_FLAG_ENCRYPTED_SHIFT 0x0A |
| |
| #define IMG_FLAG_BOOTFLAGS_MASK 0xFFFF0000 |
| #define IMG_FLAG_BOOTFLAGS_SHIFT 0x10 |
| |
| #define IMG_ARRAY_ENTRY_SIZE 128 |
| #define HEADER_IMG_ARRAY_OFFSET 0x10 |
| |
| #define HASH_TYPE_SHA_256 256 |
| #define HASH_TYPE_SHA_384 384 |
| #define HASH_TYPE_SHA_512 512 |
| |
| #define IMAGE_HASH_ALGO_DEFAULT 384 |
| #define IMAGE_PADDING_DEFAULT 0x1000 |
| |
| #define DCD_ENTRY_ADDR_IN_SCFW 0x240 |
| |
| #define CONTAINER_ALIGNMENT 0x400 |
| #define CONTAINER_FLAGS_DEFAULT 0x10 |
| #define CONTAINER_FUSE_DEFAULT 0x0 |
| |
| #define SIGNATURE_BLOCK_HEADER_LENGTH 0x10 |
| |
| #define MAX_NUM_OF_CONTAINER 2 |
| |
| #define FIRST_CONTAINER_HEADER_LENGTH 0x400 |
| |
| #define BOOT_IMG_META_MU_RID_SHIFT 10 |
| #define BOOT_IMG_META_PART_ID_SHIFT 20 |
| |
| #define IMAGE_A35_DEFAULT_META(PART) (((PART == 0) ? \ |
| PARTITION_ID_AP : PART) << \ |
| BOOT_IMG_META_PART_ID_SHIFT | \ |
| SC_R_MU_0A << \ |
| BOOT_IMG_META_MU_RID_SHIFT | \ |
| SC_R_A35_0) |
| |
| #define IMAGE_A53_DEFAULT_META(PART) (((PART == 0) ? \ |
| PARTITION_ID_AP : PART) << \ |
| BOOT_IMG_META_PART_ID_SHIFT | \ |
| SC_R_MU_0A << \ |
| BOOT_IMG_META_MU_RID_SHIFT | \ |
| SC_R_A53_0) |
| |
| #define IMAGE_A72_DEFAULT_META(PART) (((PART == 0) ? \ |
| PARTITION_ID_AP : PART) << \ |
| BOOT_IMG_META_PART_ID_SHIFT | \ |
| SC_R_MU_0A << \ |
| BOOT_IMG_META_MU_RID_SHIFT | \ |
| SC_R_A72_0) |
| |
| #define IMAGE_M4_0_DEFAULT_META(PART) (((PART == 0) ? \ |
| PARTITION_ID_M4 : PART) << \ |
| BOOT_IMG_META_PART_ID_SHIFT | \ |
| SC_R_M4_0_MU_1A << \ |
| BOOT_IMG_META_MU_RID_SHIFT | \ |
| SC_R_M4_0_PID0) |
| |
| #define IMAGE_M4_1_DEFAULT_META(PART) (((PART == 0) ? \ |
| PARTITION_ID_M4 : PART) << \ |
| BOOT_IMG_META_PART_ID_SHIFT | \ |
| SC_R_M4_1_MU_1A << \ |
| BOOT_IMG_META_MU_RID_SHIFT | \ |
| SC_R_M4_1_PID0) |
| |
| #define CONTAINER_IMAGE_ARRAY_START_OFFSET 0x2000 |
| |
| typedef struct { |
| uint8_t version; |
| uint16_t length; |
| uint8_t tag; |
| uint16_t srk_table_offset; |
| uint16_t cert_offset; |
| uint16_t blob_offset; |
| uint16_t signature_offset; |
| uint32_t reserved; |
| } __packed sig_blk_hdr_t; |
| |
| typedef struct { |
| uint32_t offset; |
| uint32_t size; |
| uint64_t dst; |
| uint64_t entry; |
| uint32_t hab_flags; |
| uint32_t meta; |
| uint8_t hash[HASH_MAX_LEN]; |
| uint8_t iv[IV_MAX_LEN]; |
| } __packed boot_img_t; |
| |
| typedef struct { |
| uint8_t version; |
| uint16_t length; |
| uint8_t tag; |
| uint32_t flags; |
| uint16_t sw_version; |
| uint8_t fuse_version; |
| uint8_t num_images; |
| uint16_t sig_blk_offset; |
| uint16_t reserved; |
| boot_img_t img[MAX_NUM_IMGS]; |
| sig_blk_hdr_t sig_blk_hdr; |
| uint32_t sigblk_size; |
| uint32_t padding; |
| } __packed flash_header_v3_t; |
| |
| typedef struct { |
| flash_header_v3_t fhdr[MAX_NUM_OF_CONTAINER]; |
| } __packed imx_header_v3_t; |
| |
| struct image_array { |
| char *name; |
| unsigned int core_type; |
| unsigned int core_id; |
| unsigned int load_addr; |
| }; |
| |
| enum imx8image_cmd { |
| CMD_INVALID, |
| CMD_BOOT_FROM, |
| CMD_FUSE_VERSION, |
| CMD_SW_VERSION, |
| CMD_MSG_BLOCK, |
| CMD_FILEOFF, |
| CMD_FLAG, |
| CMD_APPEND, |
| CMD_PARTITION, |
| CMD_SOC_TYPE, |
| CMD_CONTAINER, |
| CMD_IMAGE, |
| CMD_DATA |
| }; |
| |
| enum imx8image_core_type { |
| CFG_CORE_INVALID, |
| CFG_SCU, |
| CFG_M40, |
| CFG_M41, |
| CFG_A35, |
| CFG_A53, |
| CFG_A72 |
| }; |
| |
| enum imx8image_fld_types { |
| CFG_INVALID = -1, |
| CFG_COMMAND, |
| CFG_CORE_TYPE, |
| CFG_IMAGE_NAME, |
| CFG_LOAD_ADDR |
| }; |
| |
| typedef enum SOC_TYPE { |
| NONE = 0, |
| QX, |
| QM |
| } soc_type_t; |
| |
| typedef enum option_type { |
| NO_IMG = 0, |
| DCD, |
| SCFW, |
| SECO, |
| M40, |
| M41, |
| AP, |
| OUTPUT, |
| SCD, |
| CSF, |
| FLAG, |
| DEVICE, |
| NEW_CONTAINER, |
| APPEND, |
| DATA, |
| PARTITION, |
| FILEOFF, |
| MSG_BLOCK |
| } option_type_t; |
| |
| typedef struct { |
| option_type_t option; |
| char *filename; |
| uint64_t src; |
| uint64_t dst; |
| uint64_t entry; |
| uint64_t ext; |
| } image_t; |
| |
| #define CORE_SC 1 |
| #define CORE_CM4_0 2 |
| #define CORE_CM4_1 3 |
| #define CORE_CA53 4 |
| #define CORE_CA35 4 |
| #define CORE_CA72 5 |
| #define CORE_SECO 6 |
| |
| #define SC_R_OTP 357U |
| #define SC_R_DEBUG 354U |
| #define SC_R_ROM_0 236U |
| |
| #define MSG_DEBUG_EN SC_R_DEBUG |
| #define MSG_FUSE SC_R_OTP |
| #define MSG_FIELD SC_R_ROM_0 |
| |
| #define IMG_TYPE_CSF 0x01 /* CSF image type */ |
| #define IMG_TYPE_SCD 0x02 /* SCD image type */ |
| #define IMG_TYPE_EXEC 0x03 /* Executable image type */ |
| #define IMG_TYPE_DATA 0x04 /* Data image type */ |
| #define IMG_TYPE_DCD_DDR 0x05 /* DCD/DDR image type */ |
| #define IMG_TYPE_SECO 0x06 /* SECO image type */ |
| #define IMG_TYPE_PROV 0x07 /* Provisioning image type */ |
| #define IMG_TYPE_DEK 0x08 /* DEK validation type */ |
| |
| #define IMG_TYPE_SHIFT 0 |
| #define IMG_TYPE_MASK 0x1f |
| #define IMG_TYPE(x) (((x) & IMG_TYPE_MASK) >> IMG_TYPE_SHIFT) |
| |
| #define BOOT_IMG_FLAGS_CORE_MASK 0xF |
| #define BOOT_IMG_FLAGS_CORE_SHIFT 0x04 |
| #define BOOT_IMG_FLAGS_CPU_RID_MASK 0x3FF0 |
| #define BOOT_IMG_FLAGS_CPU_RID_SHIFT 4 |
| #define BOOT_IMG_FLAGS_MU_RID_MASK 0xFFC000 |
| #define BOOT_IMG_FLAGS_MU_RID_SHIFT 14 |
| #define BOOT_IMG_FLAGS_PARTITION_ID_MASK 0x1F000000 |
| #define BOOT_IMG_FLAGS_PARTITION_ID_SHIFT 24 |
| |
| /* Resource id used in scfw */ |
| #define SC_R_A35_0 508 |
| #define SC_R_A53_0 1 |
| #define SC_R_A72_0 6 |
| #define SC_R_MU_0A 213 |
| #define SC_R_M4_0_PID0 278 |
| #define SC_R_M4_0_MU_1A 297 |
| #define SC_R_M4_1_PID0 298 |
| #define SC_R_M4_1_MU_1A 317 |
| #define PARTITION_ID_M4 0 |
| #define PARTITION_ID_AP 1 |
| |
| #define IMG_STACK_SIZE 32 |
| |
| #define append(p, s, l) do { \ |
| memcpy((p), (uint8_t *)(s), (l)); (p) += (l); \ |
| } while (0) |
| |
| #endif |