X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=board%2Fnetstar%2Fcrcit.c;h=a16264914cbbc5f5a2065daa22c50a5c31bbd6a2;hb=54841ab50c20d6fa6c9cc3eb826989da3a22d934;hp=f6d3066c158294f68f39955e4f9b12300a22daed;hpb=795bee849603c7c2994ba20fcd96f3f9835ffd96;p=oweals%2Fu-boot.git diff --git a/board/netstar/crcit.c b/board/netstar/crcit.c index f6d3066c15..a16264914c 100644 --- a/board/netstar/crcit.c +++ b/board/netstar/crcit.c @@ -31,11 +31,11 @@ #include #include "crcek.h" -extern unsigned long crc32(unsigned long, const unsigned char *, unsigned int); +extern uint32_t crc32(uint32_t, const unsigned char *, uint); -uint32_t data[LOADER_SIZE/4 + 3]; +static uint32_t data[LOADER_SIZE/4 + 3]; -int doit(char *path, unsigned version) +static int do_crc(char *path, unsigned version) { uint32_t *p; ssize_t size; @@ -56,13 +56,14 @@ int doit(char *path, unsigned version) fprintf(stderr, "File too large\n"); return EXIT_FAILURE; } - size = (((size - 1) >> 2) + 1) << 2; - data[0] = size + 4; /* add size of version field */ + size = (size + 3) & ~3; /* round up to 4 bytes */ + size += 4; /* add size of version field */ + data[0] = size; data[1] = version; - data[(size >> 2) + 2] = crc32(0, (unsigned char *)(data + 1), data[0]); + data[size/4 + 1] = crc32(0, (unsigned char *)(data + 1), size); close(fd); - if (write(STDOUT_FILENO, data, size + 3*4) == -1) { + if (write(STDOUT_FILENO, data, size + 4 /*size*/ + 4 /*crc*/) == -1) { perror("Error writing file"); return EXIT_FAILURE; } @@ -70,15 +71,15 @@ int doit(char *path, unsigned version) return EXIT_SUCCESS; } -int main(int argc, char **argv) +int main(int argc, char * const *argv) { if (argc == 2) { - return doit(argv[1], 0); + return do_crc(argv[1], 0); } else if ((argc == 4) && (strcmp(argv[1], "-v") == 0)) { char *endptr, *nptr = argv[2]; unsigned ver = strtoul(nptr, &endptr, 0); - if (nptr != '\0' && endptr == '\0') - return doit(argv[3], ver); + if (*nptr != '\0' && *endptr == '\0') + return do_crc(argv[3], ver); } fprintf(stderr, "Usage: crcit [-v version] \n");