diff options
author | Paul Kocialkowski <contact@paulk.fr> | 2015-10-16 02:16:20 +0000 |
---|---|---|
committer | Stefan Tauner <stefan.tauner@alumni.tuwien.ac.at> | 2015-10-16 02:16:20 +0000 |
commit | c8305e1dee66cd69bd8fca38bff2c8bf32924306 (patch) | |
tree | 5093cc7a7f36228da0f1a2d8eba2e9c46239226a | |
parent | 557eb4ff18c7c8d01684a8d7afb7ffc12452bb50 (diff) | |
download | ast2050-flashrom-c8305e1dee66cd69bd8fca38bff2c8bf32924306.zip ast2050-flashrom-c8305e1dee66cd69bd8fca38bff2c8bf32924306.tar.gz |
Add support for 128 bytes write granularity
Some chips such as the ENE KB9012 internal flash require a write
granularity of 128 bytes.
Corresponding to flashrom svn r1897.
Signed-off-by: Paul Kocialkowski <contact@paulk.fr>
Acked-by: Nico Huber <nico.h@gmx.de>
-rw-r--r-- | flash.h | 1 | ||||
-rw-r--r-- | flashrom.c | 6 |
2 files changed, 7 insertions, 0 deletions
@@ -85,6 +85,7 @@ enum write_granularity { write_gran_1bit, /* Each bit can be cleared individually. */ write_gran_1byte, /* A byte can be written once. Further writes to an already written byte cause * its contents to be either undefined or to stay unchanged. */ + write_gran_128bytes, /* If less than 128 bytes are written, the unwritten bytes are undefined. */ write_gran_264bytes, /* If less than 264 bytes are written, the unwritten bytes are undefined. */ write_gran_512bytes, /* If less than 512 bytes are written, the unwritten bytes are undefined. */ write_gran_528bytes, /* If less than 528 bytes are written, the unwritten bytes are undefined. */ @@ -781,6 +781,9 @@ int need_erase(const uint8_t *have, const uint8_t *want, unsigned int len, enum break; } break; + case write_gran_128bytes: + result = need_erase_gran_bytes(have, want, len, 128); + break; case write_gran_256bytes: result = need_erase_gran_bytes(have, want, len, 256); break; @@ -847,6 +850,9 @@ static unsigned int get_next_write(const uint8_t *have, const uint8_t *want, uns case write_gran_1byte_implicit_erase: stride = 1; break; + case write_gran_128bytes: + stride = 128; + break; case write_gran_256bytes: stride = 256; break; |