From 248d6a2e40fa1855f3b2d467acdc499ae1af5091 Mon Sep 17 00:00:00 2001 From: Mattias Andrée Date: Mon, 11 Feb 2019 19:05:34 +0100 Subject: Update for libkeccak 1.2 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mattias Andrée --- common.c | 44 ++++++++++++++++++++++---------------------- common.h | 12 ++++++------ 2 files changed, 28 insertions(+), 28 deletions(-) diff --git a/common.c b/common.c index b265697..26a8276 100644 --- a/common.c +++ b/common.c @@ -17,7 +17,7 @@ /** * Storage for binary hash */ -static char *restrict hashsum = NULL; +static void *restrict hashsum = NULL; /** * Storage for hexadecimal hash @@ -77,13 +77,13 @@ eperror(void) /** - * Convert `libkeccak_generalised_spec_t` to `libkeccak_spec_t` and check for errors + * Convert `struct libkeccak_generalised_spec` to `struct libkeccak_spec` and check for errors * * @param gspec See libkeccak_degeneralise_spec(3) * @param spec See libkeccak_degeneralise_spec(3) */ static void -make_spec(libkeccak_generalised_spec_t *restrict gspec, libkeccak_spec_t *restrict spec) +make_spec(struct libkeccak_generalised_spec *restrict gspec, struct libkeccak_spec *restrict spec) { #define case /* fall through */ case #define default /* fall through */ default @@ -142,15 +142,15 @@ make_spec(libkeccak_generalised_spec_t *restrict gspec, libkeccak_spec_t *restri * @return Zero on success, -1 on error */ static int -generalised_sum_fd_hex(int fd, libkeccak_state_t *restrict state, - const libkeccak_spec_t *restrict spec, - const char *restrict suffix, char *restrict hash) +generalised_sum_fd_hex(int fd, struct libkeccak_state *restrict state, + const struct libkeccak_spec *restrict spec, + const char *restrict suffix, void *restrict hash) { ssize_t got; struct stat attr; size_t blksize = 4096, r, w; - char *restrict chunk; - char even = 1, buf = 0, c; + unsigned char *restrict chunk; + unsigned char even = 1, buf = 0, c; if (libkeccak_state_initialise(state, spec) < 0) return -1; @@ -170,7 +170,7 @@ generalised_sum_fd_hex(int fd, libkeccak_state_t *restrict state, while (r < (size_t)got) { c = chunk[r++]; if (isxdigit(c)) { - buf = (buf << 4) | ((c & 15) + (c > '9' ? 9 : 0)); + buf = (unsigned char)((buf << 4) | ((c & 15) + (c > '9' ? 9 : 0))); if ((even ^= 1)) chunk[w++] = buf; } else if (!isspace(c)) { @@ -199,11 +199,11 @@ generalised_sum_fd_hex(int fd, libkeccak_state_t *restrict state, * @return An appropriate exit value */ static int -hash(const char *restrict filename, const libkeccak_spec_t *restrict spec, - long squeezes, const char *restrict suffix, int hex) +hash(const char *restrict filename, const struct libkeccak_spec *restrict spec, + long int squeezes, const char *restrict suffix, int hex) { static size_t length = 0; - libkeccak_state_t state; + struct libkeccak_state state; int fd; if (!length) { @@ -248,7 +248,7 @@ hash(const char *restrict filename, const libkeccak_spec_t *restrict spec, * @return An appropriate exit value */ static int -check(const libkeccak_spec_t *restrict spec, long squeezes, const char *restrict suffix, +check(const struct libkeccak_spec *restrict spec, long int squeezes, const char *restrict suffix, int hex, const char *restrict filename, const char *restrict correct_hash) { size_t length = (size_t)((spec->output + 7) / 8); @@ -281,8 +281,8 @@ check(const libkeccak_spec_t *restrict spec, long squeezes, const char *restrict * @return An appropriate exit value */ static int -check_checksums(const char *restrict filename, const libkeccak_spec_t *restrict spec, - long squeezes, const char *restrict suffix, enum representation style, int hex) +check_checksums(const char *restrict filename, const struct libkeccak_spec *restrict spec, + long int squeezes, const char *restrict suffix, enum representation style, int hex) { struct stat attr; size_t blksize = 4096; @@ -395,8 +395,8 @@ check_checksums(const char *restrict filename, const libkeccak_spec_t *restrict * @return An appropriate exit value */ static int -print_checksum(const char *restrict filename, const libkeccak_spec_t *restrict spec, - long squeezes, const char *restrict suffix, enum representation style, int hex) +print_checksum(const char *restrict filename, const struct libkeccak_spec *restrict spec, + long int squeezes, const char *restrict suffix, enum representation style, int hex) { size_t p = 0, n = (size_t)((spec->output + 7) / 8); ssize_t w; @@ -415,7 +415,7 @@ print_checksum(const char *restrict filename, const libkeccak_spec_t *restrict s } else { fflush(stdout); for (; p < n; p += (size_t)w) - if ((w = write(STDOUT_FILENO, &hashsum[p], n - p)) < 0) + if ((w = write(STDOUT_FILENO, &((unsigned char *)hashsum)[p], n - p)) < 0) eperror(); } @@ -433,16 +433,16 @@ print_checksum(const char *restrict filename, const libkeccak_spec_t *restrict s * @return An appropriate exit value */ int -run(int argc, char *argv[], libkeccak_generalised_spec_t *restrict gspec, const char *restrict suffix) +run(int argc, char *argv[], struct libkeccak_generalised_spec *restrict gspec, const char *restrict suffix) { enum representation style = REPRESENTATION_UPPER_CASE; int verbose = 0; int hex = 0; int check = 0; long int squeezes = 1; - int (*fun)(const char *restrict filename, const libkeccak_spec_t *restrict spec, - long squeezes, const char *restrict suffix, enum representation style, int hex); - libkeccak_spec_t spec; + int (*fun)(const char *restrict filename, const struct libkeccak_spec *restrict spec, + long int squeezes, const char *restrict suffix, enum representation style, int hex); + struct libkeccak_spec spec; int r = 0; ARGBEGIN { diff --git a/common.h b/common.h index d503811..f116035 100644 --- a/common.h +++ b/common.h @@ -4,19 +4,19 @@ #define COMMON_MAIN(CONFIGURATION, SUFFIX)\ int main(int argc, char *argv[]) {\ - libkeccak_generalised_spec_t spec;\ + struct libkeccak_generalised_spec spec;\ libkeccak_generalised_spec_initialise(&spec);\ CONFIGURATION;\ return run(argc, argv, &spec, SUFFIX);\ } #define KECCAK_MAIN(N)\ - COMMON_MAIN(libkeccak_spec_sha3((libkeccak_spec_t *)&spec, N), "") + COMMON_MAIN(libkeccak_spec_sha3((struct libkeccak_spec *)&spec, N), "") #define SHA3_MAIN(N)\ - COMMON_MAIN(libkeccak_spec_sha3((libkeccak_spec_t *)&spec, N), LIBKECCAK_SHA3_SUFFIX) + COMMON_MAIN(libkeccak_spec_sha3((struct libkeccak_spec *)&spec, N), LIBKECCAK_SHA3_SUFFIX) #define RAWSHAKE_MAIN(N)\ - COMMON_MAIN(libkeccak_spec_rawshake((libkeccak_spec_t *)&spec, N, N), LIBKECCAK_RAWSHAKE_SUFFIX) + COMMON_MAIN(libkeccak_spec_rawshake((struct libkeccak_spec *)&spec, N, N), LIBKECCAK_RAWSHAKE_SUFFIX) #define SHAKE_MAIN(N)\ - COMMON_MAIN(libkeccak_spec_shake((libkeccak_spec_t *)&spec, N, N), LIBKECCAK_SHAKE_SUFFIX) + COMMON_MAIN(libkeccak_spec_shake((struct libkeccak_spec *)&spec, N, N), LIBKECCAK_SHAKE_SUFFIX) /** @@ -49,4 +49,4 @@ enum representation { * @param suffix Message suffix * @return An appropriate exit value */ -int run(int argc, char *argv[], libkeccak_generalised_spec_t *restrict gspec, const char *restrict suffix); +int run(int argc, char *argv[], struct libkeccak_generalised_spec *restrict gspec, const char *restrict suffix); -- cgit v1.2.3-70-g09d2