mtd: spi-nor: Fix whole chip erasing for stacked chips.

Linux-MTD Mailing List linux-mtd at lists.infradead.org
Wed May 10 19:59:14 PDT 2017


Gitweb:     http://git.infradead.org/?p=mtd-2.6.git;a=commit;h=2f5ad7f0f3e16772bafa692ad42b5af4dea292f6
Commit:     2f5ad7f0f3e16772bafa692ad42b5af4dea292f6
Parent:     ca1fa1a8a6dae3e10c73bc5f1da728e662ee9d8b
Author:     mar.krzeminski <mar.krzeminski at gmail.com>
AuthorDate: Fri Jan 6 18:19:00 2017 +0100
Committer:  Cyrille Pitchen <cyrille.pitchen at atmel.com>
CommitDate: Wed Mar 22 21:52:53 2017 +0100

    mtd: spi-nor: Fix whole chip erasing for stacked chips.
    
    Currently it is possible to disable chip erase for spi-nor driver.
    Some modern stacked (multi die) flash chips do not support chip
    erase opcode at all but spi-nor framework needs to cope with them too.
    This commit extends existing functionality to allow disable
    chip erase for a single flash chip.
    
    Signed-off-by: Marcin Krzeminski <mar.krzeminski at gmail.com>
    Signed-off-by: Cyrille Pitchen <cyrille.pitchen at atmel.com>
---
 drivers/mtd/spi-nor/spi-nor.c | 3 +++
 1 file changed, 3 insertions(+)

diff --git a/drivers/mtd/spi-nor/spi-nor.c b/drivers/mtd/spi-nor/spi-nor.c
index 561e46d..c29a351 100644
--- a/drivers/mtd/spi-nor/spi-nor.c
+++ b/drivers/mtd/spi-nor/spi-nor.c
@@ -85,6 +85,7 @@ struct flash_info {
 					 * Use dedicated 4byte address op codes
 					 * to support memory size above 128Mib.
 					 */
+#define NO_CHIP_ERASE		BIT(12) /* Chip does not support chip erase */
 };
 
 #define JEDEC_MFR(info)	((info)->id[0])
@@ -1631,6 +1632,8 @@ int spi_nor_scan(struct spi_nor *nor, const char *name, enum read_mode mode)
 		nor->flags |= SNOR_F_USE_FSR;
 	if (info->flags & SPI_NOR_HAS_TB)
 		nor->flags |= SNOR_F_HAS_SR_TB;
+	if (info->flags & NO_CHIP_ERASE)
+		nor->flags |= SNOR_F_NO_OP_CHIP_ERASE;
 
 #ifdef CONFIG_MTD_SPI_NOR_USE_4K_SECTORS
 	/* prefer "small sector" erase if possible */



More information about the linux-mtd-cvs mailing list