This patch demonstrates how we could refactor the jedec code. After the
refactor
we can delete these:
* am29f040b
* en29f002a -> file_not_used
* m29f002
* mx29f002
* pm29f002
* sst49lf040
* w49f002u
These files can be deleted if we *could* find a way to integrate the
problems
into jedec.c:
* w29ee011 -> checks specifically for w29ee011
* w39v040c -> checks for lock in probe: address 0xfff2
* pm49fl00x -> uses chip protect code
* m29f002 -> block based writing
* m29f400bt -> block based writing
I was looking through these two files and saw that they used variable block
sizes for writing sectors, maybe we can do something simpler to
block_erasers:
* m29f002
* m29f400bt
There are a few files that performs another map_flash_registers() after
successful probe, I was wondering if we could add the re-mapping to
probe_jedec_common or if its safe to omit the function call:
* pm49fl00x
* stm50flw0x0x
* w39v080fa
List of chips that use a specific addressing for command codes:
0x2AA based chips:
* am29f040b
* mx29f002
* pm29f002
0xAAA based chips:
* m29f002
* m29f400bt
0x2AAA based chips:
* pm49fl00x
* sst49lf040
* stm50flw0x0x
* w29ee011
* w39v040c
* w39v080fa
* w49f002u
If you want I can send my full notes so you can see what each file's
functions
can be converted to, on request. I don't know if my methods for the
address mask
is proper. If you can think of a better way, I'm all ears. Yes, I did
work on
this all Christmas Eve.
diff --git a/chipdrivers.h b/chipdrivers.h
index adcb46d..f722133 100644
--- a/chipdrivers.h
+++ b/chipdrivers.h
@@ -76,18 +76,34 @@ int write_en29f002a(struct flashchip *flash, uint8_t *buf);
uint8_t oddparity(uint8_t val);
void toggle_ready_jedec(chipaddr dst);
void data_polling_jedec(chipaddr dst, uint8_t data);
-void start_program_jedec(chipaddr bios);
-int write_byte_program_jedec(chipaddr bios, uint8_t *src,
- chipaddr dst);
+void start_program_jedec_common(chipaddr bios, unsigned int mask,
+ unsigned int shift);
+int write_byte_program_jedec(chipaddr bios, uint8_t *src, chipaddr dst);
+int probe_jedec_common(struct flashchip *flash, unsigned int entry_cmd,
+ unsigned int mid_cmd, unsigned int did_cmd,
+ unsigned int mask, unsigned int shift, int reset);
+int erase_chip_jedec_common(struct flashchip *flash, unsigned int mask,
+ unsigned int shift);
+int write_jedec_common(struct flashchip *flash, uint8_t *buf,
+ unsigned int mask, unsigned int shift);
+int erase_sector_jedec_common(struct flashchip *flash, unsigned int page,
+ unsigned int pagesize, unsigned int mask,
+ unsigned int shift);
+int erase_block_jedec_common(struct flashchip *flash, unsigned int page,
+ unsigned int blocksize, unsigned int mask,
+ unsigned int shift);
+int erase_chip_block_jedec(struct flashchip *flash, unsigned int page,
+ unsigned int blocksize);
+int write_sector_jedec_common(struct flashchip *flash, uint8_t *src, chipaddr
dst,
+ unsigned int page_size, unsigned int mask,
+ unsigned int shift);
int probe_jedec(struct flashchip *flash);
+int erase_sector_jedec(struct flashchip *flash, unsigned int page,
+ unsigned int pagesize);
int erase_chip_jedec(struct flashchip *flash);
+int erase_block_jedec(struct flashchip *flash, unsigned int page,
+ unsigned int blocksize);
int write_jedec(struct flashchip *flash, uint8_t *buf);
-int write_jedec_1(struct flashchip *flash, uint8_t *buf);
-int erase_sector_jedec(struct flashchip *flash, unsigned int page, unsigned
int pagesize);
-int erase_block_jedec(struct flashchip *flash, unsigned int page, unsigned int
blocksize);
-int erase_chip_block_jedec(struct flashchip *flash, unsigned int page,
unsigned int blocksize);
-int write_sector_jedec(chipaddr bios, uint8_t *src,
- chipaddr dst, unsigned int page_size);
/* m29f002.c */
int erase_m29f002(struct flashchip *flash);
diff --git a/flashchips.c b/flashchips.c
index 59f9139..af9039d 100644
--- a/flashchips.c
+++ b/flashchips.c
@@ -106,7 +106,7 @@ struct flashchip flashchips[] = {
.block_erase = erase_chip_block_jedec,
},
},
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -137,7 +137,7 @@ struct flashchip flashchips[] = {
.block_erase = erase_chip_block_jedec,
},
},
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -1182,7 +1182,7 @@ struct flashchip flashchips[] = {
.block_erase = erase_chip_29f002,
},
},
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -1213,7 +1213,7 @@ struct flashchip flashchips[] = {
.block_erase = erase_chip_29f002,
},
},
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -1574,7 +1574,7 @@ struct flashchip flashchips[] = {
.block_erase = erase_chip_block_jedec,
},
},
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -1605,7 +1605,7 @@ struct flashchip flashchips[] = {
.block_erase = erase_chip_block_jedec,
},
},
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -2112,7 +2112,7 @@ struct flashchip flashchips[] = {
.probe = probe_29f002,
.probe_timing = TIMING_IGNORED, /* routine don't use
probe_timing (mx29f002.c) */
.erase = erase_29f002,
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -2128,7 +2128,7 @@ struct flashchip flashchips[] = {
.probe = probe_29f002,
.probe_timing = TIMING_IGNORED, /* routine don't use
probe_timing (mx29f002.c) */
.erase = erase_29f002,
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -2159,7 +2159,7 @@ struct flashchip flashchips[] = {
.block_erase = erase_chip_29f002,
},
},
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -2190,7 +2190,7 @@ struct flashchip flashchips[] = {
.block_erase = erase_chip_29f002,
},
},
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
@@ -2206,7 +2206,7 @@ struct flashchip flashchips[] = {
.probe = probe_29f002,
.probe_timing = TIMING_IGNORED, /* routine don't use
probe_timing (mx29f002.c) */
.erase = erase_29f002,
- .write = write_jedec_1,
+ .write = write_jedec,
.read = read_memmapped,
},
diff --git a/jedec.c b/jedec.c
index d6cad41..86d3ac8 100644
--- a/jedec.c
+++ b/jedec.c
@@ -87,14 +87,16 @@ void data_polling_jedec(chipaddr dst, uint8_t data)
printf_debug("%s: excessive loops, i=0x%x\n", __func__, i);
}
-void start_program_jedec(chipaddr bios)
+void start_program_jedec_common(chipaddr bios, unsigned int mask, unsigned int
shift)
{
- chip_writeb(0xAA, bios + 0x5555);
- chip_writeb(0x55, bios + 0x2AAA);
- chip_writeb(0xA0, bios + 0x5555);
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
+ chip_writeb(0xA0, bios + (0x5555 & mask) );
}
-int probe_jedec(struct flashchip *flash)
+int probe_jedec_common(struct flashchip *flash, unsigned int entry_cmd,
+ unsigned int mid_cmd, unsigned int did_cmd,
+ unsigned int mask, unsigned int shift, int reset)
{
chipaddr bios = flash->virtual_memory;
uint8_t id1, id2;
@@ -118,19 +120,19 @@ int probe_jedec(struct flashchip *flash)
}
/* Issue JEDEC Product ID Entry command */
- chip_writeb(0xAA, bios + 0x5555);
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
if (probe_timing_enter)
programmer_delay(10);
- chip_writeb(0x55, bios + 0x2AAA);
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
if (probe_timing_enter)
programmer_delay(10);
- chip_writeb(0x90, bios + 0x5555);
+ chip_writeb(0x90, bios + (0x5555 & mask) );
if (probe_timing_enter)
programmer_delay(probe_timing_enter);
/* Read product ID */
- id1 = chip_readb(bios);
- id2 = chip_readb(bios + 0x01);
+ id1 = chip_readb(bios + mid_cmd);
+ id2 = chip_readb(bios + did_cmd);
largeid1 = id1;
largeid2 = id2;
@@ -147,13 +149,16 @@ int probe_jedec(struct flashchip *flash)
}
/* Issue JEDEC Product ID Exit command */
- chip_writeb(0xAA, bios + 0x5555);
- if (probe_timing_exit)
- programmer_delay(10);
- chip_writeb(0x55, bios + 0x2AAA);
- if (probe_timing_exit)
- programmer_delay(10);
- chip_writeb(0xF0, bios + 0x5555);
+ if (!reset)
+ {
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
+ if (probe_timing_exit)
+ programmer_delay(10);
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
+ if (probe_timing_exit)
+ programmer_delay(10);
+ }
+ chip_writeb(0xF0, bios + (0x5555 & mask) );
if (probe_timing_exit)
programmer_delay(probe_timing_exit);
@@ -184,24 +189,28 @@ int probe_jedec(struct flashchip *flash)
if (largeid1 == flash->manufacture_id && largeid2 == flash->model_id)
return 1;
+ //map_flash_registers(flash);
+
return 0;
}
-int erase_sector_jedec(struct flashchip *flash, unsigned int page, unsigned
int pagesize)
+int erase_sector_jedec_common(struct flashchip *flash, unsigned int page,
+ unsigned int pagesize, unsigned int mask,
+ unsigned int shift)
{
chipaddr bios = flash->virtual_memory;
/* Issue the Sector Erase command */
- chip_writeb(0xAA, bios + 0x5555);
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0x55, bios + 0x2AAA);
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
programmer_delay(10);
- chip_writeb(0x80, bios + 0x5555);
+ chip_writeb(0x80, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0xAA, bios + 0x5555);
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0x55, bios + 0x2AAA);
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
programmer_delay(10);
chip_writeb(0x30, bios + page);
programmer_delay(10);
@@ -216,21 +225,23 @@ int erase_sector_jedec(struct flashchip *flash, unsigned
int page, unsigned int
return 0;
}
-int erase_block_jedec(struct flashchip *flash, unsigned int block, unsigned
int blocksize)
+int erase_block_jedec_common(struct flashchip *flash, unsigned int block,
+ unsigned int blocksize, unsigned int mask,
+ unsigned int shift)
{
chipaddr bios = flash->virtual_memory;
/* Issue the Sector Erase command */
- chip_writeb(0xAA, bios + 0x5555);
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0x55, bios + 0x2AAA);
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
programmer_delay(10);
- chip_writeb(0x80, bios + 0x5555);
+ chip_writeb(0x80, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0xAA, bios + 0x5555);
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0x55, bios + 0x2AAA);
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
programmer_delay(10);
chip_writeb(0x50, bios + block);
programmer_delay(10);
@@ -245,35 +256,25 @@ int erase_block_jedec(struct flashchip *flash, unsigned
int block, unsigned int
return 0;
}
-/* erase chip with block_erase() prototype */
-int erase_chip_block_jedec(struct flashchip *flash, unsigned int addr,
unsigned int blocksize)
-{
- if ((addr != 0) || (blocksize != flash->total_size * 1024)) {
- fprintf(stderr, "%s called with incorrect arguments\n",
- __func__);
- return -1;
- }
- return erase_chip_jedec(flash);
-}
-
-int erase_chip_jedec(struct flashchip *flash)
+int erase_chip_jedec_common(struct flashchip *flash, unsigned int mask,
+ unsigned int shift)
{
int total_size = flash->total_size * 1024;
chipaddr bios = flash->virtual_memory;
/* Issue the JEDEC Chip Erase command */
- chip_writeb(0xAA, bios + 0x5555);
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0x55, bios + 0x2AAA);
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
programmer_delay(10);
- chip_writeb(0x80, bios + 0x5555);
+ chip_writeb(0x80, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0xAA, bios + 0x5555);
+ chip_writeb(0xAA, bios + (0x5555 & mask) );
programmer_delay(10);
- chip_writeb(0x55, bios + 0x2AAA);
+ chip_writeb(0x55, bios + ((0x2AAA & mask)>>shift) );
programmer_delay(10);
- chip_writeb(0x10, bios + 0x5555);
+ chip_writeb(0x10, bios + (0x5555 & mask) );
programmer_delay(10);
toggle_ready_jedec_slow(bios);
@@ -285,19 +286,29 @@ int erase_chip_jedec(struct flashchip *flash)
return 0;
}
-int write_page_write_jedec(struct flashchip *flash, uint8_t *src,
- int start, int page_size)
+/* erase chip with block_erase() prototype */
+int erase_chip_block_jedec(struct flashchip *flash, unsigned int addr,
+ unsigned int blocksize)
{
- int i, tried = 0, failed;
- uint8_t *s = src;
- chipaddr bios = flash->virtual_memory;
- chipaddr dst = bios + start;
- chipaddr d = dst;
+ if ((addr != 0) || (blocksize != flash->total_size * 1024)) {
+ fprintf(stderr, "%s called with incorrect arguments\n",
+ __func__);
+ return -1;
+ }
+ return erase_chip_jedec_common(flash, 0x0000, 0);
+}
-retry:
- /* Issue JEDEC Data Unprotect comand */
- start_program_jedec(bios);
+int write_helper_byte(uint8_t *src, chipaddr dst)
+{
+ /* transfer data from source to destination */
+ if (*src != 0xFF)
+ chip_writeb(*src, dst);
+ return 0;
+}
+int write_helper_page(uint8_t *src, chipaddr dst, int page_size)
+{
+ int i = 0;
/* transfer data from source to destination */
for (i = 0; i < page_size; i++) {
/* If the data is 0xFF, don't program it */
@@ -306,77 +317,53 @@ retry:
dst++;
src++;
}
-
- toggle_ready_jedec(dst - 1);
-
- dst = d;
- src = s;
- failed = verify_range(flash, src, start, page_size, NULL);
-
- if (failed && tried++ < MAX_REFLASH_TRIES) {
- fprintf(stderr, "retrying.\n");
- goto retry;
- }
- if (failed) {
- fprintf(stderr, " page 0x%lx failed!\n",
- (d - bios) / page_size);
- }
- return failed;
+ return 0;
}
-int write_byte_program_jedec(chipaddr bios, uint8_t *src,
- chipaddr dst)
+int write_sector_jedec_common(struct flashchip *flash, uint8_t *src,
+ chipaddr dst, unsigned int page_size,
unsigned int mask,
+ unsigned int shift)
{
- int tried = 0, failed = 0;
-
- /* If the data is 0xFF, don't program it and don't complain. */
- if (*src == 0xFF) {
- return 0;
- }
+ int tried = 0, failed;
+ chipaddr bios = flash->virtual_memory;
+ chipaddr v = bios;
retry:
- /* Issue JEDEC Byte Program command */
- start_program_jedec(bios);
-
- /* transfer data from source to destination */
- chip_writeb(*src, dst);
- toggle_ready_jedec(bios);
+ /* Issue JEDEC Data Unprotect comand */
+ start_program_jedec_common(bios, mask, shift);
- if (chip_readb(dst) != *src && tried++ < MAX_REFLASH_TRIES) {
- goto retry;
+ if (page_size > 1)
+ {
+ failed = write_helper_page(src, dst, page_size);
+ v = dst - 1;
+ }
+ else
+ {
+ failed = write_helper_byte(src, dst);
}
- if (tried >= MAX_REFLASH_TRIES)
- failed = 1;
-
- return failed;
-}
-
-int write_sector_jedec(chipaddr bios, uint8_t *src,
- chipaddr dst, unsigned int page_size)
-{
- int i, failed = 0;
- chipaddr olddst;
+ toggle_ready_jedec(v);
+ //failed = verify_range(flash, src, start, page_size, NULL);
- olddst = dst;
- for (i = 0; i < page_size; i++) {
- if (write_byte_program_jedec(bios, src, dst))
- failed = 1;
- dst++, src++;
+ if (failed && tried++ < MAX_REFLASH_TRIES) {
+ fprintf(stderr, "retrying.\n");
+ goto retry;
+ }
+ if (failed) {
+ fprintf(stderr, " page 0x%lx failed!\n",
+ (dst - bios) / page_size);
}
- if (failed)
- fprintf(stderr, " writing sector at 0x%lx failed!\n", olddst);
-
return failed;
}
-int write_jedec(struct flashchip *flash, uint8_t *buf)
+int write_jedec_common(struct flashchip *flash, uint8_t *buf, unsigned int
mask,
+ unsigned int shift)
{
int i, failed = 0;
int total_size = flash->total_size * 1024;
int page_size = flash->page_size;
- if (erase_chip_jedec(flash)) {
+ if (erase_chip_jedec_common(flash, mask, shift)) {
fprintf(stderr,"ERASE FAILED!\n");
return -1;
}
@@ -384,8 +371,8 @@ int write_jedec(struct flashchip *flash, uint8_t *buf)
printf("Programming page: ");
for (i = 0; i < total_size / page_size; i++) {
printf("%04d at address: 0x%08x", i, i * page_size);
- if (write_page_write_jedec(flash, buf + i * page_size,
- i * page_size, page_size))
+ if (write_sector_jedec_common(flash, buf + i * page_size,
+ i * page_size, page_size, mask,
shift))
failed = 1;
printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
}
@@ -394,29 +381,68 @@ int write_jedec(struct flashchip *flash, uint8_t *buf)
return failed;
}
-int write_jedec_1(struct flashchip *flash, uint8_t * buf)
+void start_program_jedec(chipaddr bios)
{
- int i;
- chipaddr bios = flash->virtual_memory;
- chipaddr dst = bios;
+ start_program_jedec_common(bios, 0x0000, 0);
+}
- programmer_delay(10);
- if (erase_flash(flash)) {
- fprintf(stderr, "ERASE FAILED!\n");
- return -1;
- }
+void start_program_jedec_2aa(chipaddr bios)
+{
+ start_program_jedec_common(bios, 0xf000, 2);
+}
- printf("Programming page: ");
- for (i = 0; i < flash->total_size; i++) {
- if ((i & 0x3) == 0)
- printf("address: 0x%08lx", (unsigned long)i * 1024);
+void start_program_jedec_aaa(chipaddr bios)
+{
+ start_program_jedec_common(bios, 0xf000, 0);
+}
- write_sector_jedec(bios, buf + i * 1024, dst + i * 1024, 1024);
+int probe_jedec(struct flashchip *flash)
+{
+ return probe_jedec_common(flash, 0x90, 0x00, 0x01, 0x0000, 0, 0);
+}
- if ((i & 0x3) == 0)
- printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
- }
+int probe_jedec_2aa_reset(struct flashchip *flash)
+{
+ return probe_jedec_common(flash, 0x90, 0x00, 0x01, 0xf000, 2, 1);
+}
- printf("\n");
- return 0;
+int probe_jedec_aaa_did_02(struct flashchip *flash)
+{
+ return probe_jedec_common(flash, 0x90, 0x00, 0x02, 0xf000, 0, 0);
+}
+
+int probe_jedec_60(struct flashchip *flash)
+{
+ return probe_jedec_common(flash, 0x60, 0x00, 0x01, 0x0000, 0, 0);
+}
+
+int erase_sector_jedec(struct flashchip *flash, unsigned int page, unsigned
int size)
+{
+ return erase_sector_jedec_common(flash, page, size, 0x0000, 0);
+}
+
+int erase_sector_jedec_2aa(struct flashchip *flash, unsigned int page,
unsigned int size)
+{
+ return erase_sector_jedec_common(flash, page, size, 0xf000, 2);
+}
+
+int erase_sector_jedec_aaa(struct flashchip *flash, unsigned int page,
unsigned int size)
+{
+ return erase_sector_jedec_common(flash, page, size, 0xf000, 0);
+}
+
+int erase_block_jedec(struct flashchip *flash, unsigned int page, unsigned int
size)
+{
+ return erase_block_jedec_common(flash, page, size, 0x0000, 0);
+}
+
+int erase_chip_jedec(struct flashchip *flash)
+{
+ return erase_chip_jedec_common(flash, 0x0000, 0);
}
+
+int write_jedec(struct flashchip *flash, uint8_t *buf)
+{
+ return write_jedec_common(flash, buf, 0x0000, 0);
+}
+
diff --git a/pm29f002.c b/pm29f002.c
index bf78d13..8f1d010 100644
--- a/pm29f002.c
+++ b/pm29f002.c
@@ -21,7 +21,7 @@
#include "flash.h"
/* if write_sector_jedec is used,
- this is write_jedec_1 */
+ this is write_jedec */
int write_pm29f002(struct flashchip *flash, uint8_t *buf)
{
int i, total_size = flash->total_size * 1024;
diff --git a/pm49fl00x.c b/pm49fl00x.c
index 27a1163..a016928 100644
--- a/pm49fl00x.c
+++ b/pm49fl00x.c
@@ -101,8 +101,8 @@ int write_49fl00x(struct flashchip *flash, uint8_t *buf)
/* write to the sector */
printf("%04d at address: 0x%08x", i, i * page_size);
- write_sector_jedec(bios, buf + i * page_size,
- bios + i * page_size, page_size);
+ write_sector_jedec_common(flash, buf + i * page_size,
+ bios + i * page_size, page_size,0,0);
printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
fflush(stdout);
}
diff --git a/sst49lf040.c b/sst49lf040.c
index ab1c918..821347b 100644
--- a/sst49lf040.c
+++ b/sst49lf040.c
@@ -59,8 +59,8 @@ int write_49lf040(struct flashchip *flash, uint8_t *buf)
if (i % 10 == 0)
printf("%04d at address: 0x%08x ", i, i * page_size);
- write_sector_jedec(bios, buf + i * page_size,
- bios + i * page_size, page_size);
+ write_sector_jedec_common(flash, buf + i * page_size,
+ bios + i * page_size, page_size, 0, 0);
if (i % 10 == 0)
printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
diff --git a/sst_fwhub.c b/sst_fwhub.c
index f09aa54..079dec5 100644
--- a/sst_fwhub.c
+++ b/sst_fwhub.c
@@ -157,8 +157,8 @@ int write_sst_fwhub(struct flashchip *flash, uint8_t *buf)
page_size);
if (rc)
return 1;
- write_sector_jedec(bios, buf + i * page_size,
- bios + i * page_size, page_size);
+ write_sector_jedec_common(flash, buf + i * page_size,
+ bios + i * page_size, page_size, 0,
0);
}
printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
}
diff --git a/w39v040c.c b/w39v040c.c
index 722ae29..b4b72ca 100644
--- a/w39v040c.c
+++ b/w39v040c.c
@@ -80,8 +80,8 @@ int write_w39v040c(struct flashchip *flash, uint8_t *buf)
printf("Programming page: ");
for (i = 0; i < total_size / page_size; i++) {
printf("%04d at address: 0x%08x", i, i * page_size);
- write_sector_jedec(bios, buf + i * page_size,
- bios + i * page_size, page_size);
+ write_sector_jedec_common(flash, buf + i * page_size,
+ bios + i * page_size, page_size, 0, 0);
printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
}
printf("\n");
diff --git a/w39v080fa.c b/w39v080fa.c
index 580657f..ec06d1b 100644
--- a/w39v080fa.c
+++ b/w39v080fa.c
@@ -182,7 +182,7 @@ int write_winbond_fwhub(struct flashchip *flash, uint8_t
*buf)
printf("Programming: ");
for (i = 0; i < total_size; i += flash->page_size) {
printf("0x%08x\b\b\b\b\b\b\b\b\b\b", i);
- write_sector_jedec(bios, buf + i, bios + i, flash->page_size);
+ write_sector_jedec_common(flash, buf + i, bios + i,
flash->page_size, 0, 0);
}
printf("\n");
diff --git a/w49f002u.c b/w49f002u.c
index d12bc72..28eaa99 100644
--- a/w49f002u.c
+++ b/w49f002u.c
@@ -36,8 +36,8 @@ int write_49f002(struct flashchip *flash, uint8_t *buf)
for (i = 0; i < total_size / page_size; i++) {
printf("%04d at address: 0x%08x ", i, i * page_size);
/* Byte-wise writing of 'page_size' bytes. */
- write_sector_jedec(bios, buf + i * page_size,
- bios + i * page_size, page_size);
+ write_sector_jedec_common(flash, buf + i * page_size,
+ bios + i * page_size, page_size, 0, 0);
printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
fflush(stdout);
}
_______________________________________________
flashrom mailing list
[email protected]
http://www.flashrom.org/mailman/listinfo/flashrom