Skip to content

Commit b98994c

Browse files
dangowrtmiquelraynal
authored andcommitted
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. Link: openwrt/openwrt#15214 (comment) Signed-off-by: Daniel Golle <daniel@makrotopia.org> Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
1 parent 1f3dcfe commit b98994c

3 files changed

Lines changed: 26 additions & 0 deletions

File tree

drivers/mtd/nand/spi/core.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1227,6 +1227,7 @@ static const struct nand_ops spinand_ops = {
12271227
static const struct spinand_manufacturer *spinand_manufacturers[] = {
12281228
&alliancememory_spinand_manufacturer,
12291229
&ato_spinand_manufacturer,
1230+
&esmt_8c_spinand_manufacturer,
12301231
&esmt_c8_spinand_manufacturer,
12311232
&fmsh_spinand_manufacturer,
12321233
&foresee_spinand_manufacturer,

drivers/mtd/nand/spi/esmt.c

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,7 @@
1212

1313
/* ESMT uses GigaDevice 0xc8 JECDEC ID on some SPI NANDs */
1414
#define SPINAND_MFR_ESMT_C8 0xc8
15+
#define SPINAND_MFR_ESMT_8C 0x8c
1516

1617
#define ESMT_F50L1G41LB_CFG_OTP_PROTECT BIT(7)
1718
#define ESMT_F50L1G41LB_CFG_OTP_LOCK \
@@ -184,6 +185,21 @@ static const struct spinand_fact_otp_ops f50l1g41lb_fact_otp_ops = {
184185
.read = spinand_fact_otp_read,
185186
};
186187

188+
189+
static const struct spinand_info esmt_8c_spinand_table[] = {
190+
SPINAND_INFO("F50L1G41LC",
191+
SPINAND_ID(SPINAND_READID_METHOD_OPCODE_ADDR, 0x2C),
192+
NAND_MEMORG(1, 2048, 64, 64, 1024, 20, 1, 1, 1),
193+
NAND_ECCREQ(1, 512),
194+
SPINAND_INFO_OP_VARIANTS(&read_cache_variants,
195+
&write_cache_variants,
196+
&update_cache_variants),
197+
0,
198+
SPINAND_ECCINFO(&f50l1g41lb_ooblayout, NULL),
199+
SPINAND_USER_OTP_INFO(28, 2, &f50l1g41lb_user_otp_ops),
200+
SPINAND_FACT_OTP_INFO(2, 0, &f50l1g41lb_fact_otp_ops)),
201+
};
202+
187203
static const struct spinand_info esmt_c8_spinand_table[] = {
188204
SPINAND_INFO("F50L1G41LB",
189205
SPINAND_ID(SPINAND_READID_METHOD_OPCODE_ADDR, 0x01, 0x7f,
@@ -224,6 +240,14 @@ static const struct spinand_info esmt_c8_spinand_table[] = {
224240
static const struct spinand_manufacturer_ops esmt_spinand_manuf_ops = {
225241
};
226242

243+
const struct spinand_manufacturer esmt_8c_spinand_manufacturer = {
244+
.id = SPINAND_MFR_ESMT_8C,
245+
.name = "ESMT",
246+
.chips = esmt_8c_spinand_table,
247+
.nchips = ARRAY_SIZE(esmt_8c_spinand_table),
248+
.ops = &esmt_spinand_manuf_ops,
249+
};
250+
227251
const struct spinand_manufacturer esmt_c8_spinand_manufacturer = {
228252
.id = SPINAND_MFR_ESMT_C8,
229253
.name = "ESMT",

include/linux/mtd/spinand.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -354,6 +354,7 @@ struct spinand_manufacturer {
354354
/* SPI NAND manufacturers */
355355
extern const struct spinand_manufacturer alliancememory_spinand_manufacturer;
356356
extern const struct spinand_manufacturer ato_spinand_manufacturer;
357+
extern const struct spinand_manufacturer esmt_8c_spinand_manufacturer;
357358
extern const struct spinand_manufacturer esmt_c8_spinand_manufacturer;
358359
extern const struct spinand_manufacturer fmsh_spinand_manufacturer;
359360
extern const struct spinand_manufacturer foresee_spinand_manufacturer;

0 commit comments

Comments
 (0)