diff options
author | pancake <pancake@dazo> | 2007-05-25 00:33:58 +0200 |
---|---|---|
committer | pancake <pancake@dazo> | 2007-05-25 00:33:58 +0200 |
commit | 1515b7c7c12097db8c713194217d57477074c6ac (patch) | |
tree | 20b6bf64c73293eaa7417aae8894ae0c7e1f062c /src/flash.c | |
parent | ed37b5ee621a8c90ff08cb63038c6799642748fd (diff) | |
download | 0xFFFF-1515b7c7c12097db8c713194217d57477074c6ac.tar.bz2 |
* Fix rootfs boundaries for a proper dump.
* Replace Y/n for y/N
* Implement the command '5' (read error message)
Diffstat (limited to 'src/flash.c')
-rw-r--r-- | src/flash.c | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/src/flash.c b/src/flash.c index 7a8ddd1..c81d97c 100644 --- a/src/flash.c +++ b/src/flash.c @@ -123,8 +123,33 @@ void flash_image(char *filename, char *piece, char *version) if (bread != 1) printf("WARNING: Oops wrong read %d vs %d \n", bread, bsize); bread = usb_bulk_write(dev, 2, buf, bsize, 5000); + if (bread == 64) { + /* query error message */ + int len = 0; + char nolomsg[2048]; + memset(nolomsg, '\0', 2048); + usb_control_msg(dev, 192, 5, 0, 0, nolomsg, 2048, 2000); + nolomsg[2047] = '\0'; + printf("\nNOLO says:\n"); + if (nolomsg[0] == '\0') { + printf(" (.. silence ..)\n"); + } else { + dump_bytes(nolomsg, 128); + do { + printf(" - %s\n", nolomsg+len); + len+=strlen(nolomsg+len)+1; + } while(nolomsg[len]!='\0'); + } + fclose(fd); + return; + } progressbar(off, size); - if (bread<0) perror(" -ee- "); + if (bread<0) { + printf("\n"); + perror(" -ee- "); + fclose(fd); + return; + } fflush(stdout); } fclose(fd); |