summaryrefslogtreecommitdiffstats
path: root/target/linux/atheros/patches-2.6.24/140-redboot_partition_scan.patch
diff options
context:
space:
mode:
authornbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>2008-01-31 04:44:35 +0000
committernbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>2008-01-31 04:44:35 +0000
commit697e06b22580013c25f0f170925fa5f02879345b (patch)
tree2ea99e192074677d53b80c2e88d8f929d825c180 /target/linux/atheros/patches-2.6.24/140-redboot_partition_scan.patch
parent18a605bf0b48420b0385f75c886d43c81435f532 (diff)
port atheros to 2.6.24 (untested), but do not use the new kernel by default yet
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@10335 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/atheros/patches-2.6.24/140-redboot_partition_scan.patch')
-rw-r--r--target/linux/atheros/patches-2.6.24/140-redboot_partition_scan.patch24
1 files changed, 24 insertions, 0 deletions
diff --git a/target/linux/atheros/patches-2.6.24/140-redboot_partition_scan.patch b/target/linux/atheros/patches-2.6.24/140-redboot_partition_scan.patch
new file mode 100644
index 000000000..de4ebeb55
--- /dev/null
+++ b/target/linux/atheros/patches-2.6.24/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
+@@ -140,6 +141,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;
+