diff options
author | Tokunori Ikegami <ikegami@allied-telesis.co.jp> | 2018-05-30 18:32:26 +0900 |
---|---|---|
committer | Boris Brezillon <boris.brezillon@bootlin.com> | 2018-05-30 21:38:19 +0200 |
commit | dfeae1073583dc35c33b32150e18b7048bbb37e6 (patch) | |
tree | b5071244de7a053033861d2692bd75c4370fd64b /drivers/mtd/chips | |
parent | 34c819073c8b8b652ced18e53bd2b0332dbe29cf (diff) | |
download | linux-dfeae1073583dc35c33b32150e18b7048bbb37e6.tar.gz linux-dfeae1073583dc35c33b32150e18b7048bbb37e6.tar.bz2 linux-dfeae1073583dc35c33b32150e18b7048bbb37e6.zip |
mtd: cfi_cmdset_0002: Change write buffer to check correct value
For the word write it is checked if the chip has the correct value.
But it is not checked for the write buffer as only checked if ready.
To make sure for the write buffer change to check the value.
It is enough as this patch is only checking the last written word.
Since it is described by data sheets to check the operation status.
Signed-off-by: Tokunori Ikegami <ikegami@allied-telesis.co.jp>
Reviewed-by: Joakim Tjernlund <Joakim.Tjernlund@infinera.com>
Cc: Chris Packham <chris.packham@alliedtelesis.co.nz>
Cc: Brian Norris <computersforpeace@gmail.com>
Cc: David Woodhouse <dwmw2@infradead.org>
Cc: Boris Brezillon <boris.brezillon@free-electrons.com>
Cc: Marek Vasut <marek.vasut@gmail.com>
Cc: Richard Weinberger <richard@nod.at>
Cc: Cyrille Pitchen <cyrille.pitchen@wedev4u.fr>
Cc: linux-mtd@lists.infradead.org
Cc: stable@vger.kernel.org
Signed-off-by: Boris Brezillon <boris.brezillon@bootlin.com>
Diffstat (limited to 'drivers/mtd/chips')
-rw-r--r-- | drivers/mtd/chips/cfi_cmdset_0002.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/mtd/chips/cfi_cmdset_0002.c b/drivers/mtd/chips/cfi_cmdset_0002.c index bd0c30ad8ee7..75d2c16029fd 100644 --- a/drivers/mtd/chips/cfi_cmdset_0002.c +++ b/drivers/mtd/chips/cfi_cmdset_0002.c @@ -1879,7 +1879,7 @@ static int __xipram do_write_buffer(struct map_info *map, struct flchip *chip, if (time_after(jiffies, timeo) && !chip_ready(map, adr)) break; - if (chip_ready(map, adr)) { + if (chip_good(map, adr, datum)) { xip_enable(map, chip, adr); goto op_done; } |