2019-04-16 14:15:03 +01:00
|
|
|
#ifndef SPX_HASH_H
|
|
|
|
#define SPX_HASH_H
|
|
|
|
|
2019-06-21 13:34:36 +01:00
|
|
|
#include "primitive.h"
|
|
|
|
|
|
|
|
#include <stddef.h>
|
2019-04-16 14:15:03 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
void PQCLEAN_SPHINCSSHAKE256256FSIMPLE_CLEAN_initialize_hash_function(
|
2019-06-21 13:34:36 +01:00
|
|
|
hash_state *state_seeded,
|
2019-04-16 14:15:03 +01:00
|
|
|
const unsigned char *pub_seed, const unsigned char *sk_seed);
|
|
|
|
|
|
|
|
void PQCLEAN_SPHINCSSHAKE256256FSIMPLE_CLEAN_prf_addr(
|
2019-06-21 13:34:36 +01:00
|
|
|
unsigned char *out, const unsigned char *key, const uint32_t addr[8],
|
|
|
|
const hash_state *state_seeded);
|
2019-04-16 14:15:03 +01:00
|
|
|
|
|
|
|
void PQCLEAN_SPHINCSSHAKE256256FSIMPLE_CLEAN_gen_message_random(
|
|
|
|
unsigned char *R,
|
|
|
|
const unsigned char *sk_prf, const unsigned char *optrand,
|
2019-06-21 13:34:36 +01:00
|
|
|
const unsigned char *m, size_t mlen,
|
|
|
|
const hash_state *state_seeded);
|
2019-04-16 14:15:03 +01:00
|
|
|
|
|
|
|
void PQCLEAN_SPHINCSSHAKE256256FSIMPLE_CLEAN_hash_message(
|
|
|
|
unsigned char *digest, uint64_t *tree, uint32_t *leaf_idx,
|
|
|
|
const unsigned char *R, const unsigned char *pk,
|
2019-06-21 13:34:36 +01:00
|
|
|
const unsigned char *m, size_t mlen,
|
|
|
|
const hash_state *state_seeded);
|
2019-04-16 14:15:03 +01:00
|
|
|
|
|
|
|
#endif
|