Leancrypto
0.12.0
Post-Quantum Cryptographic Library
Loading...
Searching...
No Matches
hash
api
lc_sha256.h
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2020 - 2024, 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_SHA256_H
21
#define LC_SHA256_H
22
23
#include "
lc_hash.h
"
24
25
#ifdef __cplusplus
26
extern
"C"
{
27
#endif
28
33
extern
const
struct
lc_hash
*
lc_sha256
;
34
36
#define LC_SHA256_SIZE_BLOCK 64
37
#define LC_SHA256_SIZE_DIGEST 32
38
39
struct
lc_sha256_state {
40
uint32_t H[8];
41
size_t
msg_len;
42
uint8_t partial[LC_SHA256_SIZE_BLOCK];
43
};
44
45
#define LC_SHA256_STATE_SIZE (sizeof(struct lc_sha256_state))
46
#define LC_SHA256_CTX_SIZE (sizeof(struct lc_hash) + LC_SHA256_STATE_SIZE)
47
48
#define LC_SHA256_CTX(name) \
49
LC_HASH_SET_CTX(name, lc_sha256); \
50
lc_hash_zero(name)
52
58
#define LC_SHA256_CTX_ON_STACK(name) \
59
_Pragma("GCC diagnostic push") \
60
_Pragma("GCC diagnostic ignored \"-Wvla\"") _Pragma( \
61
"GCC diagnostic ignored \"-Wdeclaration-after-statement\"") \
62
LC_ALIGNED_BUFFER(name##_ctx_buf, LC_SHA256_CTX_SIZE, \
63
LC_HASH_COMMON_ALIGNMENT); \
64
struct lc_hash_ctx *name = (struct lc_hash_ctx *)name##_ctx_buf; \
65
LC_SHA256_CTX(name); \
66
_Pragma("GCC diagnostic pop")
67
68
#ifdef __cplusplus
69
}
70
#endif
71
72
#endif
/* LC_SHA256_H */
lc_hash
void lc_hash(const struct lc_hash *hash, const uint8_t *in, size_t inlen, uint8_t *digest)
Calculate message digest - one-shot.
lc_hash.h
lc_sha256
const struct lc_hash * lc_sha256
SHA2-256 algorithm reference.
Generated by
1.11.0