]>
Commit | Line | Data |
---|---|---|
bce88370 MV |
1 | /* |
2 | * Freescale i.MX28 SB image generator | |
3 | * | |
4 | * Copyright (C) 2012 Marek Vasut <[email protected]> | |
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 | ||
7a139959 AI |
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 | |
bce88370 MV |
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__ */ |