blob: 5c59057c7710035ba0168f88015647c9f623790f [file] [log] [blame]
yuezonghe824eb0c2024-06-27 02:32:26 -07001/*
2 * (C) Copyright 2016, ZIXC Corporation.
3 *
4 * partitions.h
5 */
6#ifndef _PARTITION_TABLE_H_
7#define _PARTITION_TABLE_H_
8
9
10
11/*
12 +--------------+
13 | magic | uint32_t
14 +--------------+ +--------------+
15 | version | uint32_t 1 | z-load |
16 +--------------+ +--------------+
17 | entry nums | uint32_t 2 | u-boot |
18 +--------------+ +--------------+
19 | crc | uint32_t 3 | m0 |
20 +==============+ +--------------+
21 | name[1] | 4 | nv_r |
22 +--------------+ +--------------+
23 | offset | 5 | nv_w |
24 +--------------+ +--------------+
25 | size | 6 | ps |
26 +==============+ +--------------+
27 | | 7 | phy |
28 +==============+ +--------------+
29 | | 8 | zsp |
30 +==============+ +--------------+
31 9 | cdrom |
32 +--------------+
33 10 | fs |
34 +--------------+
35
36*/
37
38#define VIRTUAL_PART_NUM 2
39#define ARM_PS_IMAGE "cpups"
40#define ARM_ZSP_IMAGE "cpuphy"
41#define ARM_PHY_IMAGE "proc-phy"
42#define ARM_ZSP_AMT_IMAGE "cpuzspamt" //[ZhouXin] Add for AMT.
43#define ARM_APP_IMAGE "cpuap"//"proc-app" FPGA
44#define ARM_CAP_IMAGE "cpucap"
45
46#define ARM_RAMDISK_IMAGE "ramdisk"
47#define ARM_USERDATA_IMAGE "userdata"
48#define ARM_RECOVERY_USERDATA_IMAGE "recovery"
49#define ARM_UBOOT_IMAGE "uboot"
50#ifdef CONFIG_ZX297520V3E_MDL_AB
51#define ARM_ROOTFS_IMAGE "rootfs"
52#define ARM_ROOTFS2_IMAGE "rootfs2"
53#endif
54
55#define ARM_FOTA_BACKUP_IMAGE "fotabackup"
56#define ARM_FOTA_FLAG_IMAGE "fotaflag"
57#define ARM_FOTA_UPDATE_IMAGE "fotaupdate"
58#define ARM_FOTA_RECOVERY_IMAGE "recovery-kernel"
59
60#define ARM_NVRW_PARTITION "nvrw"
61#define ARM_AMT_FLAG_OFFSET 0x0
62
63/*nvrw·ÖÇødrv_nvrw ÆðʼµØÖ· ºóÃæ¶ÔÓ¦peripheral(3K) ÆðʼµØÖ·£¬*/
64#define DRV_NVRW_ADDRESS (0x00012000) //v3 0x32400 ,v2 0x68400
65#define ARM_DRV_PERIPHERAL_OFFSET (DRV_NVRW_ADDRESS+256+3*1024+3*1024+4*1024) /*drv_nvrw·ÖÇøOFFSET 0x2900*/
66
67
68#define ARM_FOTA_FLAG "FOTA-UPDATE"
69#define ARM_LOCAL_UPDATE_FLAG "LOCALUPDATE"
70#define ARM_RECOVERY_FLAG "FOTA-RECOVERY"
71#define ARM_FOTA_COPY_PS_FLAG "FOTA-PS" /*±íʾÐèÒª»¹Ô­ps°æ±¾*/
72#define ARM_FOTA_FLAG_LEN 32
73
74#define ARM_FOTA_UPDATE_SUCCESS_STRING "LOCAL-UP-SUCCESS"
75#define ARM_FOTA_UPDATE_FAILED_STRING "LOCAL-UP-FAIL"
76
77#define ARM_GMAC_INIT_FLAG "GMAC"
78#define ARM_GMAC_INIT_FLAG_LEN 5
79#define ARM_GMAC_INIT_OVERTIME_LEN 4
80
81
82#define ARM_RECOVERY_RESTART_OFFSET 0x40000
83#define ARM_RECOVERY_RESTART_FLAG "recovery reset"
84#define ARM_LOCALUP_RESULT_OFFSET 0x80000
85#define SZ_128K 0x00020000
86#define SZ_256K 0x00040000
87#define SZ_512K 0x00080000
88#define SZ_1M 0x00100000
89
90#define PART_TYPE_NAND "bin"
91#define PART_TYPE_ZFTL "nv"
92#define PART_TYPE_DDR "ddr"
93#define PART_TYPE_RAW "raw"
94#define PART_TYPE_FS "fs"
95
96#define PART1_NAME "zloader"
97#define PART1_OFFSET 0x00000000
98#define PART1_SIZE SZ_128K
99#define PART1_TYPE PART_TYPE_NAND
100
101#define PART2_NAME "uboot"
102#define PART2_OFFSET (PART1_OFFSET + PART1_SIZE)
103#define PART2_SIZE (SZ_1M + SZ_512K)
104#define PART2_TYPE PART_TYPE_NAND
105
106#define PART3_NAME "proc-lp"
107#define PART3_OFFSET (PART2_OFFSET + PART2_SIZE)
108#define PART3_SIZE (SZ_128K + SZ_256K)
109#define PART3_TYPE PART_TYPE_NAND
110
111#define PART4_NAME "nvr"
112#define PART4_OFFSET (PART3_OFFSET + PART3_SIZE)
113#define PART4_SIZE (SZ_1M * 2)
114#define PART4_TYPE PART_TYPE_ZFTL
115
116#define PART5_NAME "nvrw"
117#define PART5_OFFSET (PART4_OFFSET + PART4_SIZE)
118#define PART5_SIZE (SZ_1M * 8)
119#define PART5_TYPE PART_TYPE_ZFTL
120
121#define PART6_NAME "proc-ps"
122#define PART6_OFFSET (PART5_OFFSET + PART5_SIZE)
123#define PART6_SIZE (SZ_1M * 19)
124#define PART6_TYPE PART_TYPE_NAND
125
126#define PART7_NAME "proc-phy"
127#define PART7_OFFSET (PART6_OFFSET + PART6_SIZE)
128#define PART7_SIZE (SZ_1M * 19)
129#define PART7_TYPE PART_TYPE_NAND
130
131#define PART8_NAME "proc-zsp"
132#define PART8_OFFSET (PART7_OFFSET + PART7_SIZE)
133#define PART8_SIZE (SZ_1M * 1)
134#define PART8_TYPE PART_TYPE_NAND
135
136#define PART9_NAME "proc-app"
137#define PART9_OFFSET (PART8_OFFSET + PART8_SIZE)
138#define PART9_SIZE (SZ_1M * 10)
139#define PART9_TYPE PART_TYPE_NAND
140
141#define PART10_NAME "ramdisk"
142#define PART10_OFFSET (PART9_OFFSET + PART9_SIZE)
143#define PART10_SIZE (SZ_1M * 8)
144#define PART10_TYPE PART_TYPE_NAND
145
146#define PART11_NAME "cdrom"
147#define PART11_OFFSET (PART10_OFFSET + PART10_SIZE)
148#define PART11_SIZE (SZ_1M * 80)
149#define PART11_TYPE PART_TYPE_NAND
150
151#define PART12_NAME "fs-ffx"
152#define PART12_OFFSET (PART11_OFFSET + PART11_SIZE)
153#define PART12_SIZE (SZ_1M * 8)
154#define PART12_TYPE PART_TYPE_FS
155
156#define PART13_NAME "userdata"
157#define PART13_OFFSET (PART12_OFFSET + PART12_SIZE)
158#define PART13_SIZE (SZ_1M * 40)
159#define PART13_TYPE PART_TYPE_FS
160
161#define PART14_NAME "ddr"
162#define PART14_OFFSET 0x0
163#define PART14_SIZE 0xffffffff
164#define PART14_TYPE PART_TYPE_DDR
165
166#define PART15_NAME "raw"
167#define PART15_OFFSET 0x0
168#define PART15_SIZE (SZ_1M * 256)
169#define PART15_TYPE PART_TYPE_RAW
170
171#define PART_END 0,0,0
172#define PART1 PART1_NAME, PART1_TYPE, PART1_OFFSET, PART1_SIZE
173#define PART2 PART2_NAME, PART2_TYPE, PART2_OFFSET, PART2_SIZE
174#define PART3 PART3_NAME, PART3_TYPE, PART3_OFFSET, PART3_SIZE
175#define PART4 PART4_NAME, PART4_TYPE, PART4_OFFSET, PART4_SIZE
176#define PART5 PART5_NAME, PART5_TYPE, PART5_OFFSET, PART5_SIZE
177#define PART6 PART6_NAME, PART6_TYPE, PART6_OFFSET, PART6_SIZE
178#define PART7 PART7_NAME, PART7_TYPE, PART7_OFFSET, PART7_SIZE
179#define PART8 PART8_NAME, PART8_TYPE, PART8_OFFSET, PART8_SIZE
180#define PART9 PART9_NAME, PART9_TYPE, PART9_OFFSET, PART9_SIZE
181#define PART10 PART10_NAME, PART10_TYPE, PART10_OFFSET, PART10_SIZE
182#define PART11 PART11_NAME, PART11_TYPE, PART11_OFFSET, PART11_SIZE
183#define PART12 PART12_NAME, PART12_TYPE, PART12_OFFSET, PART12_SIZE
184#define PART13 PART13_NAME, PART13_TYPE, PART13_OFFSET, PART13_SIZE
185#define PART14 PART14_NAME, PART14_TYPE, PART14_OFFSET, PART14_SIZE
186#define PART15 PART15_NAME, PART15_TYPE, PART15_OFFSET, PART15_SIZE
187#define PART16 PART_END
188#define PART17 PART_END
189#define PART18 PART_END
190#define PART19 PART_END
191#define PART20 PART_END
192#define PART21 PART_END
193#define PART22 PART_END
194#define PART23 PART_END
195#define PART24 PART_END
196#define PART25 PART_END
197#define PART26 PART_END
198#define PART27 PART_END
199#define PART28 PART_END
200#define PART29 PART_END
201#define PART30 PART_END
202
203
204
205#define MAX_ENTRYS 30
206#define PARTITION_ENTRYS 15 /* ʵ¼ÊʹÓõķÖÇø¸öÊý */
207#define PARTITION_MAGIC 0x31594876 /* ͬ²½ Z-LOAD */
208#define PARTITION_PLARTNANME "WF7520"
209#define PARTITION_VERSION 0x00201304 /* */
210#define PARTITION_CRC 0x12345678
211#define PARTITION_SIZE 0X1000 /* ·ÖÇø±íµÄ´óС */
212
213
214typedef struct partition_entry {
215 unsigned char part_name[16];
216 unsigned char part_type[16];
217 unsigned int part_offset;
218 unsigned int part_size;
219}partition_entry_t;
220
221typedef struct partition_table {
222 unsigned int magic;
223 unsigned char platform_name[16];
224 unsigned int version; /* ·ÖÇø°æ±¾ */
225 unsigned int entrys; /* ×ܵķÖÇø¸öÊý */
226 unsigned int crc;
227 partition_entry_t table[MAX_ENTRYS];
228}partition_table_t;
229
230typedef struct image_bin_header {
231 unsigned char filename[64]; // ÎļþÃû,total 128
232 unsigned char partitonname[16]; // ·ÖÇøÃû
233 unsigned char partitontype[16]; // ·ÖÇøÀàÐÍ
234 unsigned int filelength; // Îļþ³¤¶È
235 unsigned int partitonoffset; // ÔÚ·ÖÇøÖеĵØÖ·
236 unsigned int fileaddr; //ÎļþÔںϳÉÎļþÖеÄλÖÃ
237 unsigned char btUse[20];
238}image_bin_header_t;
239typedef struct master_header
240{
241 unsigned char btFileId[16]; // ¶àBinºÏÒ»Îļþ±êʶ,total 208bytes
242 unsigned char btVersionIn[32];
243 unsigned char btVersionOut[32];
244 unsigned int dwFileNumber;
245 unsigned int dwDeviceType;
246 unsigned int dwNV;
247
248 unsigned int dwFileLengthTotal; // Îļþ×ܳ¤¶È
249 unsigned int dwCheckSum; // УÑé
250 unsigned int dwImageOffset; // ¾µÏñÊý¾ÝÔÚ¶àBinºÏÒ»ÎļþÖÐÆ«ÒÆ
251 unsigned int dwTLoaderAdd; // TLoaderÔÚ¶àBinºÏÒ»ÎļþÖÐµÄÆ«ÒÆ
252 unsigned int dwTLoaderLength; // TLoader³¤¶È
253 unsigned int dwTBootAdd; // TBootÔÚ¶àBinºÏÒ»ÎļþÖÐµÄÆ«ÒÆ
254 unsigned int dwTBootLength; // TBoot³¤¶È
255 unsigned int dwPartitonAdd; // PartitonÔÚ¶àBinºÏÒ»ÎļþÖÐµÄÆ«ÒÆ
256 unsigned int dwPartitionLength ; // Partition³¤¶È
257 unsigned char btUse[80];
258
259 image_bin_header_t image[50];
260} master_header_t;
261
262#ifdef CONFIG_ZX297520V3E_MDL_AB
263/*
264flags partition
265
266*/
267/*˫ϵͳÀàÐÍ*/
268#define FLAGS_BOOT_FOTA_OFFSET (0X0UL)
269#define FLAGS_BOOT_FOTA_SIZE (0X80000UL)
270#define FLAGS_BOOT_ENV_OFFSET (FLAGS_BOOT_FOTA_OFFSET + FLAGS_BOOT_FOTA_SIZE)
271#define FLAGS_BOOT_ENV_SIZE (0X80000UL)
272#define FLAGS_BACKUP_OFFSET (FLAGS_BOOT_ENV_OFFSET + FLAGS_BOOT_ENV_SIZE)
273
274#define FLAGS_MAGIC (0X464C4147UL)
275
276#define DUALSYSTEM_STATUS_BOOTABLE (0XB0AB) /*¿ÉÆô¶¯*/
277#define DUALSYSTEM_STATUS_SUCCESSFUL (0X5CCF) /*Äܳɹ¦Æô¶¯*/
278#define DUALSYSTEM_STATUS_UNBOOTABLE (0XBABE) /*²»¿ÉÆô¶¯*/
279#define FLAGS_PARTITION_ERROR (0x1111) /*·ÖÇøÒì³£*/
280
281
282
283typedef struct
284{
285 int status; /*bootable/successful/unbootable*/
286 int try_cnt;
287}T_DualSystem_Status;
288
289typedef enum
290{
291 DUAL_SYSTEM = 0X875A, /*µÚÒ»¸öϵͳ*/
292 DUAL_SYSTEM2 = 0X986B, /*µÚ¶þ¸öϵͳ*/
293}T_BOOT_TARGET;
294
295/*˫ϵͳÀàÐÍ*/
296typedef enum
297{
298 DUALSYSTEM_RECOVERY = 0X7575, /*normal-recovery˫ϵͳ*/
299 DUALSYSTEM_AA = 0XAAAA, /*AA˫ϵͳ*/
300 DUALSYSTEM_AB = 0XABAB /*AB˫ϵͳ*/
301}T_BOOT_DUALSYSTEM_TYPE;
302
303typedef struct
304{
305 uint32_t magic; /*Êý¾ÝÓÐЧÐÔħÊõ×Ö*/
306 T_BOOT_TARGET boot_to; /*µ±Ç°Æô¶¯ÏµÍ³±êÖ¾*/
307 uint32_t fota_status; /*fota״̬*/
308 T_DualSystem_Status system; /*µÚÒ»¸öϵͳ״̬*/
309 T_DualSystem_Status system2; /*µÚ¶þ¸öϵͳ״̬*/
310}T_BOOT_FOTA_FLAG;
311
312typedef struct
313{
314 unsigned int magic; /*Êý¾ÝÓÐЧÐÔħÊõ×Ö*/
315 T_BOOT_DUALSYSTEM_TYPE dualsys_type; /*˫ϵͳÀàÐÍ*/
316 char system_boot_env[128];
317 char system2_boot_env[128];
318}T_BOOT_ENV;
319
320typedef struct
321{
322 T_BOOT_FOTA_FLAG boot_flag;
323 T_BOOT_ENV boot_env;
324}T_FOTA_FLAG_INFO;
325#endif
326
327#ifdef CREAT_PARTITION_TABLE
328partition_table_t g_partiton_table =
329 {
330 PARTITION_MAGIC, \
331 PARTITION_PLARTNANME,\
332 PARTITION_VERSION,\
333 PARTITION_ENTRYS, \
334 PARTITION_CRC,\
335 { { PART1 },\
336 { PART2 },\
337 { PART3 },\
338 { PART4 },\
339 { PART5 },\
340 { PART6 },\
341 { PART7 },\
342 { PART8 },\
343 { PART9 },\
344 { PART10 },\
345 { PART11 },\
346 { PART12 },\
347 { PART13 },\
348 { PART14 },\
349 { PART15 },\
350 { PART16 },\
351 { PART17 },\
352 { PART18 },\
353 { PART19 },\
354 { PART20 },\
355 { PART21 },\
356 { PART22 },\
357 { PART23 },\
358 { PART24 },\
359 { PART25 },\
360 { PART26 },\
361 { PART27 },\
362 { PART28 },\
363 { PART29 },\
364 { PART30 }}
365 };
366#endif
367
368#ifndef CREAT_PARTITION_TABLE
369int read_partition_and_check( void );
370partition_entry_t *find_partition_para( uchar * name );
371void add_partition_to_bootargs(void);
372#endif
373
374#endif /* _PARTITION_TABLE_H_ */