diff options
author | orivej <orivej@yandex-team.ru> | 2022-02-10 16:44:49 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:44:49 +0300 |
commit | 718c552901d703c502ccbefdfc3c9028d608b947 (patch) | |
tree | 46534a98bbefcd7b1f3faa5b52c138ab27db75b7 /contrib/restricted/aws/s2n/pq-crypto/bike_r1/sha.h | |
parent | e9656aae26e0358d5378e5b63dcac5c8dbe0e4d0 (diff) | |
download | ydb-718c552901d703c502ccbefdfc3c9028d608b947.tar.gz |
Restoring authorship annotation for <orivej@yandex-team.ru>. Commit 1 of 2.
Diffstat (limited to 'contrib/restricted/aws/s2n/pq-crypto/bike_r1/sha.h')
-rw-r--r-- | contrib/restricted/aws/s2n/pq-crypto/bike_r1/sha.h | 122 |
1 files changed, 61 insertions, 61 deletions
diff --git a/contrib/restricted/aws/s2n/pq-crypto/bike_r1/sha.h b/contrib/restricted/aws/s2n/pq-crypto/bike_r1/sha.h index a1cc55e04a..7005a03322 100644 --- a/contrib/restricted/aws/s2n/pq-crypto/bike_r1/sha.h +++ b/contrib/restricted/aws/s2n/pq-crypto/bike_r1/sha.h @@ -1,61 +1,61 @@ -/* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. - * SPDX-License-Identifier: Apache-2.0" - * - * Written by Nir Drucker and Shay Gueron - * AWS Cryptographic Algorithms Group. - * (ndrucker@amazon.com, gueron@amazon.com) - */ - -#pragma once - -#include "cleanup.h" -#include "types.h" -#include "utilities.h" -#include <openssl/sha.h> - -#define SHA384_HASH_SIZE 48ULL -#define SHA384_HASH_QWORDS (SHA384_HASH_SIZE / 8) - -typedef struct sha384_hash_s -{ - union { - uint8_t raw[SHA384_HASH_SIZE]; - uint64_t qw[SHA384_HASH_QWORDS]; - } u; -} sha384_hash_t; -bike_static_assert(sizeof(sha384_hash_t) == SHA384_HASH_SIZE, sha384_hash_size); - -typedef sha384_hash_t sha_hash_t; - -_INLINE_ void -sha_hash_cleanup(IN OUT sha_hash_t *o) -{ - secure_clean(o->u.raw, sizeof(*o)); -} - -#define NUM_OF_BLOCKS_IN_MB 4ULL -#define SLICE_REM 111ULL -#define MAX_MB_SLICES 8ULL -#define HASH_BLOCK_SIZE 128ULL - -_INLINE_ int -sha(OUT sha_hash_t *hash_out, IN const uint32_t byte_len, IN const uint8_t *msg) -{ - SHA384(msg, byte_len, hash_out->u.raw); - return 1; -} - -_INLINE_ void -sha_mb(OUT sha_hash_t *hash_out, - IN const uint8_t *msg, - IN const uint32_t byte_len, - IN const uint32_t num) -{ - const uint32_t ls = (byte_len / NUM_OF_BLOCKS_IN_MB); - - // Hash each block (X[i]) - for(uint32_t i = 0; i < num; i++) - { - SHA384(&msg[i * ls], ls, hash_out[i].u.raw); - } -} +/* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0" + * + * Written by Nir Drucker and Shay Gueron + * AWS Cryptographic Algorithms Group. + * (ndrucker@amazon.com, gueron@amazon.com) + */ + +#pragma once + +#include "cleanup.h" +#include "types.h" +#include "utilities.h" +#include <openssl/sha.h> + +#define SHA384_HASH_SIZE 48ULL +#define SHA384_HASH_QWORDS (SHA384_HASH_SIZE / 8) + +typedef struct sha384_hash_s +{ + union { + uint8_t raw[SHA384_HASH_SIZE]; + uint64_t qw[SHA384_HASH_QWORDS]; + } u; +} sha384_hash_t; +bike_static_assert(sizeof(sha384_hash_t) == SHA384_HASH_SIZE, sha384_hash_size); + +typedef sha384_hash_t sha_hash_t; + +_INLINE_ void +sha_hash_cleanup(IN OUT sha_hash_t *o) +{ + secure_clean(o->u.raw, sizeof(*o)); +} + +#define NUM_OF_BLOCKS_IN_MB 4ULL +#define SLICE_REM 111ULL +#define MAX_MB_SLICES 8ULL +#define HASH_BLOCK_SIZE 128ULL + +_INLINE_ int +sha(OUT sha_hash_t *hash_out, IN const uint32_t byte_len, IN const uint8_t *msg) +{ + SHA384(msg, byte_len, hash_out->u.raw); + return 1; +} + +_INLINE_ void +sha_mb(OUT sha_hash_t *hash_out, + IN const uint8_t *msg, + IN const uint32_t byte_len, + IN const uint32_t num) +{ + const uint32_t ls = (byte_len / NUM_OF_BLOCKS_IN_MB); + + // Hash each block (X[i]) + for(uint32_t i = 0; i < num; i++) + { + SHA384(&msg[i * ls], ls, hash_out[i].u.raw); + } +} |