summaryrefslogtreecommitdiffstats
path: root/target/linux/brcm63xx/files/arch/mips/include/asm/mach-bcm63xx/bcm_tag.h
blob: d6a5ee811e9de033b62bf90c3cda1272804e35d1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#ifndef __BCM63XX_TAG_H
#define __BCM63XX_TAG_H

#define TAGVER_LEN 4                   /* Length of Tag Version */
#define TAGLAYOUT_LEN 4                /* Length of FlashLayoutVer */
#define SIG1_LEN 20		       /* Company Signature 1 Length */
#define SIG2_LEN 14                    /* Company Signature 2 Lenght */
#define BOARDID_LEN 16		       /* Length of BoardId */
#define ENDIANFLAG_LEN 2               /* Endian Flag Length */
#define CHIPID_LEN 6		       /* Chip Id Length */
#define IMAGE_LEN 10                   /* Length of Length Field */
#define ADDRESS_LEN 12                 /* Length of Address field */
#define DUALFLAG_LEN 2		       /* Dual Image flag Length */
#define INACTIVEFLAG_LEN 2	       /* Inactie Flag Length */
#define RSASIG_LEN 20   	       /* Length of RSA Signature in tag */
#define TAGINFO1_LEN 30                /* Length of vendor information field1 in tag */
#define FLASHLAYOUTVER_LEN 4	       /* Length of Flash Layout Version String tag */
#define TAGINFO2_LEN 16                /* Length of vendor information field2 in tag */
#define CRC_LEN 4                      /* Length of CRC in bytes */
#define ALTTAGINFO_LEN 54              /* Alternate length for vendor information; Pirelli */

#define NUM_PIRELLI 2
#define IMAGETAG_CRC_START		0xFFFFFFFF

#define PIRELLI_BOARDS { \
  "AGPF-S0", \
  "DWV-S0", \
}

/*
 * The broadcom firmware assumes the rootfs starts the image,
 * therefore uses the rootfs start (flashImageAddress)
 * to determine where to flash the image.  Since we have the kernel first
 * we have to give it the kernel address, but the crc uses the length
 * associated with this address (rootLength), which is added to the kernel
 * length (kernelLength) to determine the length of image to flash and thus
 * needs to be rootfs + deadcode (jffs2 EOF marker)
*/

struct bcm_tag {
	char tagVersion[TAGVER_LEN];           // 0-3: Version of the image tag
	char sig_1[SIG1_LEN];                  // 4-23: Company Line 1
	char sig_2[SIG2_LEN];                  // 24-37: Company Line 2
	char chipid[CHIPID_LEN];               // 38-43: Chip this image is for
	char boardid[BOARDID_LEN];             // 44-59: Board name
	char big_endian[ENDIANFLAG_LEN];       // 60-61: Map endianness -- 1 BE 0 LE
	char totalLength[IMAGE_LEN];           // 62-71: Total length of image
	char cfeAddress[ADDRESS_LEN];          // 72-83: Address in memory of CFE
	char cfeLength[IMAGE_LEN];             // 84-93: Size of CFE
	char flashImageStart[ADDRESS_LEN];     // 94-105: Address in memory of image start (kernel for OpenWRT, rootfs for stock firmware)
	char rootLength[IMAGE_LEN];            // 106-115: Size of rootfs
	char kernelAddress[ADDRESS_LEN];       // 116-127: Address in memory of kernel
	char kernelLength[IMAGE_LEN];          // 128-137: Size of kernel
	char dualImage[DUALFLAG_LEN];          // 138-139: Unused at present
	char inactiveFlag[INACTIVEFLAG_LEN];   // 140-141: Unused at present
        char rsa_signature[RSASIG_LEN];        // 142-161: RSA Signature (unused at present; some vendors may use this)
	char information1[TAGINFO1_LEN];       // 162-191: Compilation and related information (not generated/used by OpenWRT)
        char flashLayoutVer[FLASHLAYOUTVER_LEN];// 192-195: Version flash layout
        char fskernelCRC[CRC_LEN];             // 196-199: kernel+rootfs CRC32
	char information2[TAGINFO2_LEN];       // 200-215: Unused at present except Alice Gate where is is information
	char imageCRC[CRC_LEN];                // 216-219: CRC32 of image less imagetag (kernel for Alice Gate)
        char rootfsCRC[CRC_LEN];               // 220-223: CRC32 of rootfs partition
        char kernelCRC[CRC_LEN];               // 224-227: CRC32 of kernel partition
        char reserved1[8];                     // 228-235: Unused at present
        char headerCRC[CRC_LEN];               // 236-239: CRC32 of header excluding tagVersion
        char reserved2[16];                    // 240-255: Unused at present
};

#endif /* __BCM63XX_TAG_H */