extp->MajorVersion, extp->MinorVersion,
extp->MajorVersion, extp->MinorVersion);
kfree(extp);
- kfree(mtd);
- return NULL;
+ goto free_mtd;
}
printk(KERN_INFO " Amd/Fujitsu Extended Query version %c.%c.\n",
}
cfi_fixup(mtd, cfi_nopri_fixup_table);
- if (!cfi->addr_unlock1 || !cfi->addr_unlock2) {
- kfree(mtd);
- return NULL;
- }
+ if (!cfi->addr_unlock1 || !cfi->addr_unlock2)
+ goto free_mtd;
} /* CFI mode */
else if (cfi->cfi_mode == CFI_MODE_JEDEC) {
map->fldrv = &cfi_amdstd_chipdrv;
return cfi_amdstd_setup(mtd);
+
+free_mtd:
+ kfree(mtd);
+ return NULL;
}
struct mtd_info *cfi_cmdset_0006(struct map_info *map, int primary) __attribute__((alias("cfi_cmdset_0002")));
struct mtd_info *cfi_cmdset_0701(struct map_info *map, int primary) __attribute__((alias("cfi_cmdset_0002")));
mtd = kzalloc_obj(*mtd);
//printk(KERN_DEBUG "number of CFI chips: %d\n", cfi->numchips);
-
- if (!mtd) {
- kfree(cfi->cmdset_priv);
- return NULL;
- }
+ if (!mtd)
+ goto free_cmdset_priv;
mtd->priv = map;
mtd->type = MTD_NORFLASH;
mtd->numeraseregions = cfi->cfiq->NumEraseRegions * cfi->numchips;
mtd->eraseregions = kmalloc_objs(struct mtd_erase_region_info,
mtd->numeraseregions);
- if (!mtd->eraseregions) {
- kfree(cfi->cmdset_priv);
- kfree(mtd);
- return NULL;
- }
+ if (!mtd->eraseregions)
+ goto free_mtd;
for (i=0; i<cfi->cfiq->NumEraseRegions; i++) {
unsigned long ernum, ersize;
/* Argh */
printk(KERN_WARNING "Sum of regions (%lx) != total size of set of interleaved chips (%lx)\n", offset, devsize);
kfree(mtd->eraseregions);
- kfree(cfi->cmdset_priv);
- kfree(mtd);
- return NULL;
+ goto free_mtd;
}
for (i=0; i<mtd->numeraseregions;i++){
__module_get(THIS_MODULE);
mtd->name = map->name;
return mtd;
+
+free_mtd:
+ kfree(mtd);
+free_cmdset_priv:
+ kfree(cfi->cmdset_priv);
+ return NULL;
}