diff options
Diffstat (limited to 'drivers/mtd/chips/cfi_cmdset_0002.c')
-rw-r--r-- | drivers/mtd/chips/cfi_cmdset_0002.c | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/drivers/mtd/chips/cfi_cmdset_0002.c b/drivers/mtd/chips/cfi_cmdset_0002.c index d02592e6a0f..22d0493a026 100644 --- a/drivers/mtd/chips/cfi_cmdset_0002.c +++ b/drivers/mtd/chips/cfi_cmdset_0002.c | |||
@@ -317,7 +317,7 @@ static void fixup_s29gl064n_sectors(struct mtd_info *mtd) | |||
317 | 317 | ||
318 | if ((cfi->cfiq->EraseRegionInfo[0] & 0xffff) == 0x003f) { | 318 | if ((cfi->cfiq->EraseRegionInfo[0] & 0xffff) == 0x003f) { |
319 | cfi->cfiq->EraseRegionInfo[0] |= 0x0040; | 319 | cfi->cfiq->EraseRegionInfo[0] |= 0x0040; |
320 | pr_warning("%s: Bad S29GL064N CFI data, adjust from 64 to 128 sectors\n", mtd->name); | 320 | pr_warning("%s: Bad S29GL064N CFI data; adjust from 64 to 128 sectors\n", mtd->name); |
321 | } | 321 | } |
322 | } | 322 | } |
323 | 323 | ||
@@ -328,10 +328,23 @@ static void fixup_s29gl032n_sectors(struct mtd_info *mtd) | |||
328 | 328 | ||
329 | if ((cfi->cfiq->EraseRegionInfo[1] & 0xffff) == 0x007e) { | 329 | if ((cfi->cfiq->EraseRegionInfo[1] & 0xffff) == 0x007e) { |
330 | cfi->cfiq->EraseRegionInfo[1] &= ~0x0040; | 330 | cfi->cfiq->EraseRegionInfo[1] &= ~0x0040; |
331 | pr_warning("%s: Bad S29GL032N CFI data, adjust from 127 to 63 sectors\n", mtd->name); | 331 | pr_warning("%s: Bad S29GL032N CFI data; adjust from 127 to 63 sectors\n", mtd->name); |
332 | } | 332 | } |
333 | } | 333 | } |
334 | 334 | ||
335 | static void fixup_s29ns512p_sectors(struct mtd_info *mtd) | ||
336 | { | ||
337 | struct map_info *map = mtd->priv; | ||
338 | struct cfi_private *cfi = map->fldrv_priv; | ||
339 | |||
340 | /* | ||
341 | * S29NS512P flash uses more than 8bits to report number of sectors, | ||
342 | * which is not permitted by CFI. | ||
343 | */ | ||
344 | cfi->cfiq->EraseRegionInfo[0] = 0x020001ff; | ||
345 | pr_warning("%s: Bad S29NS512P CFI data; adjust to 512 sectors\n", mtd->name); | ||
346 | } | ||
347 | |||
335 | /* Used to fix CFI-Tables of chips without Extended Query Tables */ | 348 | /* Used to fix CFI-Tables of chips without Extended Query Tables */ |
336 | static struct cfi_fixup cfi_nopri_fixup_table[] = { | 349 | static struct cfi_fixup cfi_nopri_fixup_table[] = { |
337 | { CFI_MFR_SST, 0x234a, fixup_sst39vf }, /* SST39VF1602 */ | 350 | { CFI_MFR_SST, 0x234a, fixup_sst39vf }, /* SST39VF1602 */ |
@@ -362,6 +375,7 @@ static struct cfi_fixup cfi_fixup_table[] = { | |||
362 | { CFI_MFR_AMD, 0x1301, fixup_s29gl064n_sectors }, | 375 | { CFI_MFR_AMD, 0x1301, fixup_s29gl064n_sectors }, |
363 | { CFI_MFR_AMD, 0x1a00, fixup_s29gl032n_sectors }, | 376 | { CFI_MFR_AMD, 0x1a00, fixup_s29gl032n_sectors }, |
364 | { CFI_MFR_AMD, 0x1a01, fixup_s29gl032n_sectors }, | 377 | { CFI_MFR_AMD, 0x1a01, fixup_s29gl032n_sectors }, |
378 | { CFI_MFR_AMD, 0x3f00, fixup_s29ns512p_sectors }, | ||
365 | { CFI_MFR_SST, 0x536a, fixup_sst38vf640x_sectorsize }, /* SST38VF6402 */ | 379 | { CFI_MFR_SST, 0x536a, fixup_sst38vf640x_sectorsize }, /* SST38VF6402 */ |
366 | { CFI_MFR_SST, 0x536b, fixup_sst38vf640x_sectorsize }, /* SST38VF6401 */ | 380 | { CFI_MFR_SST, 0x536b, fixup_sst38vf640x_sectorsize }, /* SST38VF6401 */ |
367 | { CFI_MFR_SST, 0x536c, fixup_sst38vf640x_sectorsize }, /* SST38VF6404 */ | 381 | { CFI_MFR_SST, 0x536c, fixup_sst38vf640x_sectorsize }, /* SST38VF6404 */ |