mtd: nand_base: Only use GET/SET FEATURES command on chips that support them.

Spansion's S34MLx chips support ONFI but not the GET/SET FEATURES calls.

Signed-off-by: David Mosberger <dmosberger@gmail.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
This commit is contained in:
David Mosberger 2013-05-29 15:30:13 +03:00 committed by David Woodhouse
parent 64ddba4d8a
commit d914c932d7
2 changed files with 9 additions and 2 deletions

View File

@ -2709,7 +2709,9 @@ static int nand_onfi_set_features(struct mtd_info *mtd, struct nand_chip *chip,
{ {
int status; int status;
if (!chip->onfi_version) if (!chip->onfi_version ||
!(le16_to_cpu(chip->onfi_params.opt_cmd)
& ONFI_OPT_CMD_SET_GET_FEATURES))
return -EINVAL; return -EINVAL;
chip->cmdfunc(mtd, NAND_CMD_SET_FEATURES, addr, -1); chip->cmdfunc(mtd, NAND_CMD_SET_FEATURES, addr, -1);
@ -2730,7 +2732,9 @@ static int nand_onfi_set_features(struct mtd_info *mtd, struct nand_chip *chip,
static int nand_onfi_get_features(struct mtd_info *mtd, struct nand_chip *chip, static int nand_onfi_get_features(struct mtd_info *mtd, struct nand_chip *chip,
int addr, uint8_t *subfeature_param) int addr, uint8_t *subfeature_param)
{ {
if (!chip->onfi_version) if (!chip->onfi_version ||
!(le16_to_cpu(chip->onfi_params.opt_cmd)
& ONFI_OPT_CMD_SET_GET_FEATURES))
return -EINVAL; return -EINVAL;
/* clear the sub feature parameters */ /* clear the sub feature parameters */

View File

@ -217,6 +217,9 @@ struct nand_chip;
/* ONFI subfeature parameters length */ /* ONFI subfeature parameters length */
#define ONFI_SUBFEATURE_PARAM_LEN 4 #define ONFI_SUBFEATURE_PARAM_LEN 4
/* ONFI optional commands SET/GET FEATURES supported? */
#define ONFI_OPT_CMD_SET_GET_FEATURES (1 << 2)
struct nand_onfi_params { struct nand_onfi_params {
/* rev info and features block */ /* rev info and features block */
/* 'O' 'N' 'F' 'I' */ /* 'O' 'N' 'F' 'I' */