Remove upstreamed patches: 100-08-cmd-mtd-add-markbad-subcommand-for-NMBM-testing.patch [1] 101-01-mtd-spinand-add-support-for-FORESEE-F35SQA002G.patch [2] 101-02-mtd-spinand-add-support-for-FORESEE-F35SQA001G.patch [3] 110-mtd-spi-nand-add-support-for-FudanMicro-FM25S01A.patch [4] Some SPI-NAND driver macro definitions and function parameters have been changed in the latest release[3]. Hence we also had to rework the related local patches to follow the upstream changes. Tested on MT7981 SPI-NOR/EMMC. [1]21c1098cf4[2]2a0f8e7da0[3]2cbdd3e449[4]8b984b5a39Signed-off-by: Shiji Yang <yangshiji66@outlook.com> [daniel@makrotopia.org: tested MT7622 SNAND and SPI-NOR] Signed-off-by: Daniel Golle <daniel@makrotopia.org>
69 lines
2.6 KiB
Diff
69 lines
2.6 KiB
Diff
Subject: [PATCH] mtd: spinand: esmt: add support for F50L1G41LC
|
|
|
|
This adds support for ESMT F50L1G41LC, which appears to be an updated
|
|
version of the already supported F50L1G41LB.
|
|
Add esmt_8c SPI_NAND manufacturer to account for the newly used vendor
|
|
ID with support for the ESMT F50L1G41LC chip.
|
|
|
|
--- a/drivers/mtd/nand/spi/core.c
|
|
+++ b/drivers/mtd/nand/spi/core.c
|
|
@@ -1287,6 +1287,7 @@ static const struct spinand_manufacturer
|
|
&alliancememory_spinand_manufacturer,
|
|
&ato_spinand_manufacturer,
|
|
&esmt_c8_spinand_manufacturer,
|
|
+ &esmt_8c_spinand_manufacturer,
|
|
&etron_spinand_manufacturer,
|
|
&fmsh_spinand_manufacturer,
|
|
&foresee_spinand_manufacturer,
|
|
--- a/drivers/mtd/nand/spi/esmt.c
|
|
+++ b/drivers/mtd/nand/spi/esmt.c
|
|
@@ -17,6 +17,7 @@
|
|
|
|
/* ESMT uses GigaDevice 0xc8 JECDEC ID on some SPI NANDs */
|
|
#define SPINAND_MFR_ESMT_C8 0xc8
|
|
+#define SPINAND_MFR_ESMT_8C 0x8c
|
|
|
|
#define ESMT_F50L1G41LB_CFG_OTP_PROTECT BIT(7)
|
|
#define ESMT_F50L1G41LB_CFG_OTP_LOCK \
|
|
@@ -189,6 +190,18 @@ static const struct spinand_fact_otp_ops
|
|
.read = spinand_fact_otp_read,
|
|
};
|
|
|
|
+static const struct spinand_info esmt_8c_spinand_table[] = {
|
|
+ SPINAND_INFO("F50L1G41LC",
|
|
+ SPINAND_ID(SPINAND_READID_METHOD_OPCODE_ADDR, 0x2C),
|
|
+ NAND_MEMORG(1, 2048, 64, 64, 1024, 20, 1, 1, 1),
|
|
+ NAND_ECCREQ(1, 512),
|
|
+ SPINAND_INFO_OP_VARIANTS(&read_cache_variants,
|
|
+ &write_cache_variants,
|
|
+ &update_cache_variants),
|
|
+ 0,
|
|
+ SPINAND_ECCINFO(&f50l1g41lb_ooblayout, NULL)),
|
|
+};
|
|
+
|
|
static const struct spinand_info esmt_c8_spinand_table[] = {
|
|
SPINAND_INFO("F50L1G41LB",
|
|
SPINAND_ID(SPINAND_READID_METHOD_OPCODE_ADDR, 0x01, 0x7f,
|
|
@@ -236,3 +249,11 @@ const struct spinand_manufacturer esmt_c
|
|
.nchips = ARRAY_SIZE(esmt_c8_spinand_table),
|
|
.ops = &esmt_spinand_manuf_ops,
|
|
};
|
|
+
|
|
+const struct spinand_manufacturer esmt_8c_spinand_manufacturer = {
|
|
+ .id = SPINAND_MFR_ESMT_8C,
|
|
+ .name = "ESMT",
|
|
+ .chips = esmt_8c_spinand_table,
|
|
+ .nchips = ARRAY_SIZE(esmt_8c_spinand_table),
|
|
+ .ops = &esmt_spinand_manuf_ops,
|
|
+};
|
|
--- a/include/linux/mtd/spinand.h
|
|
+++ b/include/linux/mtd/spinand.h
|
|
@@ -414,6 +414,7 @@ struct spinand_manufacturer {
|
|
extern const struct spinand_manufacturer alliancememory_spinand_manufacturer;
|
|
extern const struct spinand_manufacturer ato_spinand_manufacturer;
|
|
extern const struct spinand_manufacturer esmt_c8_spinand_manufacturer;
|
|
+extern const struct spinand_manufacturer esmt_8c_spinand_manufacturer;
|
|
extern const struct spinand_manufacturer etron_spinand_manufacturer;
|
|
extern const struct spinand_manufacturer fmsh_spinand_manufacturer;
|
|
extern const struct spinand_manufacturer foresee_spinand_manufacturer;
|