Leancrypto 1.6.0
Post-Quantum Cryptographic Library
Loading...
Searching...
No Matches
lc_sha512.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2020 - 2025, Stephan Mueller <smueller@chronox.de>
3 *
4 * License: see LICENSE file in root directory
5 *
6 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
7 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
8 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ALL OF
9 * WHICH ARE HEREBY DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
10 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
11 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
12 * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
13 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
14 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
15 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
16 * USE OF THIS SOFTWARE, EVEN IF NOT ADVISED OF THE POSSIBILITY OF SUCH
17 * DAMAGE.
18 */
19
20#ifndef LC_SHA512_H
21#define LC_SHA512_H
22
23#include "lc_hash.h"
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
33extern const struct lc_hash *lc_sha384;
34
39extern const struct lc_hash *lc_sha512;
40
42#define LC_SHA512_SIZE_BLOCK 128
43#define LC_SHA512_SIZE_DIGEST 64
44#define LC_SHA512_STATE_WORDS 8
45
46struct lc_sha512_state {
47 uint64_t H[LC_SHA512_STATE_WORDS];
48 size_t msg_len;
49 uint8_t partial[LC_SHA512_SIZE_BLOCK];
50};
51
52#define LC_SHA512_STATE_SIZE (sizeof(struct lc_sha512_state))
53#define LC_SHA512_CTX_SIZE (sizeof(struct lc_hash) + LC_SHA512_STATE_SIZE)
54
55#define LC_SHA512_CTX(name) \
56 LC_HASH_SET_CTX(name, lc_sha512); \
57 lc_hash_zero(name)
58
59#define LC_SHA384_SIZE_BLOCK 128
60#define LC_SHA384_SIZE_DIGEST 48
61
62#define LC_SHA384_STATE_SIZE LC_SHA512_STATE_SIZE
63#define LC_SHA384_CTX_SIZE LC_SHA512_CTX_SIZE
64
65#define LC_SHA384_CTX(name) \
66 LC_HASH_SET_CTX(name, lc_sha384); \
67 lc_hash_zero(name)
69
75#define LC_SHA384_CTX_ON_STACK(name) \
76 _Pragma("GCC diagnostic push") \
77 _Pragma("GCC diagnostic ignored \"-Wvla\"") _Pragma( \
78 "GCC diagnostic ignored \"-Wdeclaration-after-statement\"") \
79 LC_ALIGNED_BUFFER(name##_ctx_buf, LC_SHA384_CTX_SIZE, \
80 LC_HASH_COMMON_ALIGNMENT); \
81 struct lc_hash_ctx *name = (struct lc_hash_ctx *)name##_ctx_buf; \
82 LC_SHA384_CTX(name); \
83 _Pragma("GCC diagnostic pop")
84
90#define LC_SHA512_CTX_ON_STACK(name) \
91 _Pragma("GCC diagnostic push") \
92 _Pragma("GCC diagnostic ignored \"-Wvla\"") _Pragma( \
93 "GCC diagnostic ignored \"-Wdeclaration-after-statement\"") \
94 LC_ALIGNED_BUFFER(name##_ctx_buf, LC_SHA512_CTX_SIZE, \
95 LC_HASH_COMMON_ALIGNMENT); \
96 struct lc_hash_ctx *name = (struct lc_hash_ctx *)name##_ctx_buf; \
97 LC_SHA512_CTX(name); \
98 _Pragma("GCC diagnostic pop")
99
100#ifdef __cplusplus
101}
102#endif
103
104#endif /* LC_SHA512_H */
int lc_hash(const struct lc_hash *hash, const uint8_t *in, size_t inlen, uint8_t *digest)
Calculate message digest - one-shot.
const struct lc_hash * lc_sha512
SHA2-512 algorithm reference.
const struct lc_hash * lc_sha384
SHA2-384 algorithm reference.