mtd: rawnand: Add the nand_wait_readrdy() helper and use it
The logic to wait for chip readiness after a page read has been duplicated in nand_do_read_ops() and nand_do_read_oob(). Provide an helper that does the right thing and call it where appropriate. Signed-off-by: Boris Brezillon <boris.brezillon@bootlin.com> Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
This commit is contained in:
parent
57361846b5
commit
85e08e5864
|
@ -3524,6 +3524,18 @@ static int nand_setup_read_retry(struct mtd_info *mtd, int retry_mode)
|
||||||
return chip->setup_read_retry(mtd, retry_mode);
|
return chip->setup_read_retry(mtd, retry_mode);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void nand_wait_readrdy(struct nand_chip *chip)
|
||||||
|
{
|
||||||
|
if (!(chip->options & NAND_NEED_READRDY))
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* Apply delay or wait for ready/busy pin */
|
||||||
|
if (!chip->dev_ready)
|
||||||
|
udelay(chip->chip_delay);
|
||||||
|
else
|
||||||
|
nand_wait_ready(nand_to_mtd(chip));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* nand_do_read_ops - [INTERN] Read data with ECC
|
* nand_do_read_ops - [INTERN] Read data with ECC
|
||||||
* @mtd: MTD device structure
|
* @mtd: MTD device structure
|
||||||
|
@ -3631,13 +3643,7 @@ read_retry:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (chip->options & NAND_NEED_READRDY) {
|
nand_wait_readrdy(chip);
|
||||||
/* Apply delay or wait for ready/busy pin */
|
|
||||||
if (!chip->dev_ready)
|
|
||||||
udelay(chip->chip_delay);
|
|
||||||
else
|
|
||||||
nand_wait_ready(mtd);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mtd->ecc_stats.failed - ecc_failures) {
|
if (mtd->ecc_stats.failed - ecc_failures) {
|
||||||
if (retry_mode + 1 < chip->read_retries) {
|
if (retry_mode + 1 < chip->read_retries) {
|
||||||
|
@ -3908,13 +3914,7 @@ static int nand_do_read_oob(struct mtd_info *mtd, loff_t from,
|
||||||
len = min(len, readlen);
|
len = min(len, readlen);
|
||||||
buf = nand_transfer_oob(mtd, buf, ops, len);
|
buf = nand_transfer_oob(mtd, buf, ops, len);
|
||||||
|
|
||||||
if (chip->options & NAND_NEED_READRDY) {
|
nand_wait_readrdy(chip);
|
||||||
/* Apply delay or wait for ready/busy pin */
|
|
||||||
if (!chip->dev_ready)
|
|
||||||
udelay(chip->chip_delay);
|
|
||||||
else
|
|
||||||
nand_wait_ready(mtd);
|
|
||||||
}
|
|
||||||
|
|
||||||
max_bitflips = max_t(unsigned int, max_bitflips, ret);
|
max_bitflips = max_t(unsigned int, max_bitflips, ret);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue