1#ifndef __BCM63XX_TAG_H
2#define __BCM63XX_TAG_H
3
4#define TAGVER_LEN 4                   /* Length of Tag Version */
5#define TAGLAYOUT_LEN 4                /* Length of FlashLayoutVer */
6#define SIG1_LEN 20		       /* Company Signature 1 Length */
7#define SIG2_LEN 14                    /* Company Signature 2 Lenght */
8#define BOARDID_LEN 16		       /* Length of BoardId */
9#define ENDIANFLAG_LEN 2               /* Endian Flag Length */
10#define CHIPID_LEN 6		       /* Chip Id Length */
11#define IMAGE_LEN 10                   /* Length of Length Field */
12#define ADDRESS_LEN 12                 /* Length of Address field */
13#define DUALFLAG_LEN 2		       /* Dual Image flag Length */
14#define INACTIVEFLAG_LEN 2	       /* Inactie Flag Length */
15#define RSASIG_LEN 20   	       /* Length of RSA Signature in tag */
16#define TAGINFO1_LEN 30                /* Length of vendor information field1 in tag */
17#define FLASHLAYOUTVER_LEN 4	       /* Length of Flash Layout Version String tag */
18#define TAGINFO2_LEN 16                /* Length of vendor information field2 in tag */
19#define CRC_LEN 4                      /* Length of CRC in bytes */
20#define ALTTAGINFO_LEN 54              /* Alternate length for vendor information; Pirelli */
21
22#define NUM_PIRELLI 2
23#define IMAGETAG_CRC_START		0xFFFFFFFF
24
25#define PIRELLI_BOARDS { \
26  "AGPF-S0", \
27  "DWV-S0", \
28}
29
30/*
31 * The broadcom firmware assumes the rootfs starts the image,
32 * therefore uses the rootfs start (flashImageAddress)
33 * to determine where to flash the image.  Since we have the kernel first
34 * we have to give it the kernel address, but the crc uses the length
35 * associated with this address (rootLength), which is added to the kernel
36 * length (kernelLength) to determine the length of image to flash and thus
37 * needs to be rootfs + deadcode (jffs2 EOF marker)
38*/
39
40struct bcm_tag {
41	char tagVersion[TAGVER_LEN];           // 0-3: Version of the image tag
42	char sig_1[SIG1_LEN];                  // 4-23: Company Line 1
43	char sig_2[SIG2_LEN];                  // 24-37: Company Line 2
44	char chipid[CHIPID_LEN];               // 38-43: Chip this image is for
45	char boardid[BOARDID_LEN];             // 44-59: Board name
46	char big_endian[ENDIANFLAG_LEN];       // 60-61: Map endianness -- 1 BE 0 LE
47	char totalLength[IMAGE_LEN];           // 62-71: Total length of image
48	char cfeAddress[ADDRESS_LEN];          // 72-83: Address in memory of CFE
49	char cfeLength[IMAGE_LEN];             // 84-93: Size of CFE
50	char flashImageStart[ADDRESS_LEN];     // 94-105: Address in memory of image start (kernel for OpenWRT, rootfs for stock firmware)
51	char flashRootLength[IMAGE_LEN];            // 106-115: Size of rootfs for flashing
52	char kernelAddress[ADDRESS_LEN];       // 116-127: Address in memory of kernel
53	char kernelLength[IMAGE_LEN];          // 128-137: Size of kernel
54	char dualImage[DUALFLAG_LEN];          // 138-139: Unused at present
55	char inactiveFlag[INACTIVEFLAG_LEN];   // 140-141: Unused at present
56        char rsa_signature[RSASIG_LEN];        // 142-161: RSA Signature (unused at present; some vendors may use this)
57	char information1[TAGINFO1_LEN];       // 162-191: Compilation and related information (not generated/used by OpenWRT)
58        char flashLayoutVer[FLASHLAYOUTVER_LEN];// 192-195: Version flash layout
59        char fskernelCRC[CRC_LEN];             // 196-199: kernel+rootfs CRC32
60	char information2[TAGINFO2_LEN];       // 200-215: Unused at present except Alice Gate where is is information
61	char imageCRC[CRC_LEN];                // 216-219: CRC32 of image less imagetag (kernel for Alice Gate)
62        char rootfsCRC[CRC_LEN];               // 220-223: CRC32 of rootfs partition
63        char kernelCRC[CRC_LEN];               // 224-227: CRC32 of kernel partition
64        char imageSequence[4];		       // 228-231: Image sequence number
65        char rootLength[4];                    // 232-235: steal from reserved1 to keep the real root length so we can use in the flash map even after we have change the rootLength to 0 to satisfy devices that check CRC on every boot
66        char headerCRC[CRC_LEN];               // 236-239: CRC32 of header excluding tagVersion
67        char reserved2[16];                    // 240-255: Unused at present
68};
69
70#endif /* __BCM63XX_TAG_H */
71