20#ifndef LC_ASCON_KECCAK_H
21#define LC_ASCON_KECCAK_H
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) + \
70 struct lc_aead_ctx **ctx);
82#define LC_AK_CTX_ON_STACK(name, hash) \
83 _Pragma("GCC diagnostic push") \
84 _Pragma("GCC diagnostic ignored \"-Wvla\"") _Pragma( \
85 "GCC diagnostic ignored \"-Wdeclaration-after-statement\"") \
86 LC_ALIGNED_BUFFER(name##_ctx_buf, \
87 LC_AK_CTX_SIZE(hash), \
88 LC_ASCON_ALIGNMENT); \
89 struct lc_aead_ctx *name = (struct lc_aead_ctx *)name##_ctx_buf; \
90 LC_ASCON_SET_CTX(name, hash, lc_ascon_keccak_aead); \
91 struct lc_ascon_cryptor *__name_ascon_crypto = name->aead_state; \
92 __name_ascon_crypto->statesize = LC_SHA3_STATE_SIZE; \
93 __name_ascon_crypto->taglen = 16; \
94 _Pragma("GCC diagnostic pop")
107#define LC_AK_CTX_ON_STACK_TAGLEN(name, hash, tagsize) \
108 _Pragma("GCC diagnostic push") \
109 _Pragma("GCC diagnostic ignored \"-Wvla\"") _Pragma( \
110 "GCC diagnostic ignored \"-Wdeclaration-after-statement\"") \
111 LC_ALIGNED_BUFFER(name##_ctx_buf, \
112 LC_AK_CTX_SIZE(hash), \
113 LC_ASCON_ALIGNMENT); \
114 struct lc_aead_ctx *name = (struct lc_aead_ctx *)name##_ctx_buf; \
115 LC_ASCON_SET_CTX(name, hash, lc_ascon_keccak_aead); \
116 struct lc_ascon_cryptor *__name_ascon_crypto = name->aead_state; \
117 __name_ascon_crypto->statesize = LC_SHA3_STATE_SIZE; \
118 __name_ascon_crypto->taglen = tagsize; \
119 _Pragma("GCC diagnostic pop")
int 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.
const struct lc_aead * lc_ascon_keccak_aead