[DIRECTFB] Placeholder
[openwrt/mini2440.git] / target / linux / atheros / patches-2.6.28 / 140-redboot_partition_scan.patch
blob289d4eb990ab6e7dc6256339444610e4090d803b
1 --- a/drivers/mtd/redboot.c
2 +++ b/drivers/mtd/redboot.c
3 @@ -60,31 +60,32 @@ static int parse_redboot_partitions(stru
4 static char nullstring[] = "unallocated";
5 #endif
7 + buf = vmalloc(master->erasesize);
8 + if (!buf)
9 + return -ENOMEM;
11 + restart:
12 if ( directory < 0 ) {
13 offset = master->size + directory * master->erasesize;
14 - while (master->block_isbad &&
15 + while (master->block_isbad &&
16 master->block_isbad(master, offset)) {
17 if (!offset) {
18 nogood:
19 printk(KERN_NOTICE "Failed to find a non-bad block to check for RedBoot partition table\n");
20 + vfree(buf);
21 return -EIO;
23 offset -= master->erasesize;
25 } else {
26 offset = directory * master->erasesize;
27 - while (master->block_isbad &&
28 + while (master->block_isbad &&
29 master->block_isbad(master, offset)) {
30 offset += master->erasesize;
31 if (offset == master->size)
32 goto nogood;
35 - buf = vmalloc(master->erasesize);
37 - if (!buf)
38 - return -ENOMEM;
40 printk(KERN_NOTICE "Searching for RedBoot partition table in %s at offset 0x%lx\n",
41 master->name, offset);
43 @@ -156,6 +157,11 @@ static int parse_redboot_partitions(stru
45 if (i == numslots) {
46 /* Didn't find it */
47 + if (offset + master->erasesize < master->size) {
48 + /* not at the end of the flash yet, maybe next block :) */
49 + directory++;
50 + goto restart;
51 + }
52 printk(KERN_NOTICE "No RedBoot partition table detected in %s\n",
53 master->name);
54 ret = 0;