mirror of
https://review.coreboot.org/flashrom.git
synced 2025-07-01 14:11:15 +02:00
Only write the flash if the image has the same size
Corresponding to flashrom svn r76 and coreboot v2 svn r2503. Signed-off-by: Stefan Reinauer <stepan@coresystems.de> Acked-by: Segher Boessenkool <segher@kernel.crashing.org>
This commit is contained in:

committed by
Stefan Reinauer

parent
566820d7f6
commit
018aca8dcc
13
flash_rom.c
13
flash_rom.c
@ -28,6 +28,8 @@
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
#include <sys/mman.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <unistd.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
@ -332,10 +334,21 @@ int main(int argc, char *argv[])
|
||||
fclose(image);
|
||||
printf("done\n");
|
||||
} else {
|
||||
struct stat image_stat;
|
||||
|
||||
if ((image = fopen(filename, "r")) == NULL) {
|
||||
perror(filename);
|
||||
exit(1);
|
||||
}
|
||||
if (fstat(fileno(image), &image_stat) != 0) {
|
||||
perror(filename);
|
||||
exit(1);
|
||||
}
|
||||
if(image_stat.st_size!=flash->total_size*1024) {
|
||||
perror("Image size doesnt match");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
fread(buf, sizeof(char), size, image);
|
||||
show_id(buf, size);
|
||||
fclose(image);
|
||||
|
Reference in New Issue
Block a user