mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-30 11:38:15 +00:00 
			
		
		
		
	i.MX8ULP support using ROM API to load container image, it use same ROM API as i.MX8MN/MP, and use same container format as i.MX8QM/QXP. Signed-off-by: Ye Li <ye.li@nxp.com> Signed-off-by: Peng Fan <peng.fan@nxp.com>
		
			
				
	
	
		
			70 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* 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;
 | |
| 
 | |
| struct generate_key_blob_hdr {
 | |
| 	u8 version;
 | |
| 	u8 length_lsb;
 | |
| 	u8 length_msb;
 | |
| 	u8 tag;
 | |
| 	u8 flags;
 | |
| 	u8 size;
 | |
| 	u8 algorithm;
 | |
| 	u8 mode;
 | |
| } __packed;
 | |
| 
 | |
| int get_container_size(ulong addr, u16 *header_length);
 | |
| #endif
 |