aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/atheros/patches-2.6.23/140-redboot_partition_scan.patch
blob: de4ebeb553ca5e87f39818089a05e31ecedccc0f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
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;