summaryrefslogtreecommitdiffstats
path: root/target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch
diff options
context:
space:
mode:
authorjogo <jogo@3c298f89-4303-0410-b956-a3cf2f4a3e73>2012-05-27 13:22:37 +0000
committerjogo <jogo@3c298f89-4303-0410-b956-a3cf2f4a3e73>2012-05-27 13:22:37 +0000
commit0bdb7cbf98db42eacfd5feda5374c98bcc76cb02 (patch)
tree837dee2aa60b9ed896891d224f965fa3ad4eaf51 /target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch
parentd1683ec919940d2ac308df6bfecba784586be1a4 (diff)
bcm63xx: add a fixup for ath9k devices
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31880 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch')
-rw-r--r--target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch35
1 files changed, 9 insertions, 26 deletions
diff --git a/target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch b/target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch
index 0476699ed..856b9e267 100644
--- a/target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch
+++ b/target/linux/brcm63xx/patches-3.3/405-bcm963xx_real_rootfs_length.patch
@@ -15,30 +15,13 @@
/* 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;
+@@ -131,7 +131,8 @@ static int bcm63xx_parse_cfe_partitions(
+ } else {
+ /* OpenWrt layout */
+ rootfsaddr = kerneladdr + kernellen;
+- rootfslen = spareaddr - rootfsaddr;
++ rootfslen = buf->real_rootfs_length;
++ spareaddr = rootfsaddr + rootfslen;
+ }
} else {
+ pr_warn("CFE boot tag CRC invalid (expected %08x, actual %08x)\n",