| /* SPDX-License-Identifier: GPL-2.0+ */ |
| /* |
| * MediaTek BootROM header definitions |
| * |
| * Copyright (C) 2018 MediaTek Inc. |
| * Author: Weijie Gao <weijie.gao@mediatek.com> |
| */ |
| |
| #ifndef _MTK_IMAGE_H |
| #define _MTK_IMAGE_H |
| |
| /* Device header definitions */ |
| |
| /* Header for NOR/SD/eMMC */ |
| union gen_boot_header { |
| struct { |
| char name[12]; |
| __le32 version; |
| __le32 size; |
| }; |
| |
| uint8_t pad[0x200]; |
| }; |
| |
| #define EMMC_BOOT_NAME "EMMC_BOOT" |
| #define SF_BOOT_NAME "SF_BOOT" |
| #define SDMMC_BOOT_NAME "SDMMC_BOOT" |
| |
| /* Header for NAND */ |
| union nand_boot_header { |
| struct { |
| char name[12]; |
| char version[4]; |
| char id[8]; |
| __le16 ioif; |
| __le16 pagesize; |
| __le16 addrcycles; |
| __le16 oobsize; |
| __le16 pages_of_block; |
| __le16 numblocks; |
| __le16 writesize_shift; |
| __le16 erasesize_shift; |
| uint8_t dummy[60]; |
| uint8_t ecc_parity[28]; |
| }; |
| |
| uint8_t data[0x80]; |
| }; |
| |
| #define NAND_BOOT_NAME "BOOTLOADER!" |
| #define NAND_BOOT_VERSION "V006" |
| #define NAND_BOOT_ID "NFIINFO" |
| |
| /* BootROM layout header */ |
| struct brom_layout_header { |
| char name[8]; |
| __le32 version; |
| __le32 header_size; |
| __le32 total_size; |
| __le32 magic; |
| __le32 type; |
| __le32 header_size_2; |
| __le32 total_size_2; |
| __le32 unused; |
| }; |
| |
| #define BRLYT_NAME "BRLYT" |
| #define BRLYT_MAGIC 0x42424242 |
| |
| enum brlyt_img_type { |
| BRLYT_TYPE_INVALID = 0, |
| BRLYT_TYPE_NAND = 0x10002, |
| BRLYT_TYPE_EMMC = 0x10005, |
| BRLYT_TYPE_NOR = 0x10007, |
| BRLYT_TYPE_SDMMC = 0x10008, |
| BRLYT_TYPE_SNAND = 0x10009 |
| }; |
| |
| /* Combined device header for NOR/SD/eMMC */ |
| struct gen_device_header { |
| union gen_boot_header boot; |
| |
| union { |
| struct brom_layout_header brlyt; |
| uint8_t brlyt_pad[0x400]; |
| }; |
| }; |
| |
| /* BootROM header definitions */ |
| struct gfh_common_header { |
| uint8_t magic[3]; |
| uint8_t version; |
| __le16 size; |
| __le16 type; |
| }; |
| |
| #define GFH_HEADER_MAGIC "MMM" |
| |
| #define GFH_TYPE_FILE_INFO 0 |
| #define GFH_TYPE_BL_INFO 1 |
| #define GFH_TYPE_BROM_CFG 7 |
| #define GFH_TYPE_BL_SEC_KEY 3 |
| #define GFH_TYPE_ANTI_CLONE 2 |
| #define GFH_TYPE_BROM_SEC_CFG 8 |
| |
| struct gfh_file_info { |
| struct gfh_common_header gfh; |
| char name[12]; |
| __le32 unused; |
| __le16 file_type; |
| uint8_t flash_type; |
| uint8_t sig_type; |
| __le32 load_addr; |
| __le32 total_size; |
| __le32 max_size; |
| __le32 hdr_size; |
| __le32 sig_size; |
| __le32 jump_offset; |
| __le32 processed; |
| }; |
| |
| #define GFH_FILE_INFO_NAME "FILE_INFO" |
| |
| #define GFH_FLASH_TYPE_GEN 5 |
| #define GFH_FLASH_TYPE_NAND 2 |
| |
| #define GFH_SIG_TYPE_NONE 0 |
| #define GFH_SIG_TYPE_SHA256 1 |
| |
| struct gfh_bl_info { |
| struct gfh_common_header gfh; |
| __le32 attr; |
| }; |
| |
| struct gfh_brom_cfg { |
| struct gfh_common_header gfh; |
| __le32 cfg_bits; |
| __le32 usbdl_by_auto_detect_timeout_ms; |
| uint8_t unused[0x48]; |
| __le32 usbdl_by_kcol0_timeout_ms; |
| __le32 usbdl_by_flag_timeout_ms; |
| uint32_t pad; |
| }; |
| |
| #define GFH_BROM_CFG_USBDL_BY_AUTO_DETECT_TIMEOUT_EN 0x02 |
| #define GFH_BROM_CFG_USBDL_AUTO_DETECT_DIS 0x10 |
| #define GFH_BROM_CFG_USBDL_BY_KCOL0_TIMEOUT_EN 0x80 |
| #define GFH_BROM_CFG_USBDL_BY_FLAG_TIMEOUT_EN 0x100 |
| |
| struct gfh_bl_sec_key { |
| struct gfh_common_header gfh; |
| uint8_t pad[0x20c]; |
| }; |
| |
| struct gfh_anti_clone { |
| struct gfh_common_header gfh; |
| uint8_t ac_b2k; |
| uint8_t ac_b2c; |
| uint16_t pad; |
| __le32 ac_offset; |
| __le32 ac_len; |
| }; |
| |
| struct gfh_brom_sec_cfg { |
| struct gfh_common_header gfh; |
| __le32 cfg_bits; |
| char customer_name[0x20]; |
| __le32 pad; |
| }; |
| |
| #define BROM_SEC_CFG_JTAG_EN 1 |
| #define BROM_SEC_CFG_UART_EN 2 |
| |
| struct gfh_header { |
| struct gfh_file_info file_info; |
| struct gfh_bl_info bl_info; |
| struct gfh_brom_cfg brom_cfg; |
| struct gfh_bl_sec_key bl_sec_key; |
| struct gfh_anti_clone anti_clone; |
| struct gfh_brom_sec_cfg brom_sec_cfg; |
| }; |
| |
| /* LK image header */ |
| |
| union lk_hdr { |
| struct { |
| __le32 magic; |
| __le32 size; |
| char name[32]; |
| __le32 loadaddr; |
| __le32 mode; |
| }; |
| |
| uint8_t data[512]; |
| }; |
| |
| #define LK_PART_MAGIC 0x58881688 |
| |
| #endif /* _MTK_IMAGE_H */ |