| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- --- a/drivers/mtd/redboot.c
- +++ b/drivers/mtd/redboot.c
- @@ -62,31 +62,32 @@ static int parse_redboot_partitions(stru
- static char nullstring[] = "unallocated";
- #endif
-
- + buf = vmalloc(master->erasesize);
- + if (!buf)
- + return -ENOMEM;
- +
- + restart:
- if ( directory < 0 ) {
- offset = master->size + directory * master->erasesize;
- - while (master->block_isbad &&
- + while (master->block_isbad &&
- master->block_isbad(master, offset)) {
- if (!offset) {
- nogood:
- printk(KERN_NOTICE "Failed to find a non-bad block to check for RedBoot partition table\n");
- + vfree(buf);
- return -EIO;
- }
- offset -= master->erasesize;
- }
- } else {
- offset = directory * master->erasesize;
- - while (master->block_isbad &&
- + while (master->block_isbad &&
- master->block_isbad(master, offset)) {
- offset += master->erasesize;
- if (offset == master->size)
- goto nogood;
- }
- }
- - buf = vmalloc(master->erasesize);
- -
- - if (!buf)
- - return -ENOMEM;
- -
- printk(KERN_NOTICE "Searching for RedBoot partition table in %s at offset 0x%lx\n",
- master->name, offset);
-
- @@ -158,6 +159,11 @@ static int parse_redboot_partitions(stru
- }
- 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;
|