Add IDs for 25 AMD chips, 11 Hynix chips, 8 Sharp chips, and their variants
AM29DL400BB, AM29DL400BT, AM29DL800BB, AM29DL800BT, AM29F004BB
AM29F004BT, AM29F200BB, AM29F200BT, AM29F400BB, AM29F400BT
AM29F800BB, AM29F800BT, AM29LV002BB, AM29LV002BT, AM29LV004BB
AM29LV004BT, AM29LV008BB, AM29LV008BT, AM29LV080B, AM29LV200BB
AM29LV200BT, AM29LV400BB, AM29LV400BT, AM29LV800BB, AM29LV800BT
HY29F002, HY29F040A, HY29F080, HY29F400B, HY29F400T, HY29F800B
HY29F800T, HY29LV400B, HY29LV400T, HY29LV800B, HY29LV800T
LH28F008BJxxPB, LH28F008BJxxPT, LH28F008SA, LH28F008SC, LH28F800BVxxBTL
LH28F800BVxxBV, LH28F800BVxxTV, LHF00L02
Corresponding to flashrom svn r674.
Signed-off-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net>
Acked-by: Stefan Reinauer <stepan@coresystems.de>
diff --git a/flashchips.c b/flashchips.c
index 4768830..891bde0 100644
--- a/flashchips.c
+++ b/flashchips.c
@@ -165,7 +165,7 @@
.name = "Am29LV081B",
.bustype = CHIP_BUSTYPE_PARALLEL,
.manufacture_id = AMD_ID,
- .model_id = AM_29LV081B,
+ .model_id = AM_29LV080B,
.total_size = 1024,
.page_size = 64 * 1024,
.tested = TEST_UNTESTED,
diff --git a/flashchips.h b/flashchips.h
index 44eb80b..a958d0b 100644
--- a/flashchips.h
+++ b/flashchips.h
@@ -39,20 +39,44 @@
#define ALLIANCE_ID 0x52 /* Alliance Semiconductor */
#define AMD_ID 0x01 /* AMD */
+#define AM_29DL400BT 0x0C
+#define AM_29DL400BB 0x0F
+#define AM_29DL800BT 0x4A
+#define AM_29DL800BB 0xCB
+#define AM_29F002BB 0x34 /* Same as Am29F002NBB */
+#define AM_29F002BT 0xB0 /* Same as Am29F002NBT */
+#define AM_29F004BB 0x7B
+#define AM_29F004BT 0x77
+#define AM_29F016D 0xAD
#define AM_29F010B 0x20 /* Same as Am29F010A */
-#define AM_29F002BT 0xB0
-#define AM_29F002BB 0x34
#define AM_29F040B 0xA4
#define AM_29F080B 0xD5
+#define AM_29F200BB 0x57
+#define AM_29F200BT 0x51
+#define AM_29F400BB 0xAB
+#define AM_29F400BT 0x23
+#define AM_29F800BB 0x58
+#define AM_29F800BT 0xD6
+#define AM_29LV002BB 0xC2
+#define AM_29LV002BT 0x40
+#define AM_29LV004BB 0xB6
+#define AM_29LV004BT 0xB5
+#define AM_29LV008BB 0x37
+#define AM_29LV008BT 0x3E
#define AM_29LV040B 0x4F
-#define AM_29LV081B 0x38
-#define AM_29F016D 0xAD
+#define AM_29LV080B 0x38 /* Same as Am29LV081B */
+#define AM_29LV200BB 0xBF
+#define AM_29LV200BT 0x3B
+#define AM_29LV800BB 0x5B /* Same as Am29LV800DB */
+#define AM_29LV400BT 0xB9
+#define AM_29LV400BB 0xBA
+#define AM_29LV800BT 0xDA /* Same as Am29LV800DT */
#define AMIC_ID 0x7F37 /* AMIC */
#define AMIC_ID_NOPREFIX 0x37 /* AMIC */
#define AMIC_A25L40P 0x2013
#define AMIC_A29002B 0x0d
-#define AMIC_A29002T 0x8c
+#define AMIC_A29002T 0x8C /* Same as A290021T */
#define AMIC_A29040B 0x86
#define AMIC_A29400T 0xB0 /* Same as 294001T */
#define AMIC_A29400U 0x31 /* Same as A294001U */
@@ -194,16 +218,29 @@
#define MBM29LV800TA 0xDA /* Same as MBM29LV800TE */
#define HYUNDAI_ID 0xAD /* Hyundai */
+#define HY_29F400T 0x23 /* Same as HY_29F400AT */
+#define HY_29F800B 0x58 /* Same as HY_29F800AB */
+#define HY_29LV800B 0x5B
+#define HY_29F040A 0xA4
+#define HY_29F400B 0xAB /* Same as HY_29F400AB */
+#define HY_29F002 0xB0
+#define HY_29LV400T 0xB9
+#define HY_29LV400B 0xBA
+#define HY_29F080 0xD5
+#define HY_29F800T 0xD6 /* Same as HY_29F800AT */
+#define HY_29LV800T 0xDA
#define IMT_ID 0x7F1F /* Integrated Memory Technologies */
#define IM_29F004B 0xAE
#define IM_29F004T 0xAF
#define INTEL_ID 0x89 /* Intel */
-#define I_82802AB 0xAD
-#define I_82802AC 0xAC
+#define I_82802AB 0xAD
+#define I_82802AC 0xAC
#define P28F001BXT 0x94 /* 28F001BX-T */
#define P28F001BXB 0x95 /* 28F001BX-B */
+#define SHARP_LH28F008SA 0xA2 /* Sharp chip, Intel Vendor ID */
+#define SHARP_LH28F008SC 0xA6 /* Sharp chip, Intel Vendor ID */
#define ISSI_ID 0xD5 /* ISSI Integrated Silicon Solutions */
@@ -287,14 +324,20 @@
#define PMC_49FL004 0x6E
#define SHARP_ID 0xB0 /* Sharp */
-#define SHARP_LHF00L04 0xCF
+#define SHARP_LH28F008BJxxPT 0xEC
+#define SHARP_LH28F008BJxxPB 0xED
+#define SHARP_LH28F800BVxxBTL 0x4B
+#define SHARP_LH28F800BVxxBV 0x4D
+#define SHARP_LH28F800BVxxTV 0x4C
+#define SHARP_LHF00L02 0xC9 /* Same as LHF00L06/LHF00L07 */
+#define SHARP_LHF00L04 0xCF /* Same as LHF00L03/LHF00L05 */
/*
* Spansion was previously a joint venture of AMD and Fujitsu.
* S25 chips are SPI. The first device ID byte is memory type and
* the second device ID byte is memory capacity.
*/
-#define SPANSION_ID 0x01 /* Spansion */
+#define SPANSION_ID 0x01 /* Spansion, same ID as AMD */
#define SPANSION_S25FL016A 0x0214
/*
@@ -336,13 +379,13 @@
#define SST_29SF040 0x13
#define SST_29VF040 0x14
#define SST_39SF010 0xB5
-#define SST_39SF020 0xB6
+#define SST_39SF020 0xB6 /* Same as 39SF020A */
#define SST_39SF040 0xB7
#define SST_39VF512 0xD4
#define SST_39VF010 0xD5
-#define SST_39VF020 0xD6
-#define SST_39VF040 0xD7
-#define SST_39VF080 0xD8 /* Same as SST_39LF080/39VF080/39VF088 */
+#define SST_39VF020 0xD6 /* Same as 39LF020 */
+#define SST_39VF040 0xD7 /* Same as 39LF040 */
+#define SST_39VF080 0xD8 /* Same as 39LF080/39VF080/39VF088 */
#define SST_49LF040B 0x50
#define SST_49LF040 0x51
#define SST_49LF020 0x61
@@ -351,7 +394,7 @@
#define SST_49LF080A 0x5B
#define SST_49LF002A 0x57
#define SST_49LF003A 0x1B
-#define SST_49LF004A 0x60
+#define SST_49LF004A 0x60 /* Same as 49LF004B */
#define SST_49LF008A 0x5A
#define SST_49LF004C 0x54
#define SST_49LF008C 0x59
@@ -389,14 +432,14 @@
#define ST_M50FW080 0x2D
#define ST_M50FW016 0x2E
#define ST_M50LPW116 0x30
-#define ST_M29F002B 0x34
-#define ST_M29F002T 0xB0 /* M29F002T / M29F002NT */
-#define ST_M29F040B 0xE2
+#define ST_M29F002B 0x34 /* Same as M29F002BB */
+#define ST_M29F002T 0xB0 /* Same as M29F002BT/M29F002NT/M29F002BNT */
+#define ST_M29F040B 0xE2 /* Same as M29F040 */
#define ST_M29F080 0xF1
#define ST_M29F200BT 0xD3
#define ST_M29F200BB 0xD4
-#define ST_M29F400BT 0xD5
-#define ST_M29F400BB 0xD6
+#define ST_M29F400BT 0xD5 /* Same as M29F400T */
+#define ST_M29F400BB 0xD6 /* Same as M29F400B */
#define ST_M29F800DB 0x58
#define ST_M29F800DT 0xEC
#define ST_M29W010B 0x23
@@ -427,8 +470,8 @@
#define W_25X32 0x3016
#define W_25X64 0x3017
#define W_29C011 0xC1
-#define W_29C020C 0x45
-#define W_29C040P 0x46
+#define W_29C020C 0x45 /* Same as W29C020 */
+#define W_29C040P 0x46 /* Same as W29C040 */
#define W_29EE011 0xC1
#define W_39L020 0xB5
#define W_39L040 0xB6