Leancrypto 0.12.0
Post-Quantum Cryptographic Library
Loading...
Searching...
No Matches
lc_ascon_keccak.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 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_ASCON_KECCAK_H
21#define LC_ASCON_KECCAK_H
22
23#include "lc_ascon_aead.h"
24#include "lc_sha3.h"
25
26#ifdef __cplusplus
27extern "C" {
28#endif
29
31#define LC_AK_STATE_SIZE (LC_SHA3_STATE_SIZE + LC_ASCON_ALIGNMENT)
32#define LC_AK_CTX_SIZE(x) \
33 (sizeof(struct lc_aead) + sizeof(struct lc_ascon_cryptor) + \
34 LC_AK_STATE_SIZE)
36
48int lc_ak_alloc(const struct lc_hash *hash, struct lc_aead_ctx **ctx);
49
62int lc_ak_alloc_taglen(const struct lc_hash *hash, uint8_t taglen,
63 struct lc_aead_ctx **ctx);
64
75#define LC_AK_CTX_ON_STACK(name, hash) \
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, \
80 LC_AK_CTX_SIZE(hash), \
81 LC_ASCON_ALIGNMENT); \
82 struct lc_aead_ctx *name = (struct lc_aead_ctx *)name##_ctx_buf; \
83 LC_ASCON_SET_CTX(name, hash); \
84 struct lc_ascon_cryptor *__name_ascon_crypto = name->aead_state; \
85 __name_ascon_crypto->statesize = LC_SHA3_STATE_SIZE; \
86 __name_ascon_crypto->taglen = 16; \
87 _Pragma("GCC diagnostic pop")
88
100#define LC_AK_CTX_ON_STACK_TAGLEN(name, hash, tagsize) \
101 _Pragma("GCC diagnostic push") \
102 _Pragma("GCC diagnostic ignored \"-Wvla\"") _Pragma( \
103 "GCC diagnostic ignored \"-Wdeclaration-after-statement\"") \
104 LC_ALIGNED_BUFFER(name##_ctx_buf, \
105 LC_AK_CTX_SIZE(hash), \
106 LC_ASCON_ALIGNMENT); \
107 struct lc_aead_ctx *name = (struct lc_aead_ctx *)name##_ctx_buf; \
108 LC_ASCON_SET_CTX(name, hash); \
109 struct lc_ascon_cryptor *__name_ascon_crypto = name->aead_state; \
110 __name_ascon_crypto->statesize = LC_SHA3_STATE_SIZE; \
111 __name_ascon_crypto->taglen = tagsize; \
112 _Pragma("GCC diagnostic pop")
113
114#ifdef __cplusplus
115}
116#endif
117
118#endif /* LC_ASCON_KECCAK_H */
void lc_hash(const struct lc_hash *hash, const uint8_t *in, size_t inlen, uint8_t *digest)
Calculate message digest - one-shot.
int lc_ak_alloc(const struct lc_hash *hash, struct lc_aead_ctx **ctx)
Allocate Ascon Keccak cryptor context on heap.
int lc_ak_alloc_taglen(const struct lc_hash *hash, uint8_t taglen, struct lc_aead_ctx **ctx)
Allocate Ascon Keccak cryptor context on heap.