summaryrefslogtreecommitdiffstats
path: root/drivers/mtd
diff options
context:
space:
mode:
authorJoël Esponde <joel.esponde@honeywell.com>2016-11-23 12:47:40 +0100
committerCyrille Pitchen <cyrille.pitchen@atmel.com>2016-11-23 15:29:20 +0100
commit807c16253319ee6ccf8873ae64f070f7eb532cd5 (patch)
treeeb3fdce52f0a9b15f6de391566181b2ef6741f22 /drivers/mtd
parentmtd: spi-nor: add Macronix mx25u25635f to list of known devices. (diff)
downloadlinux-807c16253319ee6ccf8873ae64f070f7eb532cd5.tar.xz
linux-807c16253319ee6ccf8873ae64f070f7eb532cd5.zip
mtd: spi-nor: fix spansion quad enable
With the S25FL127S nor flash part, each writing to the configuration register takes hundreds of ms. During that time, no more accesses to the flash should be done (even reads). This commit adds a wait loop after the register writing until the flash finishes its work. This issue could make rootfs mounting fail when the latter was done too much closely to this quad enable bit setting step. And in this case, a driver as UBIFS may try to recover the filesystem and may broke it completely. Signed-off-by: Joël Esponde <joel.esponde@honeywell.com> Signed-off-by: Cyrille Pitchen <cyrille.pitchen@atmel.com>
Diffstat (limited to 'drivers/mtd')
-rw-r--r--drivers/mtd/spi-nor/spi-nor.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/mtd/spi-nor/spi-nor.c b/drivers/mtd/spi-nor/spi-nor.c
index 4fd3ac8b5317..cebd0cc8a5b1 100644
--- a/drivers/mtd/spi-nor/spi-nor.c
+++ b/drivers/mtd/spi-nor/spi-nor.c
@@ -1256,6 +1256,13 @@ static int spansion_quad_enable(struct spi_nor *nor)
return -EINVAL;
}
+ ret = spi_nor_wait_till_ready(nor);
+ if (ret) {
+ dev_err(nor->dev,
+ "timeout while writing configuration register\n");
+ return ret;
+ }
+
/* read back and check it */
ret = read_cr(nor);
if (!(ret > 0 && (ret & CR_QUAD_EN_SPAN))) {