From 72111e7a53eaad7bea841ab8b09e70642bde00ae Mon Sep 17 00:00:00 2001 From: Mattias Andrée Date: Sat, 24 Aug 2024 18:02:00 +0200 Subject: Add support for Keccak, SHA3, SHAKE, and RawSHAKE via libkeccak>=1.3 (this version introduced zerocopy) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mattias Andrée --- libhashsum_init_rawshake_hasher.c | 52 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 libhashsum_init_rawshake_hasher.c (limited to 'libhashsum_init_rawshake_hasher.c') diff --git a/libhashsum_init_rawshake_hasher.c b/libhashsum_init_rawshake_hasher.c new file mode 100644 index 0000000..f90e3b7 --- /dev/null +++ b/libhashsum_init_rawshake_hasher.c @@ -0,0 +1,52 @@ +/* See LICENSE file for copyright and license details. */ +#include "common.h" +#ifdef SUPPORT_RAWSHAKE + + +int +libhashsum_init_rawshake_hasher(struct libhashsum_hasher *this, size_t hcapbits, size_t hashbits) +{ + struct libkeccak_spec spec; + + if (hcapbits == 128U) { + this->algorithm = LIBHASHSUM_RAWSHAKE128; + this->algorithm_string = "RawSHAKE128"; + } else if (hcapbits == 256U) { + this->algorithm = LIBHASHSUM_RAWSHAKE256; + this->algorithm_string = "RawSHAKE256"; + } else if (hcapbits == 512U) { + this->algorithm = LIBHASHSUM_RAWSHAKE512; + this->algorithm_string = "RawSHAKE512"; + } else { + errno = EINVAL; + return -1; + } + + if (hashbits == 0U) { + hashbits = hcapbits; + } else if (hashbits > (size_t)LONG_MAX) { + errno = EINVAL; + return -1; + } + + if (hashbits != hcapbits) { + sprintf(this->state.keccak.algostr, "%s[n=%zu]", this->algorithm_string, hashbits); + this->algorithm_string = this->state.keccak.algostr; + } + + libkeccak_spec_rawshake(&spec, (long int)hcapbits, (long int)hashbits); + return libhashsum_init_keccak__(this, hashbits, &spec, LIBKECCAK_RAWSHAKE_SUFFIX); +} + + +#else +int +libhashsum_init_rawshake_hasher(struct libhashsum_hasher *this, size_t hcapbits, size_t hashbits) +{ + (void) this; + (void) hcapbits; + (void) hashbits; + errno = ENOSYS; + return -1; +} +#endif -- cgit v1.2.3-70-g09d2