xref: /openbmc/u-boot/tools/mxsimage.h (revision 53ab4af34e4e4242809114580320d2faa150b336)
1 /*
2  * Freescale i.MX28 SB image generator
3  *
4  * Copyright (C) 2012 Marek Vasut <marex@denx.de>
5  *
6  * SPDX-License-Identifier:	GPL-2.0+
7  */
8 
9 #ifndef __MXSSB_H__
10 #define __MXSSB_H__
11 
12 #include <stdint.h>
13 #include <arpa/inet.h>
14 
15 #define SB_BLOCK_SIZE		16
16 
17 #define roundup(x, y)		((((x) + ((y) - 1)) / (y)) * (y))
18 #define ARRAY_SIZE(x)		(sizeof(x) / sizeof((x)[0]))
19 
20 struct sb_boot_image_version {
21 	uint16_t	major;
22 	uint16_t	pad0;
23 	uint16_t	minor;
24 	uint16_t	pad1;
25 	uint16_t	revision;
26 	uint16_t	pad2;
27 };
28 
29 struct sb_boot_image_header {
30 	union {
31 		/* SHA1 of the header. */
32 		uint8_t	digest[20];
33 		struct {
34 			/* CBC-MAC initialization vector. */
35 			uint8_t iv[16];
36 			uint8_t extra[4];
37 		};
38 	};
39 	/* 'STMP' */
40 	uint8_t		signature1[4];
41 	/* Major version of the image format. */
42 	uint8_t		major_version;
43 	/* Minor version of the image format. */
44 	uint8_t		minor_version;
45 	/* Flags associated with the image. */
46 	uint16_t	flags;
47 	/* Size of the image in 16b blocks. */
48 	uint32_t	image_blocks;
49 	/* Offset of the first tag in 16b blocks. */
50 	uint32_t	first_boot_tag_block;
51 	/* ID of the section to boot from. */
52 	uint32_t	first_boot_section_id;
53 	/* Amount of crypto keys. */
54 	uint16_t	key_count;
55 	/* Offset to the key dictionary in 16b blocks. */
56 	uint16_t	key_dictionary_block;
57 	/* Size of this header in 16b blocks. */
58 	uint16_t	header_blocks;
59 	/* Amount of section headers. */
60 	uint16_t	section_count;
61 	/* Section header size in 16b blocks. */
62 	uint16_t	section_header_size;
63 	/* Padding to align timestamp to uint64_t. */
64 	uint8_t		padding0[2];
65 	/* 'sgtl' (since v1.1) */
66 	uint8_t		signature2[4];
67 	/* Image generation date, in microseconds since 1.1.2000 . */
68 	uint64_t	timestamp_us;
69 	/* Product version. */
70 	struct sb_boot_image_version
71 			product_version;
72 	/* Component version. */
73 	struct sb_boot_image_version
74 			component_version;
75 	/* Drive tag for the system drive. (since v1.1) */
76 	uint16_t	drive_tag;
77 	/* Padding. */
78 	uint8_t		padding1[6];
79 };
80 
81 #define	SB_VERSION_MAJOR	1
82 #define	SB_VERSION_MINOR	1
83 
84 /* Enable to HTLLC boot report. */
85 #define SB_IMAGE_FLAG_DISPLAY_PROGRESS	(1 << 0)
86 #define SB_IMAGE_FLAGS_MASK SB_IMAGE_FLAG_DISPLAY_PROGRESS
87 
88 struct sb_key_dictionary_key {
89 	/* The CBC-MAC of image and sections header. */
90 	uint8_t		cbc_mac[SB_BLOCK_SIZE];
91 	/* The AES key encrypted by image key (zero). */
92 	uint8_t		key[SB_BLOCK_SIZE];
93 };
94 
95 struct sb_ivt_header {
96 	uint32_t	header;
97 	uint32_t	entry;
98 	uint32_t	reserved1;
99 	uint32_t	dcd;
100 	uint32_t	boot_data;
101 	uint32_t	self;
102 	uint32_t	csf;
103 	uint32_t	reserved2;
104 };
105 
106 #define	SB_HAB_IVT_TAG			0xd1UL
107 #define	SB_HAB_DCD_TAG			0xd2UL
108 
109 #define	SB_HAB_VERSION			0x40UL
110 
111 /*
112  * The "size" field in the IVT header is not naturally aligned,
113  * use this macro to fill first 4 bytes of the IVT header without
114  * causing issues on some systems (esp. M68k, PPC, MIPS-BE, ARM-BE).
115  */
116 static inline uint32_t sb_hab_ivt_header(void)
117 {
118 	uint32_t ret = 0;
119 	ret |= SB_HAB_IVT_TAG << 24;
120 	ret |= sizeof(struct sb_ivt_header) << 16;
121 	ret |= SB_HAB_VERSION;
122 	return htonl(ret);
123 }
124 
125 struct sb_sections_header {
126 	/* Section number. */
127 	uint32_t	section_number;
128 	/* Offset of this sections first instruction after "TAG". */
129 	uint32_t	section_offset;
130 	/* Size of the section in 16b blocks. */
131 	uint32_t	section_size;
132 	/* Section flags. */
133 	uint32_t	section_flags;
134 };
135 
136 #define	SB_SECTION_FLAG_BOOTABLE	(1 << 0)
137 
138 struct sb_command {
139 	struct {
140 		uint8_t		checksum;
141 		uint8_t		tag;
142 		uint16_t	flags;
143 #define ROM_TAG_CMD_FLAG_ROM_LAST_TAG	0x1
144 #define ROM_LOAD_CMD_FLAG_DCD_LOAD	0x1	/* MX28 only */
145 #define ROM_JUMP_CMD_FLAG_HAB		0x1	/* MX28 only */
146 #define ROM_CALL_CMD_FLAG_HAB		0x1	/* MX28 only */
147 	} header;
148 
149 	union {
150 	struct {
151 		uint32_t	reserved[3];
152 	} nop;
153 	struct {
154 		uint32_t	section_number;
155 		uint32_t	section_length;
156 		uint32_t	section_flags;
157 	} tag;
158 	struct {
159 		uint32_t	address;
160 		uint32_t	count;
161 		uint32_t	crc32;
162 	} load;
163 	struct {
164 		uint32_t	address;
165 		uint32_t	count;
166 		uint32_t	pattern;
167 	} fill;
168 	struct {
169 		uint32_t	address;
170 		uint32_t	reserved;
171 		/* Passed in register r0 before JUMP */
172 		uint32_t	argument;
173 	} jump;
174 	struct {
175 		uint32_t	address;
176 		uint32_t	reserved;
177 		/* Passed in register r0 before CALL */
178 		uint32_t	argument;
179 	} call;
180 	struct {
181 		uint32_t	reserved1;
182 		uint32_t	reserved2;
183 		uint32_t	mode;
184 	} mode;
185 
186 	};
187 };
188 
189 /*
190  * Most of the mode names are same or at least similar
191  * on i.MX23 and i.MX28, but some of the mode names
192  * differ. The "name" field represents the mode name
193  * on i.MX28 as seen in Table 12-2 of the datasheet.
194  * The "altname" field represents the differently named
195  * fields on i.MX23 as seen in Table 35-3 of the
196  * datasheet.
197  */
198 static const struct {
199 	const char	*name;
200 	const char	*altname;
201 	const uint8_t	mode;
202 } modetable[] = {
203 	{ "USB",		NULL,		0x00 },
204 	{ "I2C",		NULL,		0x01 },
205 	{ "SPI2_FLASH",		"SPI1_FLASH",	0x02 },
206 	{ "SPI3_FLASH",		"SPI2_FLASH",	0x03 },
207 	{ "NAND_BCH",		NULL,		0x04 },
208 	{ "JTAG",		NULL,		0x06 },
209 	{ "SPI3_EEPROM",	"SPI2_EEPROM",	0x08 },
210 	{ "SD_SSP0",		NULL,		0x09 },
211 	{ "SD_SSP1",		NULL,		0x0A }
212 };
213 
214 enum sb_tag {
215 	ROM_NOP_CMD	= 0x00,
216 	ROM_TAG_CMD	= 0x01,
217 	ROM_LOAD_CMD	= 0x02,
218 	ROM_FILL_CMD	= 0x03,
219 	ROM_JUMP_CMD	= 0x04,
220 	ROM_CALL_CMD	= 0x05,
221 	ROM_MODE_CMD	= 0x06
222 };
223 
224 struct sb_source_entry {
225 	uint8_t		tag;
226 	uint32_t	address;
227 	uint32_t	flags;
228 	char		*filename;
229 };
230 
231 #endif	/* __MXSSB_H__ */
232