diff options
| author | Mattias Andrée <maandree@kth.se> | 2024-09-04 19:41:56 +0200 | 
|---|---|---|
| committer | Mattias Andrée <maandree@kth.se> | 2024-09-04 19:41:56 +0200 | 
| commit | cda19b080eee1c8057ebcb4369455582949ed20e (patch) | |
| tree | 39d4ff4a5efaac08207ca33606fa01877b404927 /libhashsum | |
| parent | tests: check .supports_non_whole_bytes (diff) | |
| download | libhashsum-cda19b080eee1c8057ebcb4369455582949ed20e.tar.gz libhashsum-cda19b080eee1c8057ebcb4369455582949ed20e.tar.bz2 libhashsum-cda19b080eee1c8057ebcb4369455582949ed20e.tar.xz | |
Fix and test BLAKE2 support
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to '')
| -rw-r--r-- | libhashsum_init_blake2b_hasher.c | 17 | ||||
| -rw-r--r-- | libhashsum_init_blake2s_hasher.c | 10 | 
2 files changed, 15 insertions, 12 deletions
| diff --git a/libhashsum_init_blake2b_hasher.c b/libhashsum_init_blake2b_hasher.c index 57be6fe..06504d3 100644 --- a/libhashsum_init_blake2b_hasher.c +++ b/libhashsum_init_blake2b_hasher.c @@ -69,7 +69,7 @@ finalise(struct libhashsum_hasher *this, void *data, size_t bytes, unsigned extr  	size -= r;  	if (!this->hash_output) -		this->hash_output = this->state.blake224.buf; +		this->hash_output = this->state.blake2b.buf;  	if (this->state.blake2b.keybytes) {  		bytes = BLAKE2B_BLOCK_SIZE; @@ -92,16 +92,15 @@ __attribute__((__pure__))  static int  allzeroes(const uint8_t *data, size_t n)  { -	if (data) -		while (n--) -			if (data[n]) -				return 0; +	while (n--) +		if (data[n]) +			return 0;  	return 1;  }  static char * -hex(char *buf, const uint8_t *data, size_t n) +hex(char *restrict buf, const uint8_t *restrict data, size_t n)  {  	size_t i;  	for (i = 0; i < n; i++) { @@ -151,12 +150,14 @@ libhashsum_init_blake2b_hasher(struct libhashsum_hasher *this, size_t hashbits,  		.node_depth = 0U,  		.inner_len = 0U  	}; -	if (((hashbits | keybits) & 7U) || ((hashbits | keybits) > 256U)) { +	if (((hashbits | keybits) & 7U) || hashbits > 512U || keybits > 512U) {  		errno = EINVAL;  		return -1;  	} -	if (!hashbits) +	if (!hashbits) {  		hashbits = 512U; +		params.digest_len = (unsigned char)(hashbits / 8U); +	}  	libblake_init();  	this->algorithm = LIBHASHSUM_BLAKE2B;  	this->algorithm_string = mkalgostr(this->state.blake2b.algostr, "BLAKE2b", diff --git a/libhashsum_init_blake2s_hasher.c b/libhashsum_init_blake2s_hasher.c index 0957b22..689dc64 100644 --- a/libhashsum_init_blake2s_hasher.c +++ b/libhashsum_init_blake2s_hasher.c @@ -69,7 +69,7 @@ finalise(struct libhashsum_hasher *this, void *data, size_t bytes, unsigned extr  	size -= r;  	if (!this->hash_output) -		this->hash_output = this->state.blake224.buf; +		this->hash_output = this->state.blake2s.buf;  	if (this->state.blake2s.keybytes) {  		bytes = BLAKE2S_BLOCK_SIZE; @@ -100,7 +100,7 @@ allzeroes(const uint8_t *data, size_t n)  static char * -hex(char *buf, const uint8_t *data, size_t n) +hex(char *restrict buf, const uint8_t *restrict data, size_t n)  {  	size_t i;  	for (i = 0; i < n; i++) { @@ -150,12 +150,14 @@ libhashsum_init_blake2s_hasher(struct libhashsum_hasher *this, size_t hashbits,  		.node_depth = 0U,  		.inner_len = 0U  	}; -	if (((hashbits | keybits) & 7U) || ((hashbits | keybits) > 256U)) { +	if (((hashbits | keybits) & 7U) || hashbits > 256U || keybits > 256U) {  		errno = EINVAL;  		return -1;  	} -	if (!hashbits) +	if (!hashbits) {  		hashbits = 256U; +		params.digest_len = (unsigned char)(hashbits / 8U); +	}  	libblake_init();  	this->algorithm = LIBHASHSUM_BLAKE2S;  	this->algorithm_string = mkalgostr(this->state.blake2s.algostr, "BLAKE2s", | 
