diff options
author | Brian Norris <norris@broadcom.com> | 2010-08-19 11:11:02 -0400 |
---|---|---|
committer | David Woodhouse <David.Woodhouse@intel.com> | 2010-10-24 18:27:11 -0400 |
commit | 2173bae81e17b710328bc877e7b9ade7f4b90064 (patch) | |
tree | 7d4faa0e19eebee2343954ea378471be10602abf /drivers/mtd/nand | |
parent | 12c8eb98de747ebc08404e3719c40abb405994e2 (diff) |
mtd: nand: spansion S30MLxxxP support
Some Spansion chips have a method for determining eraseblock size that
is incompatible with similar ID chips of other sizes. This implements
some heuristic detection of these differences.
This patch checks for a 5-byte ID with trailing zeros as well as a
512-byte page size to ensure that chips are not misdetected as the
S30MLxxxP ORNAND series.
[Tweaked by Artem a bit]
Signed-off-by: Brian Norris <norris@broadcom.com>
Signed-off-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com>
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
Diffstat (limited to 'drivers/mtd/nand')
-rw-r--r-- | drivers/mtd/nand/nand_base.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/drivers/mtd/nand/nand_base.c b/drivers/mtd/nand/nand_base.c index 0fd22cce0ecc..b0f091aca097 100644 --- a/drivers/mtd/nand/nand_base.c +++ b/drivers/mtd/nand/nand_base.c | |||
@@ -2900,6 +2900,19 @@ static struct nand_flash_dev *nand_get_flash_type(struct mtd_info *mtd, | |||
2900 | mtd->writesize = type->pagesize; | 2900 | mtd->writesize = type->pagesize; |
2901 | mtd->oobsize = mtd->writesize / 32; | 2901 | mtd->oobsize = mtd->writesize / 32; |
2902 | busw = type->options & NAND_BUSWIDTH_16; | 2902 | busw = type->options & NAND_BUSWIDTH_16; |
2903 | |||
2904 | /* | ||
2905 | * Check for Spansion/AMD ID + repeating 5th, 6th byte since | ||
2906 | * some Spansion chips have erasesize that conflicts with size | ||
2907 | * listed in nand_ids table | ||
2908 | * Data sheet (5 byte ID): Spansion S30ML-P ORNAND (p.39) | ||
2909 | */ | ||
2910 | if (*maf_id == NAND_MFR_AMD && id_data[4] != 0x00 && | ||
2911 | id_data[5] == 0x00 && id_data[6] == 0x00 && | ||
2912 | id_data[7] == 0x00 && mtd->writesize == 512) { | ||
2913 | mtd->erasesize = 128 * 1024; | ||
2914 | mtd->erasesize <<= ((id_data[3] & 0x03) << 1); | ||
2915 | } | ||
2903 | } | 2916 | } |
2904 | 2917 | ||
2905 | /* Try to identify manufacturer */ | 2918 | /* Try to identify manufacturer */ |