[flashrom] [PATCH] EEPROM support: handle implicit erase

Carl-Daniel Hailfinger c-d.hailfinger.devel.2006 at gmx.net
Mon Jun 16 23:06:46 CEST 2014


Add support for EEPROMs with 1 byte granularity and implicit erase on
write. flashrom will not try to erase before write on these chips.
Explicitly requested erase is done by writing 0xff.

Signed-off-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006 at gmx.net>

Index: flashrom-no_implicit_erase/flash.h
===================================================================
--- flashrom-no_implicit_erase/flash.h	(Revision 1821)
+++ flashrom-no_implicit_erase/flash.h	(Arbeitskopie)
@@ -87,6 +87,7 @@
 	write_gran_528bytes,	/* If less than 528 bytes are written, the unwritten bytes are undefined. */
 	write_gran_1024bytes,	/* If less than 1024 bytes are written, the unwritten bytes are undefined. */
 	write_gran_1056bytes,	/* If less than 1056 bytes are written, the unwritten bytes are undefined. */
+	write_gran_1byte_implicit_erase, /* EEPROMs and other chips with implicit erase and 1-byte writes. */
 };
 
 /*
Index: flashrom-no_implicit_erase/flashrom.c
===================================================================
--- flashrom-no_implicit_erase/flashrom.c	(Revision 1821)
+++ flashrom-no_implicit_erase/flashrom.c	(Arbeitskopie)
@@ -766,6 +766,10 @@
 	case write_gran_1056bytes:
 		result = need_erase_gran_bytes(have, want, len, 1056);
 		break;
+	case write_gran_1byte_implicit_erase:
+		/* Do not erase, handle content changes from anything->0xff by writing 0xff. */
+		result = 0;
+		break;
 	default:
 		msg_cerr("%s: Unsupported granularity! Please report a bug at "
 			 "flashrom at flashrom.org\n", __func__);
@@ -807,6 +811,7 @@
 	switch (gran) {
 	case write_gran_1bit:
 	case write_gran_1byte:
+	case write_gran_1byte_implicit_erase:
 		stride = 1;
 		break;
 	case write_gran_256bytes:

-- 
http://www.hailfinger.org/





More information about the flashrom mailing list