diff options
author | Robert Relyea <rrelyea@redhat.com> | 2023-02-27 14:46:39 -0800 |
---|---|---|
committer | Robert Relyea <rrelyea@redhat.com> | 2023-02-27 14:46:39 -0800 |
commit | 9a7e1bc157adb261651fefb791901614460843a1 (patch) | |
tree | d35359ce38e48a2ffbb7247a8a5ad32e9e7e5ed2 /lib/liboqs/src/kem/kyber/pqcrystals-kyber_kyber512_ref/kem.h | |
parent | a0b5910d52112e6e32c5f54ad37533cde603feae (diff) | |
download | nss-hg-9a7e1bc157adb261651fefb791901614460843a1.tar.gz |
Add liboqs
Diffstat (limited to 'lib/liboqs/src/kem/kyber/pqcrystals-kyber_kyber512_ref/kem.h')
-rw-r--r-- | lib/liboqs/src/kem/kyber/pqcrystals-kyber_kyber512_ref/kem.h | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/lib/liboqs/src/kem/kyber/pqcrystals-kyber_kyber512_ref/kem.h b/lib/liboqs/src/kem/kyber/pqcrystals-kyber_kyber512_ref/kem.h new file mode 100644 index 000000000..3f3eff697 --- /dev/null +++ b/lib/liboqs/src/kem/kyber/pqcrystals-kyber_kyber512_ref/kem.h @@ -0,0 +1,41 @@ +#ifndef KEM_H +#define KEM_H + +#include <stdint.h> +#include "params.h" + +#define CRYPTO_SECRETKEYBYTES KYBER_SECRETKEYBYTES +#define CRYPTO_PUBLICKEYBYTES KYBER_PUBLICKEYBYTES +#define CRYPTO_CIPHERTEXTBYTES KYBER_CIPHERTEXTBYTES +#define CRYPTO_BYTES KYBER_SSBYTES + +#if (KYBER_K == 2) +#ifdef KYBER_90S +#define CRYPTO_ALGNAME "Kyber512-90s" +#else +#define CRYPTO_ALGNAME "Kyber512" +#endif +#elif (KYBER_K == 3) +#ifdef KYBER_90S +#define CRYPTO_ALGNAME "Kyber768-90s" +#else +#define CRYPTO_ALGNAME "Kyber768" +#endif +#elif (KYBER_K == 4) +#ifdef KYBER_90S +#define CRYPTO_ALGNAME "Kyber1024-90s" +#else +#define CRYPTO_ALGNAME "Kyber1024" +#endif +#endif + +#define crypto_kem_keypair KYBER_NAMESPACE(keypair) +int crypto_kem_keypair(uint8_t *pk, uint8_t *sk); + +#define crypto_kem_enc KYBER_NAMESPACE(enc) +int crypto_kem_enc(uint8_t *ct, uint8_t *ss, const uint8_t *pk); + +#define crypto_kem_dec KYBER_NAMESPACE(dec) +int crypto_kem_dec(uint8_t *ss, const uint8_t *ct, const uint8_t *sk); + +#endif |