crypto/fipsmodule/ml_kem/fips202_glue.h (38 lines of code) (raw):
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0 OR ISC
#ifndef MLK_AWSLC_FIPS202_GLUE_H
#define MLK_AWSLC_FIPS202_GLUE_H
#include <stddef.h>
#include <stdint.h>
#include "../sha/internal.h"
#define SHAKE128_RATE 168
#define SHAKE256_RATE 136
#define SHA3_256_RATE 136
#define SHA3_384_RATE 104
#define SHA3_512_RATE 72
#define mlk_shake128ctx KECCAK1600_CTX
static MLK_INLINE void mlk_shake128_init(mlk_shake128ctx *state) {
// Return code checks can be omitted
// SHAKE_Init always returns 1 when called with correct block size value.
(void) SHAKE_Init(state, SHAKE128_BLOCKSIZE);
}
static MLK_INLINE void mlk_shake128_release(mlk_shake128ctx *state) {
(void) state;
}
static MLK_INLINE void mlk_shake128_absorb_once(mlk_shake128ctx *state,
const uint8_t *input, size_t inlen) {
// Return code check can be omitted
// since mlkem-native adheres to call discipline
(void) SHAKE_Absorb(state, input, inlen);
}
static MLK_INLINE void mlk_shake128_squeezeblocks(uint8_t *output, size_t nblocks,
mlk_shake128ctx *state) {
// Return code check can be omitted
// since mlkem-native adheres to call discipline
(void) SHAKE_Squeeze(output, state, nblocks * SHAKE128_RATE);
}
static MLK_INLINE void mlk_shake256(uint8_t *output, size_t outlen,
const uint8_t *input, size_t inlen) {
// Return code check can be omitted
// since mlkem-native adheres to call discipline
(void) SHAKE256(input, inlen, output, outlen);
}
static MLK_INLINE void mlk_sha3_256(uint8_t *output, const uint8_t *input,
size_t inlen) {
// Return code check can be omitted
// since mlkem-native adheres to call discipline
(void) SHA3_256(input, inlen, output);
}
static MLK_INLINE void mlk_sha3_512(uint8_t *output, const uint8_t *input,
size_t inlen) {
// Return code check can be omitted
// since mlkem-native adheres to call discipline
(void) SHA3_512(input, inlen, output);
}
#endif // MLK_AWSLC_FIPS202_GLUE_H