linux: export bcm963xx_tag.h to userspace
authorJonas Gorski <jogo@openwrt.org>
Tue, 6 Nov 2012 15:21:46 +0000 (15:21 +0000)
committerJonas Gorski <jogo@openwrt.org>
Tue, 6 Nov 2012 15:21:46 +0000 (15:21 +0000)
Export bcm963xx_tag.h so mtd can use it without using kernel includes.

Signed-off-by: Catalin Patulea <cat@vv.carleton.ca>
[jonas.gorski@gmail.com: fixup bcm63xx patches, completely remove header
 from original location, refresh patches, use  a more matching patch
 number, port to 3.6]
Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com>
SVN-Revision: 34103

17 files changed:
package/mtd/src/imagetag.c
target/linux/brcm63xx/patches-3.3/304-boardid_fixup.patch
target/linux/brcm63xx/patches-3.3/401-MIPS-BCM63XX-register-ohci-device.patch
target/linux/brcm63xx/patches-3.3/403-MIPS-BCM63XX-register-ehci-device.patch
target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch
target/linux/brcm63xx/patches-3.3/430-MTD-bcm63xxpart-use-nvram-for-PSI-size.patch
target/linux/brcm63xx/patches-3.3/432-BCM63XX-allow-providing-fixup-data-in-board-data.patch
target/linux/brcm63xx/patches-3.6/304-boardid_fixup.patch
target/linux/brcm63xx/patches-3.6/401-MIPS-BCM63XX-register-ohci-device.patch
target/linux/brcm63xx/patches-3.6/403-MIPS-BCM63XX-register-ehci-device.patch
target/linux/brcm63xx/patches-3.6/405-bcm963xx_real_rootfs_length.patch
target/linux/brcm63xx/patches-3.6/430-MTD-bcm63xxpart-use-nvram-for-PSI-size.patch
target/linux/brcm63xx/patches-3.6/432-BCM63XX-allow-providing-fixup-data-in-board-data.patch
target/linux/generic/patches-3.3/260-move_bcm963xx_tag.patch [new file with mode: 0644]
target/linux/generic/patches-3.3/850-glamo_headers.patch
target/linux/generic/patches-3.6/260-move_bcm963xx_tag.patch [new file with mode: 0644]
target/linux/generic/patches-3.6/850-glamo_headers.patch

index 9f5c193c42418a43590b96c1c18e2707ede12d93..a53c17a7032cafc8c9cd8151dee4b352c16e2b20 100644 (file)
@@ -32,7 +32,7 @@
 
 #include <sys/ioctl.h>
 #include <mtd/mtd-user.h>
-#include <../arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h>
+#include <linux/bcm963xx_tag.h>
 
 #include "mtd.h"
 #include "crc32.h"
index 3b9e23ef7d376417eea9b6b32b75d5aea0f0f8f4..c3dd8e9898f22104b428671ac1786d4ad0e8a3fe 100644 (file)
@@ -4,7 +4,7 @@
  #include <bcm63xx_dev_pcmcia.h>
  #include <bcm63xx_dev_spi.h>
  #include <board_bcm963xx.h>
-+#include <bcm963xx_tag.h>
++#include <linux/bcm963xx_tag.h>
  
  #define PFX   "board_bcm963xx: "
  
index 33b1a39350dade41143102534847773bf000be23..8218fae44e46288837e559884501e14b4412ebde 100644 (file)
@@ -67,7 +67,7 @@ Subject: [PATCH 24/63] MIPS: BCM63XX: register ohci device.
  #include <bcm63xx_dev_spi.h>
 +#include <bcm63xx_dev_usb_ohci.h>
  #include <board_bcm963xx.h>
- #include <bcm963xx_tag.h>
+ #include <linux/bcm963xx_tag.h>
  
 @@ -916,6 +917,9 @@ int __init board_register_devices(void)
            !board_get_mac_address(board.enet1.mac_addr))
index d6773d5657f3035bbd718e6bdd71c76fb412d7e7..8606d414517e0abb48d7a2e3eb58cce17eef7c6a 100644 (file)
@@ -49,7 +49,7 @@ Subject: [PATCH 26/63] MIPS: BCM63XX: register ehci device.
  #include <bcm63xx_dev_usb_ohci.h>
 +#include <bcm63xx_dev_usb_ehci.h>
  #include <board_bcm963xx.h>
- #include <bcm963xx_tag.h>
+ #include <linux/bcm963xx_tag.h>
  
 @@ -917,6 +918,9 @@ int __init board_register_devices(void)
            !board_get_mac_address(board.enet1.mac_addr))
index 856b9e2674a36bc5aa70b508f4155d5f06b54501..f0e6c4c78b545acf303cfecf9f207bec304a8174 100644 (file)
@@ -1,5 +1,5 @@
---- a/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h
-+++ b/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h
+--- a/include/linux/bcm963xx_tag.h
++++ b/include/linux/bcm963xx_tag.h
 @@ -85,8 +85,10 @@ struct bcm_tag {
        __u32 rootfs_crc;
        /* 224-227: CRC32 of kernel partition */
index 5ca6f47970214ac360b4dce3b8a7500661e48ef5..fd1bfc4b8ceead9aed709af5a5fc5e6ccd09e68d 100644 (file)
@@ -14,7 +14,7 @@ Subject: [PATCH 62/79] MTD: bcm63xxpart: use nvram for PSI size
  #include <linux/mtd/partitions.h>
  
 +#include <asm/mach-bcm63xx/bcm63xx_nvram.h>
- #include <asm/mach-bcm63xx/bcm963xx_tag.h>
+ #include <linux/bcm963xx_tag.h>
  #include <asm/mach-bcm63xx/board_bcm963xx.h>
  
 @@ -90,7 +91,8 @@ static int bcm63xx_parse_cfe_partitions(
index e0e4a473804a0abf062c333c94f97bc48a17913f..8f04fa75c29a79518fdadc235c1e9ae3ec0f67bf 100644 (file)
@@ -13,7 +13,7 @@ Subject: [PATCH 67/80] BCM63XX: allow providing fixup data in board data
 @@ -33,6 +33,7 @@
  #include <bcm63xx_dev_usb_ehci.h>
  #include <board_bcm963xx.h>
- #include <bcm963xx_tag.h>
+ #include <linux/bcm963xx_tag.h>
 +#include <pci_ath9k_fixup.h>
  
  #define PFX   "board_bcm963xx: "
index 301c9161416814a1b4c361ef8318da0b3d477ab2..a463fe739c04cb593601d6678b811bd997a63fb6 100644 (file)
@@ -4,7 +4,7 @@
  #include <bcm63xx_dev_pcmcia.h>
  #include <bcm63xx_dev_spi.h>
  #include <board_bcm963xx.h>
-+#include <bcm963xx_tag.h>
++#include <linux/bcm963xx_tag.h>
  
  #define PFX   "board_bcm963xx: "
  
index a62539121d7d3d49cf308930bbde7ae452e22e14..28a7e2f1f326383cb7eac706ce5dd8539f06c947 100644 (file)
@@ -67,7 +67,7 @@ Subject: [PATCH 24/63] MIPS: BCM63XX: register ohci device.
  #include <bcm63xx_dev_spi.h>
 +#include <bcm63xx_dev_usb_ohci.h>
  #include <board_bcm963xx.h>
- #include <bcm963xx_tag.h>
+ #include <linux/bcm963xx_tag.h>
  
 @@ -961,6 +962,9 @@ int __init board_register_devices(void)
            !board_get_mac_address(board.enet1.mac_addr))
index f50be1420bf6a7e3b3047e1068d3470d5c6e34a6..eb27ed96d33055506d6340149dd6732dcdf9eb71 100644 (file)
@@ -49,7 +49,7 @@ Subject: [PATCH 26/63] MIPS: BCM63XX: register ehci device.
  #include <bcm63xx_dev_usb_ohci.h>
 +#include <bcm63xx_dev_usb_ehci.h>
  #include <board_bcm963xx.h>
- #include <bcm963xx_tag.h>
+ #include <linux/bcm963xx_tag.h>
  
 @@ -962,6 +963,9 @@ int __init board_register_devices(void)
            !board_get_mac_address(board.enet1.mac_addr))
index 856b9e2674a36bc5aa70b508f4155d5f06b54501..f0e6c4c78b545acf303cfecf9f207bec304a8174 100644 (file)
@@ -1,5 +1,5 @@
---- a/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h
-+++ b/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h
+--- a/include/linux/bcm963xx_tag.h
++++ b/include/linux/bcm963xx_tag.h
 @@ -85,8 +85,10 @@ struct bcm_tag {
        __u32 rootfs_crc;
        /* 224-227: CRC32 of kernel partition */
index 5ca6f47970214ac360b4dce3b8a7500661e48ef5..fd1bfc4b8ceead9aed709af5a5fc5e6ccd09e68d 100644 (file)
@@ -14,7 +14,7 @@ Subject: [PATCH 62/79] MTD: bcm63xxpart: use nvram for PSI size
  #include <linux/mtd/partitions.h>
  
 +#include <asm/mach-bcm63xx/bcm63xx_nvram.h>
- #include <asm/mach-bcm63xx/bcm963xx_tag.h>
+ #include <linux/bcm963xx_tag.h>
  #include <asm/mach-bcm63xx/board_bcm963xx.h>
  
 @@ -90,7 +91,8 @@ static int bcm63xx_parse_cfe_partitions(
index cb5374f33bf0fe58bf3a6ab59b4dbdef71f54d78..5d35cbfdfb0546a42c618ca903767bac99a58743 100644 (file)
@@ -13,7 +13,7 @@ Subject: [PATCH 67/80] BCM63XX: allow providing fixup data in board data
 @@ -33,6 +33,7 @@
  #include <bcm63xx_dev_usb_ehci.h>
  #include <board_bcm963xx.h>
- #include <bcm963xx_tag.h>
+ #include <linux/bcm963xx_tag.h>
 +#include <pci_ath9k_fixup.h>
  
  #define PFX   "board_bcm963xx: "
diff --git a/target/linux/generic/patches-3.3/260-move_bcm963xx_tag.patch b/target/linux/generic/patches-3.3/260-move_bcm963xx_tag.patch
new file mode 100644 (file)
index 0000000..b281326
--- /dev/null
@@ -0,0 +1,219 @@
+--- a/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h
++++ /dev/null
+@@ -1,96 +0,0 @@
+-#ifndef __BCM963XX_TAG_H
+-#define __BCM963XX_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 Length */
+-#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 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 (flash_image_address)
+- * 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 (root_length), which is added to the kernel
+- * length (kernel_length) to determine the length of image to flash and thus
+- * needs to be rootfs + deadcode (jffs2 EOF marker)
+-*/
+-
+-struct bcm_tag {
+-      /* 0-3: Version of the image tag */
+-      char tag_version[TAGVER_LEN];
+-      /* 4-23: Company Line 1 */
+-      char sig_1[SIG1_LEN];
+-      /*  24-37: Company Line 2 */
+-      char sig_2[SIG2_LEN];
+-      /* 38-43: Chip this image is for */
+-      char chip_id[CHIPID_LEN];
+-      /* 44-59: Board name */
+-      char board_id[BOARDID_LEN];
+-      /* 60-61: Map endianness -- 1 BE 0 LE */
+-      char big_endian[ENDIANFLAG_LEN];
+-      /* 62-71: Total length of image */
+-      char total_length[IMAGE_LEN];
+-      /* 72-83: Address in memory of CFE */
+-      char cfe__address[ADDRESS_LEN];
+-      /* 84-93: Size of CFE */
+-      char cfe_length[IMAGE_LEN];
+-      /* 94-105: Address in memory of image start
+-       * (kernel for OpenWRT, rootfs for stock firmware)
+-       */
+-      char flash_image_start[ADDRESS_LEN];
+-      /* 106-115: Size of rootfs */
+-      char root_length[IMAGE_LEN];
+-      /* 116-127: Address in memory of kernel */
+-      char kernel_address[ADDRESS_LEN];
+-      /* 128-137: Size of kernel */
+-      char kernel_length[IMAGE_LEN];
+-      /* 138-139: Unused at the moment */
+-      char dual_image[DUALFLAG_LEN];
+-      /* 140-141: Unused at the moment */
+-      char inactive_flag[INACTIVEFLAG_LEN];
+-      /* 142-161: RSA Signature (not used; some vendors may use this) */
+-      char rsa_signature[RSASIG_LEN];
+-      /* 162-191: Compilation and related information (not used in OpenWrt) */
+-      char information1[TAGINFO1_LEN];
+-      /* 192-195: Version flash layout */
+-      char flash_layout_ver[FLASHLAYOUTVER_LEN];
+-      /* 196-199: kernel+rootfs CRC32 */
+-      __u32 fskernel_crc;
+-      /* 200-215: Unused except on Alice Gate where is is information */
+-      char information2[TAGINFO2_LEN];
+-      /* 216-219: CRC32 of image less imagetag (kernel for Alice Gate) */
+-      __u32 image_crc;
+-      /* 220-223: CRC32 of rootfs partition */
+-      __u32 rootfs_crc;
+-      /* 224-227: CRC32 of kernel partition */
+-      __u32 kernel_crc;
+-      /* 228-235: Unused at present */
+-      char reserved1[8];
+-      /* 236-239: CRC32 of header excluding last 20 bytes */
+-      __u32 header_crc;
+-      /* 240-255: Unused at present */
+-      char reserved2[16];
+-};
+-
+-#endif /* __BCM63XX_TAG_H */
+--- a/drivers/mtd/bcm63xxpart.c
++++ b/drivers/mtd/bcm63xxpart.c
+@@ -32,7 +32,7 @@
+ #include <linux/mtd/mtd.h>
+ #include <linux/mtd/partitions.h>
+-#include <asm/mach-bcm63xx/bcm963xx_tag.h>
++#include <linux/bcm963xx_tag.h>
+ #include <asm/mach-bcm63xx/board_bcm963xx.h>
+ #define BCM63XX_EXTENDED_SIZE 0xBFC00000      /* Extended flash address */
+--- a/include/linux/Kbuild
++++ b/include/linux/Kbuild
+@@ -77,6 +77,7 @@ header-y += blk_types.h
+ header-y += blkpg.h
+ header-y += blktrace_api.h
+ header-y += bpqether.h
++header-y += bcm963xx_tag.h
+ header-y += bsg.h
+ header-y += can.h
+ header-y += capability.h
+--- /dev/null
++++ b/include/linux/bcm963xx_tag.h
+@@ -0,0 +1,96 @@
++#ifndef __BCM963XX_TAG_H
++#define __BCM963XX_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 Length */
++#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 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 (flash_image_address)
++ * 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 (root_length), which is added to the kernel
++ * length (kernel_length) to determine the length of image to flash and thus
++ * needs to be rootfs + deadcode (jffs2 EOF marker)
++*/
++
++struct bcm_tag {
++      /* 0-3: Version of the image tag */
++      char tag_version[TAGVER_LEN];
++      /* 4-23: Company Line 1 */
++      char sig_1[SIG1_LEN];
++      /*  24-37: Company Line 2 */
++      char sig_2[SIG2_LEN];
++      /* 38-43: Chip this image is for */
++      char chip_id[CHIPID_LEN];
++      /* 44-59: Board name */
++      char board_id[BOARDID_LEN];
++      /* 60-61: Map endianness -- 1 BE 0 LE */
++      char big_endian[ENDIANFLAG_LEN];
++      /* 62-71: Total length of image */
++      char total_length[IMAGE_LEN];
++      /* 72-83: Address in memory of CFE */
++      char cfe__address[ADDRESS_LEN];
++      /* 84-93: Size of CFE */
++      char cfe_length[IMAGE_LEN];
++      /* 94-105: Address in memory of image start
++       * (kernel for OpenWRT, rootfs for stock firmware)
++       */
++      char flash_image_start[ADDRESS_LEN];
++      /* 106-115: Size of rootfs */
++      char root_length[IMAGE_LEN];
++      /* 116-127: Address in memory of kernel */
++      char kernel_address[ADDRESS_LEN];
++      /* 128-137: Size of kernel */
++      char kernel_length[IMAGE_LEN];
++      /* 138-139: Unused at the moment */
++      char dual_image[DUALFLAG_LEN];
++      /* 140-141: Unused at the moment */
++      char inactive_flag[INACTIVEFLAG_LEN];
++      /* 142-161: RSA Signature (not used; some vendors may use this) */
++      char rsa_signature[RSASIG_LEN];
++      /* 162-191: Compilation and related information (not used in OpenWrt) */
++      char information1[TAGINFO1_LEN];
++      /* 192-195: Version flash layout */
++      char flash_layout_ver[FLASHLAYOUTVER_LEN];
++      /* 196-199: kernel+rootfs CRC32 */
++      __u32 fskernel_crc;
++      /* 200-215: Unused except on Alice Gate where is is information */
++      char information2[TAGINFO2_LEN];
++      /* 216-219: CRC32 of image less imagetag (kernel for Alice Gate) */
++      __u32 image_crc;
++      /* 220-223: CRC32 of rootfs partition */
++      __u32 rootfs_crc;
++      /* 224-227: CRC32 of kernel partition */
++      __u32 kernel_crc;
++      /* 228-235: Unused at present */
++      char reserved1[8];
++      /* 236-239: CRC32 of header excluding last 20 bytes */
++      __u32 header_crc;
++      /* 240-255: Unused at present */
++      char reserved2[16];
++};
++
++#endif /* __BCM63XX_TAG_H */
index c75e1d62ea024bb5a94413bd38e2af842d5e92ff..d6d49fdf50ac790c37a18daaf878752ea375531e 100644 (file)
@@ -10,7 +10,7 @@
  #define FB_ACCEL_NEOMAGIC_NM2093 92   /* NeoMagic NM2093              */
 --- a/include/linux/Kbuild
 +++ b/include/linux/Kbuild
-@@ -144,6 +144,8 @@ header-y += generic_serial.h
+@@ -145,6 +145,8 @@ header-y += generic_serial.h
  header-y += genetlink.h
  header-y += gfs2_ondisk.h
  header-y += gigaset_dev.h
diff --git a/target/linux/generic/patches-3.6/260-move_bcm963xx_tag.patch b/target/linux/generic/patches-3.6/260-move_bcm963xx_tag.patch
new file mode 100644 (file)
index 0000000..dd2fbae
--- /dev/null
@@ -0,0 +1,219 @@
+--- a/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h
++++ /dev/null
+@@ -1,96 +0,0 @@
+-#ifndef __BCM963XX_TAG_H
+-#define __BCM963XX_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 Length */
+-#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 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 (flash_image_address)
+- * 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 (root_length), which is added to the kernel
+- * length (kernel_length) to determine the length of image to flash and thus
+- * needs to be rootfs + deadcode (jffs2 EOF marker)
+-*/
+-
+-struct bcm_tag {
+-      /* 0-3: Version of the image tag */
+-      char tag_version[TAGVER_LEN];
+-      /* 4-23: Company Line 1 */
+-      char sig_1[SIG1_LEN];
+-      /*  24-37: Company Line 2 */
+-      char sig_2[SIG2_LEN];
+-      /* 38-43: Chip this image is for */
+-      char chip_id[CHIPID_LEN];
+-      /* 44-59: Board name */
+-      char board_id[BOARDID_LEN];
+-      /* 60-61: Map endianness -- 1 BE 0 LE */
+-      char big_endian[ENDIANFLAG_LEN];
+-      /* 62-71: Total length of image */
+-      char total_length[IMAGE_LEN];
+-      /* 72-83: Address in memory of CFE */
+-      char cfe__address[ADDRESS_LEN];
+-      /* 84-93: Size of CFE */
+-      char cfe_length[IMAGE_LEN];
+-      /* 94-105: Address in memory of image start
+-       * (kernel for OpenWRT, rootfs for stock firmware)
+-       */
+-      char flash_image_start[ADDRESS_LEN];
+-      /* 106-115: Size of rootfs */
+-      char root_length[IMAGE_LEN];
+-      /* 116-127: Address in memory of kernel */
+-      char kernel_address[ADDRESS_LEN];
+-      /* 128-137: Size of kernel */
+-      char kernel_length[IMAGE_LEN];
+-      /* 138-139: Unused at the moment */
+-      char dual_image[DUALFLAG_LEN];
+-      /* 140-141: Unused at the moment */
+-      char inactive_flag[INACTIVEFLAG_LEN];
+-      /* 142-161: RSA Signature (not used; some vendors may use this) */
+-      char rsa_signature[RSASIG_LEN];
+-      /* 162-191: Compilation and related information (not used in OpenWrt) */
+-      char information1[TAGINFO1_LEN];
+-      /* 192-195: Version flash layout */
+-      char flash_layout_ver[FLASHLAYOUTVER_LEN];
+-      /* 196-199: kernel+rootfs CRC32 */
+-      __u32 fskernel_crc;
+-      /* 200-215: Unused except on Alice Gate where is is information */
+-      char information2[TAGINFO2_LEN];
+-      /* 216-219: CRC32 of image less imagetag (kernel for Alice Gate) */
+-      __u32 image_crc;
+-      /* 220-223: CRC32 of rootfs partition */
+-      __u32 rootfs_crc;
+-      /* 224-227: CRC32 of kernel partition */
+-      __u32 kernel_crc;
+-      /* 228-235: Unused at present */
+-      char reserved1[8];
+-      /* 236-239: CRC32 of header excluding last 20 bytes */
+-      __u32 header_crc;
+-      /* 240-255: Unused at present */
+-      char reserved2[16];
+-};
+-
+-#endif /* __BCM63XX_TAG_H */
+--- a/drivers/mtd/bcm63xxpart.c
++++ b/drivers/mtd/bcm63xxpart.c
+@@ -32,7 +32,7 @@
+ #include <linux/mtd/mtd.h>
+ #include <linux/mtd/partitions.h>
+-#include <asm/mach-bcm63xx/bcm963xx_tag.h>
++#include <linux/bcm963xx_tag.h>
+ #include <asm/mach-bcm63xx/board_bcm963xx.h>
+ #define BCM63XX_EXTENDED_SIZE 0xBFC00000      /* Extended flash address */
+--- a/include/linux/Kbuild
++++ b/include/linux/Kbuild
+@@ -78,6 +78,7 @@ header-y += blk_types.h
+ header-y += blkpg.h
+ header-y += blktrace_api.h
+ header-y += bpqether.h
++header-y += bcm963xx_tag.h
+ header-y += bsg.h
+ header-y += can.h
+ header-y += capability.h
+--- /dev/null
++++ b/include/linux/bcm963xx_tag.h
+@@ -0,0 +1,96 @@
++#ifndef __BCM963XX_TAG_H
++#define __BCM963XX_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 Length */
++#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 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 (flash_image_address)
++ * 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 (root_length), which is added to the kernel
++ * length (kernel_length) to determine the length of image to flash and thus
++ * needs to be rootfs + deadcode (jffs2 EOF marker)
++*/
++
++struct bcm_tag {
++      /* 0-3: Version of the image tag */
++      char tag_version[TAGVER_LEN];
++      /* 4-23: Company Line 1 */
++      char sig_1[SIG1_LEN];
++      /*  24-37: Company Line 2 */
++      char sig_2[SIG2_LEN];
++      /* 38-43: Chip this image is for */
++      char chip_id[CHIPID_LEN];
++      /* 44-59: Board name */
++      char board_id[BOARDID_LEN];
++      /* 60-61: Map endianness -- 1 BE 0 LE */
++      char big_endian[ENDIANFLAG_LEN];
++      /* 62-71: Total length of image */
++      char total_length[IMAGE_LEN];
++      /* 72-83: Address in memory of CFE */
++      char cfe__address[ADDRESS_LEN];
++      /* 84-93: Size of CFE */
++      char cfe_length[IMAGE_LEN];
++      /* 94-105: Address in memory of image start
++       * (kernel for OpenWRT, rootfs for stock firmware)
++       */
++      char flash_image_start[ADDRESS_LEN];
++      /* 106-115: Size of rootfs */
++      char root_length[IMAGE_LEN];
++      /* 116-127: Address in memory of kernel */
++      char kernel_address[ADDRESS_LEN];
++      /* 128-137: Size of kernel */
++      char kernel_length[IMAGE_LEN];
++      /* 138-139: Unused at the moment */
++      char dual_image[DUALFLAG_LEN];
++      /* 140-141: Unused at the moment */
++      char inactive_flag[INACTIVEFLAG_LEN];
++      /* 142-161: RSA Signature (not used; some vendors may use this) */
++      char rsa_signature[RSASIG_LEN];
++      /* 162-191: Compilation and related information (not used in OpenWrt) */
++      char information1[TAGINFO1_LEN];
++      /* 192-195: Version flash layout */
++      char flash_layout_ver[FLASHLAYOUTVER_LEN];
++      /* 196-199: kernel+rootfs CRC32 */
++      __u32 fskernel_crc;
++      /* 200-215: Unused except on Alice Gate where is is information */
++      char information2[TAGINFO2_LEN];
++      /* 216-219: CRC32 of image less imagetag (kernel for Alice Gate) */
++      __u32 image_crc;
++      /* 220-223: CRC32 of rootfs partition */
++      __u32 rootfs_crc;
++      /* 224-227: CRC32 of kernel partition */
++      __u32 kernel_crc;
++      /* 228-235: Unused at present */
++      char reserved1[8];
++      /* 236-239: CRC32 of header excluding last 20 bytes */
++      __u32 header_crc;
++      /* 240-255: Unused at present */
++      char reserved2[16];
++};
++
++#endif /* __BCM63XX_TAG_H */
index c75e1d62ea024bb5a94413bd38e2af842d5e92ff..d6d49fdf50ac790c37a18daaf878752ea375531e 100644 (file)
@@ -10,7 +10,7 @@
  #define FB_ACCEL_NEOMAGIC_NM2093 92   /* NeoMagic NM2093              */
 --- a/include/linux/Kbuild
 +++ b/include/linux/Kbuild
-@@ -144,6 +144,8 @@ header-y += generic_serial.h
+@@ -145,6 +145,8 @@ header-y += generic_serial.h
  header-y += genetlink.h
  header-y += gfs2_ondisk.h
  header-y += gigaset_dev.h