diff options
author | Pali Rohár <pali.rohar@gmail.com> | 2012-06-23 13:07:34 +0200 |
---|---|---|
committer | Pali Rohár <pali.rohar@gmail.com> | 2012-06-23 13:07:34 +0200 |
commit | 8bc521f3e5e83fddc08a031aa7cf7499514ee732 (patch) | |
tree | 386753580f47d05c640e68b50b2120a2af48373e /src/hash.c | |
parent | b1cfc3181bc83b43e07f3b801166c8c8181cecf8 (diff) | |
download | 0xFFFF-8bc521f3e5e83fddc08a031aa7cf7499514ee732.tar.bz2 |
do_hash_file - align size for mmc images, append chars \xff (nokia flasher needs mmc images alingned)
Diffstat (limited to 'src/hash.c')
-rw-r--r-- | src/hash.c | 16 |
1 files changed, 15 insertions, 1 deletions
@@ -17,6 +17,7 @@ */ #include <stdio.h> +#include <string.h> #include "hash.h" usho do_hash(usho *b, int len) @@ -27,11 +28,12 @@ usho do_hash(usho *b, int len) return result; } -usho do_hash_file(const char *filename) +usho do_hash_file(const char *filename, const char *type) { unsigned char buf[BSIZE]; FILE *fd = fopen(filename, "r"); usho hash = 0; + int size; int ret; if (fd == NULL) { @@ -46,8 +48,20 @@ usho do_hash_file(const char *filename) hash ^= do_hash((usho *)&buf, ret); } while(ret); + size = ftell(fd); fclose(fd); + /* mmc image must be aligned */ + if (type && strcmp(type, "mmc") == 0) { + int align = ((size >> 8) + 1) << 8; + printf("align from %d to %d\n", size, align); + buf[0] = 0xff; + while (size < align) { + hash ^= do_hash((usho *)&buf, 1); + ++size; + } + } + return hash; } |