summaryrefslogtreecommitdiffstats
path: root/target/linux/brcm63xx/patches-3.3/041-bcm963xx_real_rootfs_length.patch
diff options
context:
space:
mode:
authorJonas Gorski <jogo@openwrt.org>2012-02-04 10:17:27 +0000
committerJonas Gorski <jogo@openwrt.org>2012-02-04 10:17:27 +0000
commit778e5d4fa5f1d51bf397a2b58a428dd49ac2eee8 (patch)
tree8c89489a9a2b1cadc7d55be826ce6cdb33b7427d /target/linux/brcm63xx/patches-3.3/041-bcm963xx_real_rootfs_length.patch
parent49874a57f1db8f9bc74171935676c72ad5cef830 (diff)
downloadmaster-31e0f0ae-778e5d4fa5f1d51bf397a2b58a428dd49ac2eee8.tar.gz
master-31e0f0ae-778e5d4fa5f1d51bf397a2b58a428dd49ac2eee8.tar.bz2
master-31e0f0ae-778e5d4fa5f1d51bf397a2b58a428dd49ac2eee8.zip
brcm63xx: add support for linux 3.3
SVN-Revision: 30027
Diffstat (limited to 'target/linux/brcm63xx/patches-3.3/041-bcm963xx_real_rootfs_length.patch')
-rw-r--r--target/linux/brcm63xx/patches-3.3/041-bcm963xx_real_rootfs_length.patch44
1 files changed, 44 insertions, 0 deletions
diff --git a/target/linux/brcm63xx/patches-3.3/041-bcm963xx_real_rootfs_length.patch b/target/linux/brcm63xx/patches-3.3/041-bcm963xx_real_rootfs_length.patch
new file mode 100644
index 0000000000..0476699edb
--- /dev/null
+++ b/target/linux/brcm63xx/patches-3.3/041-bcm963xx_real_rootfs_length.patch
@@ -0,0 +1,44 @@
+--- a/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h
++++ b/arch/mips/include/asm/mach-bcm63xx/bcm963xx_tag.h
+@@ -85,8 +85,10 @@ struct bcm_tag {
+ __u32 rootfs_crc;
+ /* 224-227: CRC32 of kernel partition */
+ __u32 kernel_crc;
+- /* 228-235: Unused at present */
+- char reserved1[8];
++ /* 228-231: Image sequence number */
++ char image_sequence[4];
++ /* 222-235: Openwrt: real rootfs length */
++ __u32 real_rootfs_length;
+ /* 236-239: CRC32 of header excluding last 20 bytes */
+ __u32 header_crc;
+ /* 240-255: Unused at present */
+--- a/drivers/mtd/bcm63xxpart.c
++++ b/drivers/mtd/bcm63xxpart.c
+@@ -77,7 +77,7 @@ static int bcm63xx_parse_cfe_partitions(
+ int ret;
+ size_t retlen;
+ unsigned int rootfsaddr, kerneladdr, spareaddr;
+- unsigned int rootfslen, kernellen, sparelen, totallen;
++ unsigned int rootfslen, kernellen, sparelen;
+ unsigned int cfelen, nvramlen;
+ int namelen = 0;
+ int i;
+@@ -111,14 +111,15 @@ static int bcm63xx_parse_cfe_partitions(
+
+ sscanf(buf->kernel_address, "%u", &kerneladdr);
+ sscanf(buf->kernel_length, "%u", &kernellen);
+- sscanf(buf->total_length, "%u", &totallen);
++ rootfslen = buf->real_rootfs_length;
+
+ pr_info("CFE boot tag found with version %s and board type %s\n",
+ tagversion, boardid);
+
+ kerneladdr = kerneladdr - BCM63XX_EXTENDED_SIZE;
+ rootfsaddr = kerneladdr + kernellen;
+- spareaddr = roundup(totallen, master->erasesize) + cfelen;
++ rootfslen = roundup(rootfslen, master->erasesize);
++ spareaddr = rootfsaddr + rootfslen;
+ sparelen = master->size - spareaddr - nvramlen;
+ rootfslen = spareaddr - rootfsaddr;
+ } else {