mirror of
https://review.coreboot.org/flashrom.git
synced 2025-10-24 11:08:19 +02:00
Convert chips' message printing to msg_c* Fixed suggestions by Carl-Daniel
Corresponding to flashrom svn r982. Signed-off-by: Sean Nelson <audiohacked@gmail.com> Acked-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net>
This commit is contained in:
53
82802ab.c
53
82802ab.c
@@ -34,13 +34,13 @@
|
|||||||
// I need that Berkeley bit-map printer
|
// I need that Berkeley bit-map printer
|
||||||
void print_status_82802ab(uint8_t status)
|
void print_status_82802ab(uint8_t status)
|
||||||
{
|
{
|
||||||
printf_debug("%s", status & 0x80 ? "Ready:" : "Busy:");
|
msg_cdbg("%s", status & 0x80 ? "Ready:" : "Busy:");
|
||||||
printf_debug("%s", status & 0x40 ? "BE SUSPEND:" : "BE RUN/FINISH:");
|
msg_cdbg("%s", status & 0x40 ? "BE SUSPEND:" : "BE RUN/FINISH:");
|
||||||
printf_debug("%s", status & 0x20 ? "BE ERROR:" : "BE OK:");
|
msg_cdbg("%s", status & 0x20 ? "BE ERROR:" : "BE OK:");
|
||||||
printf_debug("%s", status & 0x10 ? "PROG ERR:" : "PROG OK:");
|
msg_cdbg("%s", status & 0x10 ? "PROG ERR:" : "PROG OK:");
|
||||||
printf_debug("%s", status & 0x8 ? "VP ERR:" : "VPP OK:");
|
msg_cdbg("%s", status & 0x8 ? "VP ERR:" : "VPP OK:");
|
||||||
printf_debug("%s", status & 0x4 ? "PROG SUSPEND:" : "PROG RUN/FINISH:");
|
msg_cdbg("%s", status & 0x4 ? "PROG SUSPEND:" : "PROG RUN/FINISH:");
|
||||||
printf_debug("%s", status & 0x2 ? "WP|TBL#|WP#,ABORT:" : "UNLOCK:");
|
msg_cdbg("%s", status & 0x2 ? "WP|TBL#|WP#,ABORT:" : "UNLOCK:");
|
||||||
}
|
}
|
||||||
|
|
||||||
int probe_82802ab(struct flashchip *flash)
|
int probe_82802ab(struct flashchip *flash)
|
||||||
@@ -65,21 +65,21 @@ int probe_82802ab(struct flashchip *flash)
|
|||||||
|
|
||||||
programmer_delay(10);
|
programmer_delay(10);
|
||||||
|
|
||||||
printf_debug("%s: id1 0x%02x, id2 0x%02x", __func__, id1, id2);
|
msg_cdbg("%s: id1 0x%02x, id2 0x%02x", __func__, id1, id2);
|
||||||
|
|
||||||
if (!oddparity(id1))
|
if (!oddparity(id1))
|
||||||
printf_debug(", id1 parity violation");
|
msg_cdbg(", id1 parity violation");
|
||||||
|
|
||||||
/* Read the product ID location again. We should now see normal flash contents. */
|
/* Read the product ID location again. We should now see normal flash contents. */
|
||||||
flashcontent1 = chip_readb(bios);
|
flashcontent1 = chip_readb(bios);
|
||||||
flashcontent2 = chip_readb(bios + 0x01);
|
flashcontent2 = chip_readb(bios + 0x01);
|
||||||
|
|
||||||
if (id1 == flashcontent1)
|
if (id1 == flashcontent1)
|
||||||
printf_debug(", id1 is normal flash content");
|
msg_cdbg(", id1 is normal flash content");
|
||||||
if (id2 == flashcontent2)
|
if (id2 == flashcontent2)
|
||||||
printf_debug(", id2 is normal flash content");
|
msg_cdbg(", id2 is normal flash content");
|
||||||
|
|
||||||
printf_debug("\n");
|
msg_cdbg("\n");
|
||||||
if (id1 != flash->manufacture_id || id2 != flash->model_id)
|
if (id1 != flash->manufacture_id || id2 != flash->model_id)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@@ -137,10 +137,10 @@ int erase_block_82802ab(struct flashchip *flash, unsigned int page, unsigned int
|
|||||||
print_status_82802ab(status);
|
print_status_82802ab(status);
|
||||||
|
|
||||||
if (check_erased_range(flash, page, pagesize)) {
|
if (check_erased_range(flash, page, pagesize)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
printf("DONE BLOCK 0x%x\n", page);
|
msg_cinfo("DONE BLOCK 0x%x\n", page);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -150,14 +150,14 @@ int erase_82802ab(struct flashchip *flash)
|
|||||||
int i;
|
int i;
|
||||||
unsigned int total_size = flash->total_size * 1024;
|
unsigned int total_size = flash->total_size * 1024;
|
||||||
|
|
||||||
printf("total_size is %d; flash->page_size is %d\n",
|
msg_cspew("total_size is %d; flash->page_size is %d\n",
|
||||||
total_size, flash->page_size);
|
total_size, flash->page_size);
|
||||||
for (i = 0; i < total_size; i += flash->page_size)
|
for (i = 0; i < total_size; i += flash->page_size)
|
||||||
if (erase_block_82802ab(flash, i, flash->page_size)) {
|
if (erase_block_82802ab(flash, i, flash->page_size)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
printf("DONE ERASE\n");
|
msg_cinfo("DONE ERASE\n");
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -184,14 +184,13 @@ int write_82802ab(struct flashchip *flash, uint8_t *buf)
|
|||||||
uint8_t *tmpbuf = malloc(page_size);
|
uint8_t *tmpbuf = malloc(page_size);
|
||||||
|
|
||||||
if (!tmpbuf) {
|
if (!tmpbuf) {
|
||||||
printf("Could not allocate memory!\n");
|
msg_cerr("Could not allocate memory!\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
printf("Programming page: \n");
|
msg_cinfo("Programming page: \n");
|
||||||
for (i = 0; i < total_size / page_size; i++) {
|
for (i = 0; i < total_size / page_size; i++) {
|
||||||
printf
|
msg_cinfo("\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\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");
|
msg_cinfo("%04d at address: 0x%08x", i, i * page_size);
|
||||||
printf("%04d at address: 0x%08x", i, i * page_size);
|
|
||||||
|
|
||||||
/* Auto Skip Blocks, which already contain the desired data
|
/* Auto Skip Blocks, which already contain the desired data
|
||||||
* Faster, because we only write, what has changed
|
* Faster, because we only write, what has changed
|
||||||
@@ -202,19 +201,19 @@ int write_82802ab(struct flashchip *flash, uint8_t *buf)
|
|||||||
*/
|
*/
|
||||||
chip_readn(tmpbuf, bios + i * page_size, page_size);
|
chip_readn(tmpbuf, bios + i * page_size, page_size);
|
||||||
if (!memcmp((void *)(buf + i * page_size), tmpbuf, page_size)) {
|
if (!memcmp((void *)(buf + i * page_size), tmpbuf, page_size)) {
|
||||||
printf("SKIPPED\n");
|
msg_cdbg("SKIPPED\n");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* erase block by block and write block by block; this is the most secure way */
|
/* erase block by block and write block by block; this is the most secure way */
|
||||||
if (erase_block_82802ab(flash, i * page_size, page_size)) {
|
if (erase_block_82802ab(flash, i * page_size, page_size)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_82802ab(bios, buf + i * page_size,
|
write_page_82802ab(bios, buf + i * page_size,
|
||||||
bios + i * page_size, page_size);
|
bios + i * page_size, page_size);
|
||||||
}
|
}
|
||||||
printf("\n");
|
msg_cinfo("DONE!\n");
|
||||||
free(tmpbuf);
|
free(tmpbuf);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@@ -234,7 +233,7 @@ int unlock_28f004s5(struct flashchip *flash)
|
|||||||
|
|
||||||
/* Read master lock-bit */
|
/* Read master lock-bit */
|
||||||
mcfg = chip_readb(bios + 0x3);
|
mcfg = chip_readb(bios + 0x3);
|
||||||
msg_cinfo("master lock is ");
|
msg_cdbg("master lock is ");
|
||||||
if (mcfg) {
|
if (mcfg) {
|
||||||
msg_cdbg("locked!\n");
|
msg_cdbg("locked!\n");
|
||||||
} else {
|
} else {
|
||||||
@@ -256,9 +255,11 @@ int unlock_28f004s5(struct flashchip *flash)
|
|||||||
|
|
||||||
/* Unlock: clear block lock-bits, if needed */
|
/* Unlock: clear block lock-bits, if needed */
|
||||||
if (can_unlock && need_unlock) {
|
if (can_unlock && need_unlock) {
|
||||||
|
msg_cdbg("Unlock: ");
|
||||||
chip_writeb(0x60, bios);
|
chip_writeb(0x60, bios);
|
||||||
chip_writeb(0xD0, bios);
|
chip_writeb(0xD0, bios);
|
||||||
chip_writeb(0xFF, bios);
|
chip_writeb(0xFF, bios);
|
||||||
|
msg_cdbg("Done!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Error: master locked or a block is locked */
|
/* Error: master locked or a block is locked */
|
||||||
|
54
jedec.c
54
jedec.c
@@ -55,7 +55,7 @@ void toggle_ready_jedec_common(chipaddr dst, int delay)
|
|||||||
tmp1 = tmp2;
|
tmp1 = tmp2;
|
||||||
}
|
}
|
||||||
if (i > 0x100000)
|
if (i > 0x100000)
|
||||||
printf_debug("%s: excessive loops, i=0x%x\n", __func__, i);
|
msg_cdbg("%s: excessive loops, i=0x%x\n", __func__, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
void toggle_ready_jedec(chipaddr dst)
|
void toggle_ready_jedec(chipaddr dst)
|
||||||
@@ -89,7 +89,7 @@ void data_polling_jedec(chipaddr dst, uint8_t data)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (i > 0x100000)
|
if (i > 0x100000)
|
||||||
printf_debug("%s: excessive loops, i=0x%x\n", __func__, i);
|
msg_cdbg("%s: excessive loops, i=0x%x\n", __func__, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
void start_program_jedec_common(struct flashchip *flash, unsigned int mask)
|
void start_program_jedec_common(struct flashchip *flash, unsigned int mask)
|
||||||
@@ -113,12 +113,12 @@ int probe_jedec_common(struct flashchip *flash, unsigned int mask)
|
|||||||
else if (flash->probe_timing == TIMING_ZERO) { /* No delay. */
|
else if (flash->probe_timing == TIMING_ZERO) { /* No delay. */
|
||||||
probe_timing_enter = probe_timing_exit = 0;
|
probe_timing_enter = probe_timing_exit = 0;
|
||||||
} else if (flash->probe_timing == TIMING_FIXME) { /* == _IGNORED */
|
} else if (flash->probe_timing == TIMING_FIXME) { /* == _IGNORED */
|
||||||
printf_debug("Chip lacks correct probe timing information, "
|
msg_cdbg("Chip lacks correct probe timing information, "
|
||||||
"using default 10mS/40uS. ");
|
"using default 10mS/40uS. ");
|
||||||
probe_timing_enter = 10000;
|
probe_timing_enter = 10000;
|
||||||
probe_timing_exit = 40;
|
probe_timing_exit = 40;
|
||||||
} else {
|
} else {
|
||||||
printf("Chip has negative value in probe_timing, failing "
|
msg_cerr("Chip has negative value in probe_timing, failing "
|
||||||
"without chip access\n");
|
"without chip access\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -166,9 +166,9 @@ int probe_jedec_common(struct flashchip *flash, unsigned int mask)
|
|||||||
if (probe_timing_exit)
|
if (probe_timing_exit)
|
||||||
programmer_delay(probe_timing_exit);
|
programmer_delay(probe_timing_exit);
|
||||||
|
|
||||||
printf_debug("%s: id1 0x%02x, id2 0x%02x", __func__, largeid1, largeid2);
|
msg_cdbg("%s: id1 0x%02x, id2 0x%02x", __func__, largeid1, largeid2);
|
||||||
if (!oddparity(id1))
|
if (!oddparity(id1))
|
||||||
printf_debug(", id1 parity violation");
|
msg_cdbg(", id1 parity violation");
|
||||||
|
|
||||||
/* Read the product ID location again. We should now see normal flash contents. */
|
/* Read the product ID location again. We should now see normal flash contents. */
|
||||||
flashcontent1 = chip_readb(bios);
|
flashcontent1 = chip_readb(bios);
|
||||||
@@ -185,11 +185,11 @@ int probe_jedec_common(struct flashchip *flash, unsigned int mask)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (largeid1 == flashcontent1)
|
if (largeid1 == flashcontent1)
|
||||||
printf_debug(", id1 is normal flash content");
|
msg_cdbg(", id1 is normal flash content");
|
||||||
if (largeid2 == flashcontent2)
|
if (largeid2 == flashcontent2)
|
||||||
printf_debug(", id2 is normal flash content");
|
msg_cdbg(", id2 is normal flash content");
|
||||||
|
|
||||||
printf_debug("\n");
|
msg_cdbg("\n");
|
||||||
if (largeid1 != flash->manufacture_id || largeid2 != flash->model_id)
|
if (largeid1 != flash->manufacture_id || largeid2 != flash->model_id)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@@ -223,7 +223,7 @@ int erase_sector_jedec_common(struct flashchip *flash, unsigned int page,
|
|||||||
toggle_ready_jedec_slow(bios);
|
toggle_ready_jedec_slow(bios);
|
||||||
|
|
||||||
if (check_erased_range(flash, page, pagesize)) {
|
if (check_erased_range(flash, page, pagesize)) {
|
||||||
fprintf(stderr,"ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -253,7 +253,7 @@ int erase_block_jedec_common(struct flashchip *flash, unsigned int block,
|
|||||||
toggle_ready_jedec_slow(bios);
|
toggle_ready_jedec_slow(bios);
|
||||||
|
|
||||||
if (check_erased_range(flash, block, blocksize)) {
|
if (check_erased_range(flash, block, blocksize)) {
|
||||||
fprintf(stderr,"ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -282,7 +282,7 @@ int erase_chip_jedec_common(struct flashchip *flash, unsigned int mask)
|
|||||||
toggle_ready_jedec_slow(bios);
|
toggle_ready_jedec_slow(bios);
|
||||||
|
|
||||||
if (check_erased_range(flash, 0, total_size)) {
|
if (check_erased_range(flash, 0, total_size)) {
|
||||||
fprintf(stderr,"ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -330,7 +330,7 @@ int write_sector_jedec_common(struct flashchip *flash, uint8_t *src,
|
|||||||
dst++, src++;
|
dst++, src++;
|
||||||
}
|
}
|
||||||
if (failed)
|
if (failed)
|
||||||
fprintf(stderr, " writing sector at 0x%lx failed!\n", olddst);
|
msg_cerr(" writing sector at 0x%lx failed!\n", olddst);
|
||||||
|
|
||||||
return failed;
|
return failed;
|
||||||
}
|
}
|
||||||
@@ -364,11 +364,11 @@ retry:
|
|||||||
failed = verify_range(flash, src, start, page_size, NULL);
|
failed = verify_range(flash, src, start, page_size, NULL);
|
||||||
|
|
||||||
if (failed && tried++ < MAX_REFLASH_TRIES) {
|
if (failed && tried++ < MAX_REFLASH_TRIES) {
|
||||||
fprintf(stderr, "retrying.\n");
|
msg_cerr("retrying.\n");
|
||||||
goto retry;
|
goto retry;
|
||||||
}
|
}
|
||||||
if (failed) {
|
if (failed) {
|
||||||
fprintf(stderr, " page 0x%lx failed!\n",
|
msg_cerr(" page 0x%lx failed!\n",
|
||||||
(d - bios) / page_size);
|
(d - bios) / page_size);
|
||||||
}
|
}
|
||||||
return failed;
|
return failed;
|
||||||
@@ -387,7 +387,7 @@ int getaddrmask(struct flashchip *flash)
|
|||||||
return MASK_AAA;
|
return MASK_AAA;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "%s called with unknown mask\n", __func__);
|
msg_cerr("%s called with unknown mask\n", __func__);
|
||||||
return 0;
|
return 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -403,19 +403,19 @@ int write_jedec(struct flashchip *flash, uint8_t *buf)
|
|||||||
mask = getaddrmask(flash);
|
mask = getaddrmask(flash);
|
||||||
|
|
||||||
if (erase_chip_jedec(flash)) {
|
if (erase_chip_jedec(flash)) {
|
||||||
fprintf(stderr,"ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Programming page: ");
|
msg_cinfo("Programming page: ");
|
||||||
for (i = 0; i < total_size / page_size; i++) {
|
for (i = 0; i < total_size / page_size; i++) {
|
||||||
printf("%04d at address: 0x%08x", i, i * page_size);
|
msg_cinfo("%04d at address: 0x%08x", i, i * page_size);
|
||||||
if (write_page_write_jedec_common(flash, buf + i * page_size,
|
if (write_page_write_jedec_common(flash, buf + i * page_size,
|
||||||
i * page_size, page_size, mask))
|
i * page_size, page_size, mask))
|
||||||
failed = 1;
|
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");
|
msg_cinfo("\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");
|
msg_cinfo("DONE!\n");
|
||||||
|
|
||||||
return failed;
|
return failed;
|
||||||
}
|
}
|
||||||
@@ -431,22 +431,22 @@ int write_jedec_1(struct flashchip *flash, uint8_t * buf)
|
|||||||
|
|
||||||
programmer_delay(10);
|
programmer_delay(10);
|
||||||
if (erase_flash(flash)) {
|
if (erase_flash(flash)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Programming page: ");
|
msg_cinfo("Programming page: ");
|
||||||
for (i = 0; i < flash->total_size; i++) {
|
for (i = 0; i < flash->total_size; i++) {
|
||||||
if ((i & 0x3) == 0)
|
if ((i & 0x3) == 0)
|
||||||
printf("address: 0x%08lx", (unsigned long)i * 1024);
|
msg_cinfo("address: 0x%08lx", (unsigned long)i * 1024);
|
||||||
|
|
||||||
write_sector_jedec_common(flash, buf + i * 1024, dst + i * 1024, 1024, mask);
|
write_sector_jedec_common(flash, buf + i * 1024, dst + i * 1024, 1024, mask);
|
||||||
|
|
||||||
if ((i & 0x3) == 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");
|
msg_cinfo("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("\n");
|
msg_cinfo("DONE!\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -458,7 +458,7 @@ int erase_chip_block_jedec(struct flashchip *flash, unsigned int addr,
|
|||||||
|
|
||||||
mask = getaddrmask(flash);
|
mask = getaddrmask(flash);
|
||||||
if ((addr != 0) || (blocksize != flash->total_size * 1024)) {
|
if ((addr != 0) || (blocksize != flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "%s called with incorrect arguments\n",
|
msg_cerr("%s called with incorrect arguments\n",
|
||||||
__func__);
|
__func__);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
59
m29f400bt.c
59
m29f400bt.c
@@ -42,8 +42,7 @@ void write_page_m29f400bt(chipaddr bios, uint8_t *src,
|
|||||||
//chip_writeb(0xF0, bios);
|
//chip_writeb(0xF0, bios);
|
||||||
//programmer_delay(5);
|
//programmer_delay(5);
|
||||||
toggle_ready_jedec(dst);
|
toggle_ready_jedec(dst);
|
||||||
printf
|
msg_cerr("Value in the flash at address 0x%lx = %#x, want %#x\n",
|
||||||
("Value in the flash at address 0x%lx = %#x, want %#x\n",
|
|
||||||
(dst - bios), chip_readb(dst), *src);
|
(dst - bios), chip_readb(dst), *src);
|
||||||
dst++;
|
dst++;
|
||||||
src++;
|
src++;
|
||||||
@@ -73,7 +72,7 @@ int probe_m29f400bt(struct flashchip *flash)
|
|||||||
|
|
||||||
programmer_delay(10);
|
programmer_delay(10);
|
||||||
|
|
||||||
printf_debug("%s: id1 0x%02x, id2 0x%02x\n", __func__, id1, id2);
|
msg_cdbg("%s: id1 0x%02x, id2 0x%02x\n", __func__, id1, id2);
|
||||||
|
|
||||||
if (id1 == flash->manufacture_id && id2 == flash->model_id)
|
if (id1 == flash->manufacture_id && id2 == flash->model_id)
|
||||||
return 1;
|
return 1;
|
||||||
@@ -97,7 +96,7 @@ int erase_m29f400bt(struct flashchip *flash)
|
|||||||
toggle_ready_jedec(bios);
|
toggle_ready_jedec(bios);
|
||||||
|
|
||||||
if (check_erased_range(flash, 0, flash->total_size * 1024)) {
|
if (check_erased_range(flash, 0, flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -121,7 +120,7 @@ int block_erase_m29f400bt(struct flashchip *flash, unsigned int start, unsigned
|
|||||||
toggle_ready_jedec(bios);
|
toggle_ready_jedec(bios);
|
||||||
|
|
||||||
if (check_erased_range(flash, start, len)) {
|
if (check_erased_range(flash, start, len)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -130,7 +129,7 @@ int block_erase_m29f400bt(struct flashchip *flash, unsigned int start, unsigned
|
|||||||
int block_erase_chip_m29f400bt(struct flashchip *flash, unsigned int address, unsigned int blocklen)
|
int block_erase_chip_m29f400bt(struct flashchip *flash, unsigned int address, unsigned int blocklen)
|
||||||
{
|
{
|
||||||
if ((address != 0) || (blocklen != flash->total_size * 1024)) {
|
if ((address != 0) || (blocklen != flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "%s called with incorrect arguments\n",
|
msg_cerr("%s called with incorrect arguments\n",
|
||||||
__func__);
|
__func__);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@@ -145,7 +144,7 @@ int write_m29f400bt(struct flashchip *flash, uint8_t *buf)
|
|||||||
chipaddr bios = flash->virtual_memory;
|
chipaddr bios = flash->virtual_memory;
|
||||||
|
|
||||||
//erase_m29f400bt (flash);
|
//erase_m29f400bt (flash);
|
||||||
printf("Programming page:\n ");
|
msg_cinfo("Programming page:\n ");
|
||||||
/*********************************
|
/*********************************
|
||||||
*Pages for M29F400BT:
|
*Pages for M29F400BT:
|
||||||
* 16 0x7c000 0x7ffff TOP
|
* 16 0x7c000 0x7ffff TOP
|
||||||
@@ -161,47 +160,47 @@ int write_m29f400bt(struct flashchip *flash, uint8_t *buf)
|
|||||||
* 64 0x10000 0x1ffff
|
* 64 0x10000 0x1ffff
|
||||||
* 64 0x00000 0x0ffff BOTTOM
|
* 64 0x00000 0x0ffff BOTTOM
|
||||||
*********************************/
|
*********************************/
|
||||||
printf("total_size/page_size = %d\n", total_size / page_size);
|
msg_cinfo("total_size/page_size = %d\n", total_size / page_size);
|
||||||
for (i = 0; i < (total_size / page_size) - 1; i++) {
|
for (i = 0; i < (total_size / page_size) - 1; i++) {
|
||||||
printf("%04d at address: 0x%08x\n", i, i * page_size);
|
msg_cinfo("%04d at address: 0x%08x\n", i, i * page_size);
|
||||||
if (block_erase_m29f400bt(flash, i * page_size, page_size)) {
|
if (block_erase_m29f400bt(flash, i * page_size, page_size)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + i * page_size,
|
write_page_m29f400bt(bios, buf + i * page_size,
|
||||||
bios + i * page_size, page_size);
|
bios + i * page_size, page_size);
|
||||||
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");
|
msg_cinfo("\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("%04d at address: 0x%08x\n", 7, 0x70000);
|
msg_cinfo("%04d at address: 0x%08x\n", 7, 0x70000);
|
||||||
if (block_erase_m29f400bt(flash, 0x70000, 32 * 1024)) {
|
if (block_erase_m29f400bt(flash, 0x70000, 32 * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + 0x70000, bios + 0x70000, 32 * 1024);
|
write_page_m29f400bt(bios, buf + 0x70000, bios + 0x70000, 32 * 1024);
|
||||||
|
|
||||||
printf("%04d at address: 0x%08x\n", 8, 0x78000);
|
msg_cinfo("%04d at address: 0x%08x\n", 8, 0x78000);
|
||||||
if (block_erase_m29f400bt(flash, 0x78000, 8 * 1024)) {
|
if (block_erase_m29f400bt(flash, 0x78000, 8 * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + 0x78000, bios + 0x78000, 8 * 1024);
|
write_page_m29f400bt(bios, buf + 0x78000, bios + 0x78000, 8 * 1024);
|
||||||
|
|
||||||
printf("%04d at address: 0x%08x\n", 9, 0x7a000);
|
msg_cinfo("%04d at address: 0x%08x\n", 9, 0x7a000);
|
||||||
if (block_erase_m29f400bt(flash, 0x7a000, 8 * 1024)) {
|
if (block_erase_m29f400bt(flash, 0x7a000, 8 * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + 0x7a000, bios + 0x7a000, 8 * 1024);
|
write_page_m29f400bt(bios, buf + 0x7a000, bios + 0x7a000, 8 * 1024);
|
||||||
|
|
||||||
printf("%04d at address: 0x%08x\n", 10, 0x7c000);
|
msg_cinfo("%04d at address: 0x%08x\n", 10, 0x7c000);
|
||||||
if (block_erase_m29f400bt(flash, 0x7c000, 16 * 1024)) {
|
if (block_erase_m29f400bt(flash, 0x7c000, 16 * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + 0x7c000, bios + 0x7c000, 16 * 1024);
|
write_page_m29f400bt(bios, buf + 0x7c000, bios + 0x7c000, 16 * 1024);
|
||||||
|
|
||||||
printf("\n");
|
msg_cinfo("\n");
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -210,7 +209,7 @@ int write_coreboot_m29f400bt(struct flashchip *flash, uint8_t *buf)
|
|||||||
{
|
{
|
||||||
chipaddr bios = flash->virtual_memory;
|
chipaddr bios = flash->virtual_memory;
|
||||||
|
|
||||||
printf("Programming page:\n ");
|
msg_cinfo("Programming page:\n ");
|
||||||
/*********************************
|
/*********************************
|
||||||
*Pages for M29F400BT:
|
*Pages for M29F400BT:
|
||||||
* 16 0x7c000 0x7ffff TOP
|
* 16 0x7c000 0x7ffff TOP
|
||||||
@@ -226,35 +225,35 @@ int write_coreboot_m29f400bt(struct flashchip *flash, uint8_t *buf)
|
|||||||
* 64 0x10000 0x1ffff
|
* 64 0x10000 0x1ffff
|
||||||
* 64 0x00000 0x0ffff BOTTOM
|
* 64 0x00000 0x0ffff BOTTOM
|
||||||
*********************************/
|
*********************************/
|
||||||
printf("%04d at address: 0x%08x\n", 7, 0x00000);
|
msg_cinfo("%04d at address: 0x%08x\n", 7, 0x00000);
|
||||||
if (block_erase_m29f400bt(flash, 0x00000, 64 * 1024)) {
|
if (block_erase_m29f400bt(flash, 0x00000, 64 * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + 0x00000, bios + 0x00000, 64 * 1024);
|
write_page_m29f400bt(bios, buf + 0x00000, bios + 0x00000, 64 * 1024);
|
||||||
|
|
||||||
printf("%04d at address: 0x%08x\n", 7, 0x10000);
|
msg_cinfo("%04d at address: 0x%08x\n", 7, 0x10000);
|
||||||
if (block_erase_m29f400bt(flash, 0x10000, 64 * 1024)) {
|
if (block_erase_m29f400bt(flash, 0x10000, 64 * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + 0x10000, bios + 0x10000, 64 * 1024);
|
write_page_m29f400bt(bios, buf + 0x10000, bios + 0x10000, 64 * 1024);
|
||||||
|
|
||||||
printf("%04d at address: 0x%08x\n", 7, 0x20000);
|
msg_cinfo("%04d at address: 0x%08x\n", 7, 0x20000);
|
||||||
if (block_erase_m29f400bt(flash, 0x20000, 64 * 1024)) {
|
if (block_erase_m29f400bt(flash, 0x20000, 64 * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + 0x20000, bios + 0x20000, 64 * 1024);
|
write_page_m29f400bt(bios, buf + 0x20000, bios + 0x20000, 64 * 1024);
|
||||||
|
|
||||||
printf("%04d at address: 0x%08x\n", 7, 0x30000);
|
msg_cinfo("%04d at address: 0x%08x\n", 7, 0x30000);
|
||||||
if (block_erase_m29f400bt(flash, 0x30000, 64 * 1024)) {
|
if (block_erase_m29f400bt(flash, 0x30000, 64 * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
write_page_m29f400bt(bios, buf + 0x30000, bios + 0x30000, 64 * 1024);
|
write_page_m29f400bt(bios, buf + 0x30000, bios + 0x30000, 64 * 1024);
|
||||||
|
|
||||||
printf("\n");
|
msg_cinfo("\n");
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@@ -34,14 +34,14 @@ int erase_lhf00l04_block(struct flashchip *flash, unsigned int blockaddr, unsign
|
|||||||
|
|
||||||
// clear status register
|
// clear status register
|
||||||
chip_writeb(0x50, bios);
|
chip_writeb(0x50, bios);
|
||||||
printf("Erase at 0x%lx\n", bios);
|
msg_cdbg("Erase at 0x%lx\n", bios);
|
||||||
status = wait_82802ab(flash->virtual_memory);
|
status = wait_82802ab(flash->virtual_memory);
|
||||||
print_status_82802ab(status);
|
print_status_82802ab(status);
|
||||||
// clear write protect
|
// clear write protect
|
||||||
printf("write protect is at 0x%lx\n", (wrprotect));
|
msg_cspew("write protect is at 0x%lx\n", (wrprotect));
|
||||||
printf("write protect is 0x%x\n", chip_readb(wrprotect));
|
msg_cspew("write protect is 0x%x\n", chip_readb(wrprotect));
|
||||||
chip_writeb(0, wrprotect);
|
chip_writeb(0, wrprotect);
|
||||||
printf("write protect is 0x%x\n", chip_readb(wrprotect));
|
msg_cspew("write protect is 0x%x\n", chip_readb(wrprotect));
|
||||||
|
|
||||||
// now start it
|
// now start it
|
||||||
chip_writeb(0x20, bios);
|
chip_writeb(0x20, bios);
|
||||||
@@ -50,10 +50,10 @@ int erase_lhf00l04_block(struct flashchip *flash, unsigned int blockaddr, unsign
|
|||||||
// now let's see what the register is
|
// now let's see what the register is
|
||||||
status = wait_82802ab(flash->virtual_memory);
|
status = wait_82802ab(flash->virtual_memory);
|
||||||
print_status_82802ab(status);
|
print_status_82802ab(status);
|
||||||
printf("DONE BLOCK 0x%x\n", blockaddr);
|
msg_cinfo("DONE BLOCK 0x%x\n", blockaddr);
|
||||||
|
|
||||||
if (check_erased_range(flash, blockaddr, blocklen)) {
|
if (check_erased_range(flash, blockaddr, blocklen)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -67,17 +67,17 @@ int write_lhf00l04(struct flashchip *flash, uint8_t *buf)
|
|||||||
chipaddr bios = flash->virtual_memory;
|
chipaddr bios = flash->virtual_memory;
|
||||||
|
|
||||||
if (erase_flash(flash)) {
|
if (erase_flash(flash)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
printf("Programming page: ");
|
msg_cinfo("Programming page: ");
|
||||||
for (i = 0; i < total_size / page_size; i++) {
|
for (i = 0; i < total_size / page_size; i++) {
|
||||||
printf("%04d at address: 0x%08x", i, i * page_size);
|
msg_cinfo("%04d at address: 0x%08x", i, i * page_size);
|
||||||
write_page_82802ab(bios, buf + i * page_size,
|
write_page_82802ab(bios, buf + i * page_size,
|
||||||
bios + i * page_size, page_size);
|
bios + i * page_size, page_size);
|
||||||
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");
|
msg_cinfo("\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");
|
msg_cinfo("\n");
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
127
spi25.c
127
spi25.c
@@ -39,10 +39,10 @@ static int spi_rdid(unsigned char *readarr, int bytes)
|
|||||||
ret = spi_send_command(sizeof(cmd), bytes, cmd, readarr);
|
ret = spi_send_command(sizeof(cmd), bytes, cmd, readarr);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
printf_debug("RDID returned");
|
msg_cspew("RDID returned");
|
||||||
for (i = 0; i < bytes; i++)
|
for (i = 0; i < bytes; i++)
|
||||||
printf_debug(" 0x%02x", readarr[i]);
|
msg_cspew(" 0x%02x", readarr[i]);
|
||||||
printf_debug(". ");
|
msg_cspew(". ");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -63,7 +63,7 @@ static int spi_rems(unsigned char *readarr)
|
|||||||
}
|
}
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
printf_debug("REMS returned %02x %02x. ", readarr[0], readarr[1]);
|
msg_cspew("REMS returned %02x %02x. ", readarr[0], readarr[1]);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -84,7 +84,7 @@ static int spi_res(unsigned char *readarr)
|
|||||||
}
|
}
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
printf_debug("RES returned %02x. ", readarr[0]);
|
msg_cspew("RES returned %02x. ", readarr[0]);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -97,7 +97,7 @@ int spi_write_enable(void)
|
|||||||
result = spi_send_command(sizeof(cmd), 0, cmd, NULL);
|
result = spi_send_command(sizeof(cmd), 0, cmd, NULL);
|
||||||
|
|
||||||
if (result)
|
if (result)
|
||||||
fprintf(stderr, "%s failed\n", __func__);
|
msg_cerr("%s failed\n", __func__);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -120,12 +120,12 @@ static int probe_spi_rdid_generic(struct flashchip *flash, int bytes)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (!oddparity(readarr[0]))
|
if (!oddparity(readarr[0]))
|
||||||
printf_debug("RDID byte 0 parity violation. ");
|
msg_cdbg("RDID byte 0 parity violation. ");
|
||||||
|
|
||||||
/* Check if this is a continuation vendor ID */
|
/* Check if this is a continuation vendor ID */
|
||||||
if (readarr[0] == 0x7f) {
|
if (readarr[0] == 0x7f) {
|
||||||
if (!oddparity(readarr[1]))
|
if (!oddparity(readarr[1]))
|
||||||
printf_debug("RDID byte 1 parity violation. ");
|
msg_cdbg("RDID byte 1 parity violation. ");
|
||||||
id1 = (readarr[0] << 8) | readarr[1];
|
id1 = (readarr[0] << 8) | readarr[1];
|
||||||
id2 = readarr[2];
|
id2 = readarr[2];
|
||||||
if (bytes > 3) {
|
if (bytes > 3) {
|
||||||
@@ -137,7 +137,7 @@ static int probe_spi_rdid_generic(struct flashchip *flash, int bytes)
|
|||||||
id2 = (readarr[1] << 8) | readarr[2];
|
id2 = (readarr[1] << 8) | readarr[2];
|
||||||
}
|
}
|
||||||
|
|
||||||
printf_debug("%s: id1 0x%02x, id2 0x%02x\n", __func__, id1, id2);
|
msg_cdbg("%s: id1 0x%02x, id2 0x%02x\n", __func__, id1, id2);
|
||||||
|
|
||||||
if (id1 == flash->manufacture_id && id2 == flash->model_id) {
|
if (id1 == flash->manufacture_id && id2 == flash->model_id) {
|
||||||
/* Print the status register to tell the
|
/* Print the status register to tell the
|
||||||
@@ -192,7 +192,7 @@ int probe_spi_rdid4(struct flashchip *flash)
|
|||||||
#endif
|
#endif
|
||||||
return probe_spi_rdid_generic(flash, 4);
|
return probe_spi_rdid_generic(flash, 4);
|
||||||
default:
|
default:
|
||||||
printf_debug("4b ID not supported on this SPI controller\n");
|
msg_cinfo("4b ID not supported on this SPI controller\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@@ -209,7 +209,7 @@ int probe_spi_rems(struct flashchip *flash)
|
|||||||
id1 = readarr[0];
|
id1 = readarr[0];
|
||||||
id2 = readarr[1];
|
id2 = readarr[1];
|
||||||
|
|
||||||
printf_debug("%s: id1 0x%x, id2 0x%x\n", __func__, id1, id2);
|
msg_cdbg("%s: id1 0x%x, id2 0x%x\n", __func__, id1, id2);
|
||||||
|
|
||||||
if (id1 == flash->manufacture_id && id2 == flash->model_id) {
|
if (id1 == flash->manufacture_id && id2 == flash->model_id) {
|
||||||
/* Print the status register to tell the
|
/* Print the status register to tell the
|
||||||
@@ -262,7 +262,7 @@ int probe_spi_res(struct flashchip *flash)
|
|||||||
|
|
||||||
/* FIXME: Handle the case where RES gives a 2-byte response. */
|
/* FIXME: Handle the case where RES gives a 2-byte response. */
|
||||||
id2 = readarr[0];
|
id2 = readarr[0];
|
||||||
printf_debug("%s: id 0x%x\n", __func__, id2);
|
msg_cdbg("%s: id 0x%x\n", __func__, id2);
|
||||||
if (id2 != flash->model_id)
|
if (id2 != flash->model_id)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@@ -283,7 +283,7 @@ uint8_t spi_read_status_register(void)
|
|||||||
/* Read Status Register */
|
/* Read Status Register */
|
||||||
ret = spi_send_command(sizeof(cmd), sizeof(readarr), cmd, readarr);
|
ret = spi_send_command(sizeof(cmd), sizeof(readarr), cmd, readarr);
|
||||||
if (ret)
|
if (ret)
|
||||||
fprintf(stderr, "RDSR failed!\n");
|
msg_cerr("RDSR failed!\n");
|
||||||
|
|
||||||
return readarr[0];
|
return readarr[0];
|
||||||
}
|
}
|
||||||
@@ -291,17 +291,17 @@ uint8_t spi_read_status_register(void)
|
|||||||
/* Prettyprint the status register. Common definitions. */
|
/* Prettyprint the status register. Common definitions. */
|
||||||
void spi_prettyprint_status_register_common(uint8_t status)
|
void spi_prettyprint_status_register_common(uint8_t status)
|
||||||
{
|
{
|
||||||
printf_debug("Chip status register: Bit 5 / Block Protect 3 (BP3) is "
|
msg_cdbg("Chip status register: Bit 5 / Block Protect 3 (BP3) is "
|
||||||
"%sset\n", (status & (1 << 5)) ? "" : "not ");
|
"%sset\n", (status & (1 << 5)) ? "" : "not ");
|
||||||
printf_debug("Chip status register: Bit 4 / Block Protect 2 (BP2) is "
|
msg_cdbg("Chip status register: Bit 4 / Block Protect 2 (BP2) is "
|
||||||
"%sset\n", (status & (1 << 4)) ? "" : "not ");
|
"%sset\n", (status & (1 << 4)) ? "" : "not ");
|
||||||
printf_debug("Chip status register: Bit 3 / Block Protect 1 (BP1) is "
|
msg_cdbg("Chip status register: Bit 3 / Block Protect 1 (BP1) is "
|
||||||
"%sset\n", (status & (1 << 3)) ? "" : "not ");
|
"%sset\n", (status & (1 << 3)) ? "" : "not ");
|
||||||
printf_debug("Chip status register: Bit 2 / Block Protect 0 (BP0) is "
|
msg_cdbg("Chip status register: Bit 2 / Block Protect 0 (BP0) is "
|
||||||
"%sset\n", (status & (1 << 2)) ? "" : "not ");
|
"%sset\n", (status & (1 << 2)) ? "" : "not ");
|
||||||
printf_debug("Chip status register: Write Enable Latch (WEL) is "
|
msg_cdbg("Chip status register: Write Enable Latch (WEL) is "
|
||||||
"%sset\n", (status & (1 << 1)) ? "" : "not ");
|
"%sset\n", (status & (1 << 1)) ? "" : "not ");
|
||||||
printf_debug("Chip status register: Write In Progress (WIP/BUSY) is "
|
msg_cdbg("Chip status register: Write In Progress (WIP/BUSY) is "
|
||||||
"%sset\n", (status & (1 << 0)) ? "" : "not ");
|
"%sset\n", (status & (1 << 0)) ? "" : "not ");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -311,18 +311,18 @@ void spi_prettyprint_status_register_common(uint8_t status)
|
|||||||
*/
|
*/
|
||||||
void spi_prettyprint_status_register_st_m25p(uint8_t status)
|
void spi_prettyprint_status_register_st_m25p(uint8_t status)
|
||||||
{
|
{
|
||||||
printf_debug("Chip status register: Status Register Write Disable "
|
msg_cdbg("Chip status register: Status Register Write Disable "
|
||||||
"(SRWD) is %sset\n", (status & (1 << 7)) ? "" : "not ");
|
"(SRWD) is %sset\n", (status & (1 << 7)) ? "" : "not ");
|
||||||
printf_debug("Chip status register: Bit 6 is "
|
msg_cdbg("Chip status register: Bit 6 is "
|
||||||
"%sset\n", (status & (1 << 6)) ? "" : "not ");
|
"%sset\n", (status & (1 << 6)) ? "" : "not ");
|
||||||
spi_prettyprint_status_register_common(status);
|
spi_prettyprint_status_register_common(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
void spi_prettyprint_status_register_sst25(uint8_t status)
|
void spi_prettyprint_status_register_sst25(uint8_t status)
|
||||||
{
|
{
|
||||||
printf_debug("Chip status register: Block Protect Write Disable "
|
msg_cdbg("Chip status register: Block Protect Write Disable "
|
||||||
"(BPL) is %sset\n", (status & (1 << 7)) ? "" : "not ");
|
"(BPL) is %sset\n", (status & (1 << 7)) ? "" : "not ");
|
||||||
printf_debug("Chip status register: Auto Address Increment Programming "
|
msg_cdbg("Chip status register: Auto Address Increment Programming "
|
||||||
"(AAI) is %sset\n", (status & (1 << 6)) ? "" : "not ");
|
"(AAI) is %sset\n", (status & (1 << 6)) ? "" : "not ");
|
||||||
spi_prettyprint_status_register_common(status);
|
spi_prettyprint_status_register_common(status);
|
||||||
}
|
}
|
||||||
@@ -342,7 +342,7 @@ void spi_prettyprint_status_register_sst25vf016(uint8_t status)
|
|||||||
"all", "all"
|
"all", "all"
|
||||||
};
|
};
|
||||||
spi_prettyprint_status_register_sst25(status);
|
spi_prettyprint_status_register_sst25(status);
|
||||||
printf_debug("Resulting block protection : %s\n",
|
msg_cdbg("Resulting block protection : %s\n",
|
||||||
bpt[(status & 0x1c) >> 2]);
|
bpt[(status & 0x1c) >> 2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -356,7 +356,7 @@ void spi_prettyprint_status_register_sst25vf040b(uint8_t status)
|
|||||||
"all blocks", "all blocks", "all blocks", "all blocks"
|
"all blocks", "all blocks", "all blocks", "all blocks"
|
||||||
};
|
};
|
||||||
spi_prettyprint_status_register_sst25(status);
|
spi_prettyprint_status_register_sst25(status);
|
||||||
printf_debug("Resulting block protection : %s\n",
|
msg_cdbg("Resulting block protection : %s\n",
|
||||||
bpt[(status & 0x1c) >> 2]);
|
bpt[(status & 0x1c) >> 2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -365,7 +365,7 @@ void spi_prettyprint_status_register(struct flashchip *flash)
|
|||||||
uint8_t status;
|
uint8_t status;
|
||||||
|
|
||||||
status = spi_read_status_register();
|
status = spi_read_status_register();
|
||||||
printf_debug("Chip status register is %02x\n", status);
|
msg_cdbg("Chip status register is %02x\n", status);
|
||||||
switch (flash->manufacture_id) {
|
switch (flash->manufacture_id) {
|
||||||
case ST_ID:
|
case ST_ID:
|
||||||
if (((flash->model_id & 0xff00) == 0x2000) ||
|
if (((flash->model_id & 0xff00) == 0x2000) ||
|
||||||
@@ -416,13 +416,13 @@ int spi_chip_erase_60(struct flashchip *flash)
|
|||||||
|
|
||||||
result = spi_disable_blockprotect();
|
result = spi_disable_blockprotect();
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "spi_disable_blockprotect failed\n");
|
msg_cerr("spi_disable_blockprotect failed\n");
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution\n",
|
msg_cerr("%s failed during command execution\n",
|
||||||
__func__);
|
__func__);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -433,7 +433,7 @@ int spi_chip_erase_60(struct flashchip *flash)
|
|||||||
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
||||||
programmer_delay(1000 * 1000);
|
programmer_delay(1000 * 1000);
|
||||||
if (check_erased_range(flash, 0, flash->total_size * 1024)) {
|
if (check_erased_range(flash, 0, flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -462,13 +462,13 @@ int spi_chip_erase_c7(struct flashchip *flash)
|
|||||||
|
|
||||||
result = spi_disable_blockprotect();
|
result = spi_disable_blockprotect();
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "spi_disable_blockprotect failed\n");
|
msg_cerr("spi_disable_blockprotect failed\n");
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution\n", __func__);
|
msg_cerr("%s failed during command execution\n", __func__);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
/* Wait until the Write-In-Progress bit is cleared.
|
/* Wait until the Write-In-Progress bit is cleared.
|
||||||
@@ -478,23 +478,12 @@ int spi_chip_erase_c7(struct flashchip *flash)
|
|||||||
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
||||||
programmer_delay(1000 * 1000);
|
programmer_delay(1000 * 1000);
|
||||||
if (check_erased_range(flash, 0, flash->total_size * 1024)) {
|
if (check_erased_range(flash, 0, flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int spi_chip_erase_60_c7(struct flashchip *flash)
|
|
||||||
{
|
|
||||||
int result;
|
|
||||||
result = spi_chip_erase_60(flash);
|
|
||||||
if (result) {
|
|
||||||
printf_debug("spi_chip_erase_60 failed, trying c7\n");
|
|
||||||
result = spi_chip_erase_c7(flash);
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
int spi_block_erase_52(struct flashchip *flash, unsigned int addr, unsigned int blocklen)
|
int spi_block_erase_52(struct flashchip *flash, unsigned int addr, unsigned int blocklen)
|
||||||
{
|
{
|
||||||
int result;
|
int result;
|
||||||
@@ -523,7 +512,7 @@ int spi_block_erase_52(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution at address 0x%x\n",
|
msg_cerr("%s failed during command execution at address 0x%x\n",
|
||||||
__func__, addr);
|
__func__, addr);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -533,7 +522,7 @@ int spi_block_erase_52(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
||||||
programmer_delay(100 * 1000);
|
programmer_delay(100 * 1000);
|
||||||
if (check_erased_range(flash, addr, blocklen)) {
|
if (check_erased_range(flash, addr, blocklen)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -572,7 +561,7 @@ int spi_block_erase_d8(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution at address 0x%x\n",
|
msg_cerr("%s failed during command execution at address 0x%x\n",
|
||||||
__func__, addr);
|
__func__, addr);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -582,7 +571,7 @@ int spi_block_erase_d8(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
||||||
programmer_delay(100 * 1000);
|
programmer_delay(100 * 1000);
|
||||||
if (check_erased_range(flash, addr, blocklen)) {
|
if (check_erased_range(flash, addr, blocklen)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -619,7 +608,7 @@ int spi_block_erase_d7(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution at address 0x%x\n",
|
msg_cerr("%s failed during command execution at address 0x%x\n",
|
||||||
__func__, addr);
|
__func__, addr);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -629,7 +618,7 @@ int spi_block_erase_d7(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
||||||
programmer_delay(100 * 1000);
|
programmer_delay(100 * 1000);
|
||||||
if (check_erased_range(flash, addr, blocklen)) {
|
if (check_erased_range(flash, addr, blocklen)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -643,17 +632,17 @@ int spi_chip_erase_d8(struct flashchip *flash)
|
|||||||
|
|
||||||
spi_disable_blockprotect();
|
spi_disable_blockprotect();
|
||||||
|
|
||||||
printf("Erasing chip: \n");
|
msg_cinfo("Erasing chip: \n");
|
||||||
|
|
||||||
for (i = 0; i < total_size / erase_size; i++) {
|
for (i = 0; i < total_size / erase_size; i++) {
|
||||||
rc = spi_block_erase_d8(flash, i * erase_size, erase_size);
|
rc = spi_block_erase_d8(flash, i * erase_size, erase_size);
|
||||||
if (rc) {
|
if (rc) {
|
||||||
fprintf(stderr, "Error erasing block at 0x%x\n", i);
|
msg_cerr("Error erasing block at 0x%x\n", i);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("\n");
|
msg_cinfo("\n");
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
@@ -687,7 +676,7 @@ int spi_block_erase_20(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution at address 0x%x\n",
|
msg_cerr("%s failed during command execution at address 0x%x\n",
|
||||||
__func__, addr);
|
__func__, addr);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -697,7 +686,7 @@ int spi_block_erase_20(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
while (spi_read_status_register() & JEDEC_RDSR_BIT_WIP)
|
||||||
programmer_delay(10 * 1000);
|
programmer_delay(10 * 1000);
|
||||||
if (check_erased_range(flash, addr, blocklen)) {
|
if (check_erased_range(flash, addr, blocklen)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -706,7 +695,7 @@ int spi_block_erase_20(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
int spi_block_erase_60(struct flashchip *flash, unsigned int addr, unsigned int blocklen)
|
int spi_block_erase_60(struct flashchip *flash, unsigned int addr, unsigned int blocklen)
|
||||||
{
|
{
|
||||||
if ((addr != 0) || (blocklen != flash->total_size * 1024)) {
|
if ((addr != 0) || (blocklen != flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "%s called with incorrect arguments\n",
|
msg_cerr("%s called with incorrect arguments\n",
|
||||||
__func__);
|
__func__);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@@ -716,7 +705,7 @@ int spi_block_erase_60(struct flashchip *flash, unsigned int addr, unsigned int
|
|||||||
int spi_block_erase_c7(struct flashchip *flash, unsigned int addr, unsigned int blocklen)
|
int spi_block_erase_c7(struct flashchip *flash, unsigned int addr, unsigned int blocklen)
|
||||||
{
|
{
|
||||||
if ((addr != 0) || (blocklen != flash->total_size * 1024)) {
|
if ((addr != 0) || (blocklen != flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "%s called with incorrect arguments\n",
|
msg_cerr("%s called with incorrect arguments\n",
|
||||||
__func__);
|
__func__);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@@ -732,7 +721,7 @@ int spi_write_status_enable(void)
|
|||||||
result = spi_send_command(sizeof(cmd), JEDEC_EWSR_INSIZE, cmd, NULL);
|
result = spi_send_command(sizeof(cmd), JEDEC_EWSR_INSIZE, cmd, NULL);
|
||||||
|
|
||||||
if (result)
|
if (result)
|
||||||
fprintf(stderr, "%s failed\n", __func__);
|
msg_cerr("%s failed\n", __func__);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -765,7 +754,7 @@ int spi_write_status_register(int status)
|
|||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution\n",
|
msg_cerr("%s failed during command execution\n",
|
||||||
__func__);
|
__func__);
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
@@ -800,7 +789,7 @@ int spi_byte_program(int addr, uint8_t databyte)
|
|||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution at address 0x%x\n",
|
msg_cerr("%s failed during command execution at address 0x%x\n",
|
||||||
__func__, addr);
|
__func__, addr);
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
@@ -835,11 +824,11 @@ int spi_nbyte_program(int addr, uint8_t *bytes, int len)
|
|||||||
}};
|
}};
|
||||||
|
|
||||||
if (!len) {
|
if (!len) {
|
||||||
fprintf(stderr, "%s called for zero-length write\n", __func__);
|
msg_cerr("%s called for zero-length write\n", __func__);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (len > 256) {
|
if (len > 256) {
|
||||||
fprintf(stderr, "%s called for too long a write\n", __func__);
|
msg_cerr("%s called for too long a write\n", __func__);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -847,7 +836,7 @@ int spi_nbyte_program(int addr, uint8_t *bytes, int len)
|
|||||||
|
|
||||||
result = spi_send_multicommand(cmds);
|
result = spi_send_multicommand(cmds);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "%s failed during command execution at address 0x%x\n",
|
msg_cerr("%s failed during command execution at address 0x%x\n",
|
||||||
__func__, addr);
|
__func__, addr);
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
@@ -861,10 +850,10 @@ int spi_disable_blockprotect(void)
|
|||||||
status = spi_read_status_register();
|
status = spi_read_status_register();
|
||||||
/* If there is block protection in effect, unprotect it first. */
|
/* If there is block protection in effect, unprotect it first. */
|
||||||
if ((status & 0x3c) != 0) {
|
if ((status & 0x3c) != 0) {
|
||||||
printf_debug("Some block protection in effect, disabling\n");
|
msg_cdbg("Some block protection in effect, disabling\n");
|
||||||
result = spi_write_status_register(status & ~0x3c);
|
result = spi_write_status_register(status & ~0x3c);
|
||||||
if (result) {
|
if (result) {
|
||||||
fprintf(stderr, "spi_write_status_register failed\n");
|
msg_cerr("spi_write_status_register failed\n");
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -936,12 +925,12 @@ int spi_chip_write_1(struct flashchip *flash, uint8_t *buf)
|
|||||||
|
|
||||||
spi_disable_blockprotect();
|
spi_disable_blockprotect();
|
||||||
/* Erase first */
|
/* Erase first */
|
||||||
printf("Erasing flash before programming... ");
|
msg_cinfo("Erasing flash before programming... ");
|
||||||
if (erase_flash(flash)) {
|
if (erase_flash(flash)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
printf("done.\n");
|
msg_cinfo("done.\n");
|
||||||
for (i = 0; i < total_size; i++) {
|
for (i = 0; i < total_size; i++) {
|
||||||
result = spi_byte_program(i, buf[i]);
|
result = spi_byte_program(i, buf[i]);
|
||||||
if (result)
|
if (result)
|
||||||
@@ -962,7 +951,7 @@ int spi_aai_write(struct flashchip *flash, uint8_t *buf)
|
|||||||
switch (spi_controller) {
|
switch (spi_controller) {
|
||||||
#if INTERNAL_SUPPORT == 1
|
#if INTERNAL_SUPPORT == 1
|
||||||
case SPI_CONTROLLER_WBSIO:
|
case SPI_CONTROLLER_WBSIO:
|
||||||
fprintf(stderr, "%s: impossible with Winbond SPI masters,"
|
msg_cerr("%s: impossible with Winbond SPI masters,"
|
||||||
" degrading to byte program\n", __func__);
|
" degrading to byte program\n", __func__);
|
||||||
return spi_chip_write_1(flash, buf);
|
return spi_chip_write_1(flash, buf);
|
||||||
#endif
|
#endif
|
||||||
@@ -970,7 +959,7 @@ int spi_aai_write(struct flashchip *flash, uint8_t *buf)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (erase_flash(flash)) {
|
if (erase_flash(flash)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
/* FIXME: This will fail on ICH/VIA SPI. */
|
/* FIXME: This will fail on ICH/VIA SPI. */
|
||||||
|
16
sst28sf040.c
16
sst28sf040.c
@@ -63,7 +63,7 @@ int erase_sector_28sf040(struct flashchip *flash, unsigned int address, unsigned
|
|||||||
toggle_ready_jedec(bios);
|
toggle_ready_jedec(bios);
|
||||||
|
|
||||||
if (check_erased_range(flash, address, sector_size)) {
|
if (check_erased_range(flash, address, sector_size)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -105,7 +105,7 @@ int erase_28sf040(struct flashchip *flash)
|
|||||||
toggle_ready_jedec(bios);
|
toggle_ready_jedec(bios);
|
||||||
|
|
||||||
if (check_erased_range(flash, 0, flash->total_size * 1024)) {
|
if (check_erased_range(flash, 0, flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -120,21 +120,21 @@ int write_28sf040(struct flashchip *flash, uint8_t *buf)
|
|||||||
|
|
||||||
unprotect_28sf040(bios);
|
unprotect_28sf040(bios);
|
||||||
|
|
||||||
printf("Programming page: ");
|
msg_cinfo("Programming page: ");
|
||||||
for (i = 0; i < total_size / page_size; i++) {
|
for (i = 0; i < total_size / page_size; i++) {
|
||||||
/* erase the page before programming */
|
/* erase the page before programming */
|
||||||
if (erase_sector_28sf040(flash, i * page_size, page_size)) {
|
if (erase_sector_28sf040(flash, i * page_size, page_size)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* write to the sector */
|
/* write to the sector */
|
||||||
printf("%04d at address: 0x%08x", i, i * page_size);
|
msg_cinfo("%04d at address: 0x%08x", i, i * page_size);
|
||||||
write_sector_28sf040(bios, buf + i * page_size,
|
write_sector_28sf040(bios, buf + i * page_size,
|
||||||
bios + i * page_size, page_size);
|
bios + i * page_size, page_size);
|
||||||
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");
|
msg_cinfo("\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");
|
msg_cinfo("\n");
|
||||||
|
|
||||||
protect_28sf040(bios);
|
protect_28sf040(bios);
|
||||||
|
|
||||||
@@ -144,7 +144,7 @@ int write_28sf040(struct flashchip *flash, uint8_t *buf)
|
|||||||
int erase_chip_28sf040(struct flashchip *flash, unsigned int addr, unsigned int blocklen)
|
int erase_chip_28sf040(struct flashchip *flash, unsigned int addr, unsigned int blocklen)
|
||||||
{
|
{
|
||||||
if ((addr != 0) || (blocklen != flash->total_size * 1024)) {
|
if ((addr != 0) || (blocklen != flash->total_size * 1024)) {
|
||||||
fprintf(stderr, "%s called with incorrect arguments\n",
|
msg_cerr("%s called with incorrect arguments\n",
|
||||||
__func__);
|
__func__);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@@ -27,7 +27,7 @@
|
|||||||
int unlock_block_49lfxxxc(struct flashchip *flash, unsigned long address, unsigned char bits)
|
int unlock_block_49lfxxxc(struct flashchip *flash, unsigned long address, unsigned char bits)
|
||||||
{
|
{
|
||||||
unsigned long lock = flash->virtual_registers + address + 2;
|
unsigned long lock = flash->virtual_registers + address + 2;
|
||||||
printf_debug("lockbits at address=0x%08lx is 0x%01x\n", lock, chip_readb(lock));
|
msg_cdbg("lockbits at address=0x%08lx is 0x%01x\n", lock, chip_readb(lock));
|
||||||
chip_writeb(bits, lock);
|
chip_writeb(bits, lock);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@@ -39,30 +39,30 @@ static int write_lockbits_49lfxxxc(struct flashchip *flash, unsigned char bits)
|
|||||||
int i, left = flash->total_size * 1024;
|
int i, left = flash->total_size * 1024;
|
||||||
unsigned long address;
|
unsigned long address;
|
||||||
|
|
||||||
printf_debug("\nbios=0x%08lx\n", registers);
|
msg_cdbg("\nbios=0x%08lx\n", registers);
|
||||||
for (i = 0; left > 65536; i++, left -= 65536) {
|
for (i = 0; left > 65536; i++, left -= 65536) {
|
||||||
printf_debug("lockbits at address=0x%08lx is 0x%01x\n",
|
msg_cdbg("lockbits at address=0x%08lx is 0x%01x\n",
|
||||||
registers + (i * 65536) + 2,
|
registers + (i * 65536) + 2,
|
||||||
chip_readb(registers + (i * 65536) + 2));
|
chip_readb(registers + (i * 65536) + 2));
|
||||||
chip_writeb(bits, registers + (i * 65536) + 2);
|
chip_writeb(bits, registers + (i * 65536) + 2);
|
||||||
}
|
}
|
||||||
address = i * 65536;
|
address = i * 65536;
|
||||||
printf_debug("lockbits at address=0x%08lx is 0x%01x\n",
|
msg_cdbg("lockbits at address=0x%08lx is 0x%01x\n",
|
||||||
registers + address + 2,
|
registers + address + 2,
|
||||||
chip_readb(registers + address + 2));
|
chip_readb(registers + address + 2));
|
||||||
chip_writeb(bits, registers + address + 2);
|
chip_writeb(bits, registers + address + 2);
|
||||||
address += 32768;
|
address += 32768;
|
||||||
printf_debug("lockbits at address=0x%08lx is 0x%01x\n",
|
msg_cdbg("lockbits at address=0x%08lx is 0x%01x\n",
|
||||||
registers + address + 2,
|
registers + address + 2,
|
||||||
chip_readb(registers + address + 2));
|
chip_readb(registers + address + 2));
|
||||||
chip_writeb(bits, registers + address + 2);
|
chip_writeb(bits, registers + address + 2);
|
||||||
address += 8192;
|
address += 8192;
|
||||||
printf_debug("lockbits at address=0x%08lx is 0x%01x\n",
|
msg_cdbg("lockbits at address=0x%08lx is 0x%01x\n",
|
||||||
registers + address + 2,
|
registers + address + 2,
|
||||||
chip_readb(registers + address + 2));
|
chip_readb(registers + address + 2));
|
||||||
chip_writeb(bits, registers + address + 2);
|
chip_writeb(bits, registers + address + 2);
|
||||||
address += 8192;
|
address += 8192;
|
||||||
printf_debug("lockbits at address=0x%08lx is 0x%01x\n",
|
msg_cdbg("lockbits at address=0x%08lx is 0x%01x\n",
|
||||||
registers + address + 2,
|
registers + address + 2,
|
||||||
chip_readb(registers + address + 2));
|
chip_readb(registers + address + 2));
|
||||||
chip_writeb(bits, registers + address + 2);
|
chip_writeb(bits, registers + address + 2);
|
||||||
@@ -86,7 +86,7 @@ int erase_sector_49lfxxxc(struct flashchip *flash, unsigned int address, unsigne
|
|||||||
status = wait_82802ab(bios);
|
status = wait_82802ab(bios);
|
||||||
|
|
||||||
if (check_erased_range(flash, address, sector_size)) {
|
if (check_erased_range(flash, address, sector_size)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@@ -100,21 +100,21 @@ int write_49lfxxxc(struct flashchip *flash, uint8_t *buf)
|
|||||||
chipaddr bios = flash->virtual_memory;
|
chipaddr bios = flash->virtual_memory;
|
||||||
|
|
||||||
write_lockbits_49lfxxxc(flash, 0);
|
write_lockbits_49lfxxxc(flash, 0);
|
||||||
printf("Programming page: ");
|
msg_cinfo("Programming page: ");
|
||||||
for (i = 0; i < total_size / page_size; i++) {
|
for (i = 0; i < total_size / page_size; i++) {
|
||||||
/* erase the page before programming */
|
/* erase the page before programming */
|
||||||
if (erase_sector_49lfxxxc(flash, i * page_size, flash->page_size)) {
|
if (erase_sector_49lfxxxc(flash, i * page_size, flash->page_size)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* write to the sector */
|
/* write to the sector */
|
||||||
printf("%04d at address: 0x%08x", i, i * page_size);
|
msg_cinfo("%04d at address: 0x%08x", i, i * page_size);
|
||||||
write_page_82802ab(bios, buf + i * page_size,
|
write_page_82802ab(bios, buf + i * page_size,
|
||||||
bios + i * page_size, page_size);
|
bios + i * page_size, page_size);
|
||||||
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");
|
msg_cinfo("\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");
|
msg_cinfo("\n");
|
||||||
|
|
||||||
chip_writeb(0xFF, bios);
|
chip_writeb(0xFF, bios);
|
||||||
|
|
||||||
|
14
sst_fwhub.c
14
sst_fwhub.c
@@ -33,20 +33,20 @@ int check_sst_fwhub_block_lock(struct flashchip *flash, int offset)
|
|||||||
uint8_t blockstatus;
|
uint8_t blockstatus;
|
||||||
|
|
||||||
blockstatus = chip_readb(registers + offset + 2);
|
blockstatus = chip_readb(registers + offset + 2);
|
||||||
printf_debug("Lock status for 0x%06x (size 0x%06x) is %02x, ",
|
msg_cdbg("Lock status for 0x%06x (size 0x%06x) is %02x, ",
|
||||||
offset, flash->page_size, blockstatus);
|
offset, flash->page_size, blockstatus);
|
||||||
switch (blockstatus & 0x3) {
|
switch (blockstatus & 0x3) {
|
||||||
case 0x0:
|
case 0x0:
|
||||||
printf_debug("full access\n");
|
msg_cdbg("full access\n");
|
||||||
break;
|
break;
|
||||||
case 0x1:
|
case 0x1:
|
||||||
printf_debug("write locked\n");
|
msg_cdbg("write locked\n");
|
||||||
break;
|
break;
|
||||||
case 0x2:
|
case 0x2:
|
||||||
printf_debug("locked open\n");
|
msg_cdbg("locked open\n");
|
||||||
break;
|
break;
|
||||||
case 0x3:
|
case 0x3:
|
||||||
printf_debug("write locked down\n");
|
msg_cdbg("write locked down\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/* Return content of the write_locked bit */
|
/* Return content of the write_locked bit */
|
||||||
@@ -61,11 +61,11 @@ int clear_sst_fwhub_block_lock(struct flashchip *flash, int offset)
|
|||||||
blockstatus = check_sst_fwhub_block_lock(flash, offset);
|
blockstatus = check_sst_fwhub_block_lock(flash, offset);
|
||||||
|
|
||||||
if (blockstatus) {
|
if (blockstatus) {
|
||||||
printf_debug("Trying to clear lock for 0x%06x... ", offset)
|
msg_cdbg("Trying to clear lock for 0x%06x... ", offset);
|
||||||
chip_writeb(0, registers + offset + 2);
|
chip_writeb(0, registers + offset + 2);
|
||||||
|
|
||||||
blockstatus = check_sst_fwhub_block_lock(flash, offset);
|
blockstatus = check_sst_fwhub_block_lock(flash, offset);
|
||||||
printf_debug("%s\n", (blockstatus) ? "failed" : "OK");
|
msg_cdbg("%s\n", (blockstatus) ? "failed" : "OK");
|
||||||
}
|
}
|
||||||
|
|
||||||
return blockstatus;
|
return blockstatus;
|
||||||
|
@@ -61,19 +61,19 @@ int unlock_block_stm50flw0x0x(struct flashchip *flash, int offset)
|
|||||||
|
|
||||||
// unlock each 4k-sector
|
// unlock each 4k-sector
|
||||||
for (j = 0; j < 0x10000; j += 0x1000) {
|
for (j = 0; j < 0x10000; j += 0x1000) {
|
||||||
printf_debug("unlocking at 0x%x\n", offset + j);
|
msg_cdbg("unlocking at 0x%x\n", offset + j);
|
||||||
chip_writeb(unlock_sector, wrprotect + offset + j);
|
chip_writeb(unlock_sector, wrprotect + offset + j);
|
||||||
if (chip_readb(wrprotect + offset + j) != unlock_sector) {
|
if (chip_readb(wrprotect + offset + j) != unlock_sector) {
|
||||||
printf("Cannot unlock sector @ 0x%x\n",
|
msg_cerr("Cannot unlock sector @ 0x%x\n",
|
||||||
offset + j);
|
offset + j);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
printf_debug("unlocking at 0x%x\n", offset);
|
msg_cdbg("unlocking at 0x%x\n", offset);
|
||||||
chip_writeb(unlock_sector, wrprotect + offset);
|
chip_writeb(unlock_sector, wrprotect + offset);
|
||||||
if (chip_readb(wrprotect + offset) != unlock_sector) {
|
if (chip_readb(wrprotect + offset) != unlock_sector) {
|
||||||
printf("Cannot unlock sector @ 0x%x\n", offset);
|
msg_cerr("Cannot unlock sector @ 0x%x\n", offset);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -87,7 +87,7 @@ int unlock_stm50flw0x0x(struct flashchip *flash)
|
|||||||
|
|
||||||
for (i = 0; i < flash->total_size * 1024; i+= flash->page_size) {
|
for (i = 0; i < flash->total_size * 1024; i+= flash->page_size) {
|
||||||
if(unlock_block_stm50flw0x0x(flash, i)) {
|
if(unlock_block_stm50flw0x0x(flash, i)) {
|
||||||
fprintf(stderr, "UNLOCK FAILED!\n");
|
msg_cerr("UNLOCK FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -101,7 +101,7 @@ int erase_sector_stm50flw0x0x(struct flashchip *flash, unsigned int sector, unsi
|
|||||||
|
|
||||||
// clear status register
|
// clear status register
|
||||||
chip_writeb(0x50, bios);
|
chip_writeb(0x50, bios);
|
||||||
printf_debug("Erase at 0x%lx\n", bios);
|
msg_cdbg("Erase at 0x%lx\n", bios);
|
||||||
// now start it
|
// now start it
|
||||||
chip_writeb(0x32, bios);
|
chip_writeb(0x32, bios);
|
||||||
chip_writeb(0xd0, bios);
|
chip_writeb(0xd0, bios);
|
||||||
@@ -110,10 +110,10 @@ int erase_sector_stm50flw0x0x(struct flashchip *flash, unsigned int sector, unsi
|
|||||||
wait_82802ab(flash->virtual_memory);
|
wait_82802ab(flash->virtual_memory);
|
||||||
|
|
||||||
if (check_erased_range(flash, sector, sectorsize)) {
|
if (check_erased_range(flash, sector, sectorsize)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
printf("DONE BLOCK 0x%x\n", sector);
|
msg_cinfo("DONE BLOCK 0x%x\n", sector);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -130,21 +130,20 @@ int erase_chip_stm50flw0x0x(struct flashchip *flash, unsigned int addr, unsigned
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Erasing page:\n");
|
msg_cinfo("Erasing page:\n");
|
||||||
for (i = 0; i < total_size / page_size; i++) {
|
for (i = 0; i < total_size / page_size; i++) {
|
||||||
printf
|
msg_cinfo("\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\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");
|
msg_cinfo("%04d at address: 0x%08x ", i, i * page_size);
|
||||||
printf("%04d at address: 0x%08x ", i, i * page_size);
|
|
||||||
//if (unlock_block_stm50flw0x0x(flash, i * page_size)) {
|
//if (unlock_block_stm50flw0x0x(flash, i * page_size)) {
|
||||||
// fprintf(stderr, "UNLOCK FAILED!\n");
|
// msg_cerr("UNLOCK FAILED!\n");
|
||||||
// return -1;
|
// return -1;
|
||||||
//}
|
//}
|
||||||
if (erase_block_82802ab(flash, i * page_size, page_size)) {
|
if (erase_block_82802ab(flash, i * page_size, page_size)) {
|
||||||
fprintf(stderr, "ERASE FAILED!\n");
|
msg_cerr("ERASE FAILED!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
printf("\n");
|
msg_cinfo("\n");
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@@ -29,7 +29,7 @@ int probe_w29ee011(struct flashchip *flash)
|
|||||||
extern char *chip_to_probe;
|
extern char *chip_to_probe;
|
||||||
|
|
||||||
if (!chip_to_probe || strcmp(chip_to_probe, "W29EE011")) {
|
if (!chip_to_probe || strcmp(chip_to_probe, "W29EE011")) {
|
||||||
printf_debug("Probing disabled for Winbond W29EE011 because "
|
msg_cdbg("Probing disabled for Winbond W29EE011 because "
|
||||||
"the probing sequence puts the AMIC A49LF040A in "
|
"the probing sequence puts the AMIC A49LF040A in "
|
||||||
"a funky state. Use 'flashrom -c W29EE011' if you "
|
"a funky state. Use 'flashrom -c W29EE011' if you "
|
||||||
"have a board with this chip.\n");
|
"have a board with this chip.\n");
|
||||||
@@ -62,7 +62,7 @@ int probe_w29ee011(struct flashchip *flash)
|
|||||||
chip_writeb(0xF0, bios + 0x5555);
|
chip_writeb(0xF0, bios + 0x5555);
|
||||||
programmer_delay(10);
|
programmer_delay(10);
|
||||||
|
|
||||||
printf_debug("%s: id1 0x%02x, id2 0x%02x\n", __func__, id1, id2);
|
msg_cdbg("%s: id1 0x%02x, id2 0x%02x\n", __func__, id1, id2);
|
||||||
|
|
||||||
if (id1 == flash->manufacture_id && id2 == flash->model_id)
|
if (id1 == flash->manufacture_id && id2 == flash->model_id)
|
||||||
return 1;
|
return 1;
|
||||||
|
@@ -42,7 +42,7 @@ int printlock_w39v040c(struct flashchip *flash)
|
|||||||
chip_writeb(0xF0, bios + 0x5555);
|
chip_writeb(0xF0, bios + 0x5555);
|
||||||
programmer_delay(40);
|
programmer_delay(40);
|
||||||
|
|
||||||
printf("%s: Boot block #TBL is %slocked, rest of chip #WP is %slocked.\n",
|
msg_cdbg("%s: Boot block #TBL is %slocked, rest of chip #WP is %slocked.\n",
|
||||||
__func__, lock & 0x4 ? "" : "un", lock & 0x8 ? "" : "un");
|
__func__, lock & 0x4 ? "" : "un", lock & 0x8 ? "" : "un");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
28
w39v080fa.c
28
w39v080fa.c
@@ -26,37 +26,37 @@ static int unlock_block_winbond_fwhub(struct flashchip *flash, int offset)
|
|||||||
chipaddr wrprotect = flash->virtual_registers + offset + 2;
|
chipaddr wrprotect = flash->virtual_registers + offset + 2;
|
||||||
uint8_t locking;
|
uint8_t locking;
|
||||||
|
|
||||||
printf_debug("Trying to unlock block @0x%08x = 0x%02x\n", offset,
|
msg_cdbg("Trying to unlock block @0x%08x = 0x%02x\n", offset,
|
||||||
chip_readb(wrprotect));
|
chip_readb(wrprotect));
|
||||||
|
|
||||||
locking = chip_readb(wrprotect);
|
locking = chip_readb(wrprotect);
|
||||||
switch (locking & 0x7) {
|
switch (locking & 0x7) {
|
||||||
case 0:
|
case 0:
|
||||||
printf_debug("Full Access.\n");
|
msg_cdbg("Full Access.\n");
|
||||||
return 0;
|
return 0;
|
||||||
case 1:
|
case 1:
|
||||||
printf_debug("Write Lock (Default State).\n");
|
msg_cdbg("Write Lock (Default State).\n");
|
||||||
chip_writeb(0, wrprotect);
|
chip_writeb(0, wrprotect);
|
||||||
return 0;
|
return 0;
|
||||||
case 2:
|
case 2:
|
||||||
printf_debug("Locked Open (Full Access, Lock Down).\n");
|
msg_cdbg("Locked Open (Full Access, Lock Down).\n");
|
||||||
return 0;
|
return 0;
|
||||||
case 3:
|
case 3:
|
||||||
fprintf(stderr, "Error: Write Lock, Locked Down.\n");
|
msg_cerr("Error: Write Lock, Locked Down.\n");
|
||||||
return -1;
|
return -1;
|
||||||
case 4:
|
case 4:
|
||||||
printf_debug("Read Lock.\n");
|
msg_cdbg("Read Lock.\n");
|
||||||
chip_writeb(0, wrprotect);
|
chip_writeb(0, wrprotect);
|
||||||
return 0;
|
return 0;
|
||||||
case 5:
|
case 5:
|
||||||
printf_debug("Read/Write Lock.\n");
|
msg_cdbg("Read/Write Lock.\n");
|
||||||
chip_writeb(0, wrprotect);
|
chip_writeb(0, wrprotect);
|
||||||
return 0;
|
return 0;
|
||||||
case 6:
|
case 6:
|
||||||
fprintf(stderr, "Error: Read Lock, Locked Down.\n");
|
msg_cerr("Error: Read Lock, Locked Down.\n");
|
||||||
return -1;
|
return -1;
|
||||||
case 7:
|
case 7:
|
||||||
fprintf(stderr, "Error: Read/Write Lock, Locked Down.\n");
|
msg_cerr("Error: Read/Write Lock, Locked Down.\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -89,17 +89,17 @@ int unlock_winbond_fwhub(struct flashchip *flash)
|
|||||||
chip_writeb(0xF0, bios + 0x5555);
|
chip_writeb(0xF0, bios + 0x5555);
|
||||||
programmer_delay(10);
|
programmer_delay(10);
|
||||||
|
|
||||||
printf_debug("Lockout bits:\n");
|
msg_cdbg("Lockout bits:\n");
|
||||||
|
|
||||||
if (locking & (1 << 2))
|
if (locking & (1 << 2))
|
||||||
fprintf(stderr, "Error: hardware bootblock locking (#TBL).\n");
|
msg_cerr("Error: hardware bootblock locking (#TBL).\n");
|
||||||
else
|
else
|
||||||
printf_debug("No hardware bootblock locking (good!)\n");
|
msg_cdbg("No hardware bootblock locking (good!)\n");
|
||||||
|
|
||||||
if (locking & (1 << 3))
|
if (locking & (1 << 3))
|
||||||
fprintf(stderr, "Error: hardware block locking (#WP).\n");
|
msg_cerr("Error: hardware block locking (#WP).\n");
|
||||||
else
|
else
|
||||||
printf_debug("No hardware block locking (good!)\n");
|
msg_cdbg("No hardware block locking (good!)\n");
|
||||||
|
|
||||||
if (locking & ((1 << 2) | (1 << 3)))
|
if (locking & ((1 << 2) | (1 << 3)))
|
||||||
return -1;
|
return -1;
|
||||||
|
Reference in New Issue
Block a user