Factor out read and erase functions from flashrom main().
Signed-off-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net> Acked-by: Peter Stuge <peter@stuge.se> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@3923 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
fe53c7628b
commit
b6dc72303c
1 changed files with 57 additions and 38 deletions
|
@ -187,6 +187,61 @@ int verify_flash(struct flashchip *flash, uint8_t *buf)
|
|||
return 0;
|
||||
}
|
||||
|
||||
int read_flash(struct flashchip *flash, char *filename, unsigned int exclude_start_position, unsigned int exclude_end_position)
|
||||
{
|
||||
unsigned long numbytes;
|
||||
FILE *image;
|
||||
unsigned long size = flash->total_size * 1024;
|
||||
unsigned char *buf = calloc(size, sizeof(char));
|
||||
if ((image = fopen(filename, "w")) == NULL) {
|
||||
perror(filename);
|
||||
exit(1);
|
||||
}
|
||||
printf("Reading flash... ");
|
||||
if (flash->read == NULL)
|
||||
memcpy(buf, (const char *)flash->virtual_memory, size);
|
||||
else
|
||||
flash->read(flash, buf);
|
||||
|
||||
if (exclude_end_position - exclude_start_position > 0)
|
||||
memset(buf + exclude_start_position, 0,
|
||||
exclude_end_position - exclude_start_position);
|
||||
|
||||
numbytes = fwrite(buf, 1, size, image);
|
||||
fclose(image);
|
||||
printf("%s.\n", numbytes == size ? "done" : "FAILED");
|
||||
if (numbytes != size)
|
||||
return 1;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int erase_flash(struct flashchip *flash)
|
||||
{
|
||||
uint32_t erasedbytes;
|
||||
unsigned long size = flash->total_size * 1024;
|
||||
unsigned char *buf = calloc(size, sizeof(char));
|
||||
printf("Erasing flash chip... ");
|
||||
if (NULL == flash->erase) {
|
||||
printf("FAILED!\n");
|
||||
fprintf(stderr, "ERROR: flashrom has no erase function for this flash chip.\n");
|
||||
return 1;
|
||||
}
|
||||
flash->erase(flash);
|
||||
if (NULL == flash->read)
|
||||
memcpy(buf, (const char *)flash->virtual_memory, size);
|
||||
else
|
||||
flash->read(flash, buf);
|
||||
for (erasedbytes = 0; erasedbytes < size; erasedbytes++)
|
||||
if (0xff != buf[erasedbytes]) {
|
||||
printf("FAILED!\n");
|
||||
fprintf(stderr, "ERROR at 0x%08x: Expected=0xff, Read=0x%02x\n",
|
||||
erasedbytes, buf[erasedbytes]);
|
||||
return 1;
|
||||
}
|
||||
printf("SUCCESS.\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
#define MAX(a, b) ((a) > (b) ? (a) : (b))
|
||||
#define POS_PRINT(x) do { pos += strlen(x); printf(x); } while (0)
|
||||
|
||||
|
@ -279,7 +334,6 @@ int main(int argc, char *argv[])
|
|||
{
|
||||
uint8_t *buf;
|
||||
unsigned long size, numbytes;
|
||||
uint32_t erasedbytes;
|
||||
FILE *image;
|
||||
/* Probe for up to three flash chips. */
|
||||
struct flashchip *flash, *flashes[3];
|
||||
|
@ -555,45 +609,10 @@ int main(int argc, char *argv[])
|
|||
buf = (uint8_t *) calloc(size, sizeof(char));
|
||||
|
||||
if (erase_it) {
|
||||
printf("Erasing flash chip... ");
|
||||
if (NULL == flash->erase) {
|
||||
printf("FAILED!\n");
|
||||
fprintf(stderr, "ERROR: flashrom has no erase function for this flash chip.\n");
|
||||
if (erase_flash(flash))
|
||||
return 1;
|
||||
}
|
||||
flash->erase(flash);
|
||||
if (NULL == flash->read)
|
||||
memcpy(buf, (const char *)flash->virtual_memory, size);
|
||||
else
|
||||
flash->read(flash, buf);
|
||||
for (erasedbytes = 0; erasedbytes < size; erasedbytes++)
|
||||
if (0xff != buf[erasedbytes]) {
|
||||
printf("FAILED!\n");
|
||||
fprintf(stderr, "ERROR at 0x%08x: Expected=0xff, Read=0x%02x\n",
|
||||
erasedbytes, buf[erasedbytes]);
|
||||
return 1;
|
||||
}
|
||||
printf("SUCCESS.\n");
|
||||
return 0;
|
||||
} else if (read_it) {
|
||||
if ((image = fopen(filename, "w")) == NULL) {
|
||||
perror(filename);
|
||||
exit(1);
|
||||
}
|
||||
printf("Reading flash... ");
|
||||
if (flash->read == NULL)
|
||||
memcpy(buf, (const char *)flash->virtual_memory, size);
|
||||
else
|
||||
flash->read(flash, buf);
|
||||
|
||||
if (exclude_end_position - exclude_start_position > 0)
|
||||
memset(buf + exclude_start_position, 0,
|
||||
exclude_end_position - exclude_start_position);
|
||||
|
||||
numbytes = fwrite(buf, 1, size, image);
|
||||
fclose(image);
|
||||
printf("%s.\n", numbytes == size ? "done" : "FAILED");
|
||||
if (numbytes != size)
|
||||
if (read_flash(flash, filename, exclude_start_position, exclude_end_position))
|
||||
return 1;
|
||||
} else {
|
||||
struct stat image_stat;
|
||||
|
|
Loading…
Reference in a new issue