summaryrefslogtreecommitdiff
path: root/target/linux/atheros-2.6/patches/140-redboot_partition_scan.patch
diff options
context:
space:
mode:
authornbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>2006-12-25 08:05:48 +0000
committernbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>2006-12-25 08:05:48 +0000
commit13596cf723ef9a54194e762d9d2424b9df2d38a5 (patch)
treec7afe4fd997936fc5292f99ef66e64563fbaad93 /target/linux/atheros-2.6/patches/140-redboot_partition_scan.patch
parent0aa989462424e5b67b0fd61f50c131f2e81be828 (diff)
Add support for Atheros SoC (used in Fonera, Meraki) - Merry Christmas, everybody :)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@5898 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/atheros-2.6/patches/140-redboot_partition_scan.patch')
-rw-r--r--target/linux/atheros-2.6/patches/140-redboot_partition_scan.patch24
1 files changed, 24 insertions, 0 deletions
diff --git a/target/linux/atheros-2.6/patches/140-redboot_partition_scan.patch b/target/linux/atheros-2.6/patches/140-redboot_partition_scan.patch
new file mode 100644
index 0000000000..979b2f48b4
--- /dev/null
+++ b/target/linux/atheros-2.6/patches/140-redboot_partition_scan.patch
@@ -0,0 +1,24 @@
+diff -urN linux.old/drivers/mtd/redboot.c linux.dev/drivers/mtd/redboot.c
+--- linux.old/drivers/mtd/redboot.c 2006-12-14 23:53:29.000000000 +0100
++++ linux.dev/drivers/mtd/redboot.c 2006-12-16 04:23:42.000000000 +0100
+@@ -64,6 +64,7 @@
+ if (!buf)
+ return -ENOMEM;
+
++restart:
+ if ( directory < 0 )
+ offset = master->size + directory*master->erasesize;
+ else
+@@ -139,6 +140,11 @@
+ }
+ if (i == numslots) {
+ /* Didn't find it */
++ if (offset + master->erasesize < master->size) {
++ /* not at the end of the flash yet, maybe next block :) */
++ directory++;
++ goto restart;
++ }
+ printk(KERN_NOTICE "No RedBoot partition table detected in %s\n",
+ master->name);
+ ret = 0;
+