diff options
author | Felix Fietkau <nbd@openwrt.org> | 2006-10-23 14:52:04 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2006-10-23 14:52:04 +0000 |
commit | 34f202b0eca8e359a673ed1c8ac793a941f4870b (patch) | |
tree | 51a5505a4bea4f87973b84cad4f324b02dea261d /package | |
parent | a2befd586f4e57fce9cd996853fd1e06d19f5991 (diff) | |
download | upstream-34f202b0eca8e359a673ed1c8ac793a941f4870b.tar.gz upstream-34f202b0eca8e359a673ed1c8ac793a941f4870b.tar.bz2 upstream-34f202b0eca8e359a673ed1c8ac793a941f4870b.zip |
improve mtd image check - don't check trx header if the target partition is not 'linux', don't display image check messages with -qq and -f, fixes #850
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@5269 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package')
-rw-r--r-- | package/mtd/src/mtd.c | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/package/mtd/src/mtd.c b/package/mtd/src/mtd.c index 23e99160a1..1e9d316e4c 100644 --- a/package/mtd/src/mtd.c +++ b/package/mtd/src/mtd.c @@ -62,6 +62,7 @@ struct trx_header { char buf[BUFSIZE]; int buflen; +int quiet; int image_check_bcom(int imagefd, const char *mtd) @@ -70,6 +71,9 @@ image_check_bcom(int imagefd, const char *mtd) struct mtd_info_user mtdInfo; int fd; + if (strcmp(mtd, "linux") != 0) + return 1; + buflen = read(imagefd, buf, 32); if (buflen < 32) { fprintf(stdout, "Could not get image header, file too small (%ld bytes)\n", buflen); @@ -88,10 +92,11 @@ image_check_bcom(int imagefd, const char *mtd) } if (trx->magic != TRX_MAGIC || trx->len < sizeof(struct trx_header)) { - fprintf(stderr, "Bad trx header\n"); - fprintf(stderr, "If this is a firmware in bin format, like some of the\n" - "original firmware files are, use following command to convert to trx:\n" - "dd if=firmware.bin of=firmware.trx bs=32 skip=1\n"); + if (quiet < 2) { + fprintf(stderr, "Bad trx header\n"); + fprintf(stderr, "If this is a firmware in bin format, like some of the\n" + "original firmware files are, you need to convert it to trx.\n"); + } return 0; } @@ -255,7 +260,7 @@ mtd_erase(const char *mtd) } int -mtd_write(int imagefd, const char *mtd, int quiet) +mtd_write(int imagefd, const char *mtd) { int fd, i, result; size_t r, w, e; @@ -346,7 +351,7 @@ void usage(void) int main (int argc, char **argv) { - int ch, i, boot, unlock, imagefd, force, quiet, unlocked; + int ch, i, boot, unlock, imagefd, force, unlocked; char *erase[MAX_ARGS], *device, *imagefile; enum { CMD_ERASE, @@ -413,10 +418,10 @@ int main (int argc, char **argv) /* check trx file before erasing or writing anything */ if (!image_check(imagefd, device)) { - if ((quiet < 2) || !force) - fprintf(stderr, "TRX check failed!\n"); - if (!force) + if (!force) { + fprintf(stderr, "Image check failed.\n"); exit(1); + } } else { if (!mtd_check(device)) { fprintf(stderr, "Can't open device for writing!\n"); @@ -460,7 +465,7 @@ int main (int argc, char **argv) case CMD_WRITE: if (quiet < 2) fprintf(stderr, "Writing from %s to %s ... ", imagefile, device); - mtd_write(imagefd, device, quiet); + mtd_write(imagefd, device); if (quiet < 2) fprintf(stderr, "\n"); break; |