kyber512r3_polyvec_avx2.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. #pragma once
  2. #include <stdint.h>
  3. #include "kyber512r3_params.h"
  4. #include "kyber512r3_poly_avx2.h"
  5. #if defined(S2N_KYBER512R3_AVX2_BMI2)
  6. #define polyvec S2N_KYBER_512_R3_NAMESPACE(polyvec)
  7. typedef struct{
  8. poly vec[S2N_KYBER_512_R3_K];
  9. } polyvec;
  10. #define polyvec_compress_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_compress_avx2)
  11. void polyvec_compress_avx2(uint8_t r[S2N_KYBER_512_R3_POLYVECCOMPRESSEDBYTES+2], const polyvec *a);
  12. #define polyvec_decompress_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_decompress_avx2)
  13. void polyvec_decompress_avx2(polyvec *r, const uint8_t a[S2N_KYBER_512_R3_POLYVECCOMPRESSEDBYTES+12]);
  14. #define polyvec_tobytes_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_tobytes_avx2)
  15. void polyvec_tobytes_avx2(uint8_t r[S2N_KYBER_512_R3_POLYVECBYTES], const polyvec *a);
  16. #define polyvec_frombytes_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_frombytes_avx2)
  17. void polyvec_frombytes_avx2(polyvec *r, const uint8_t a[S2N_KYBER_512_R3_POLYVECBYTES]);
  18. #define polyvec_ntt_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_ntt_avx2)
  19. void polyvec_ntt_avx2(polyvec *r);
  20. #define polyvec_invntt_tomont_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_invntt_tomont_avx2)
  21. void polyvec_invntt_tomont_avx2(polyvec *r);
  22. #define polyvec_basemul_acc_montgomery_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_basemul_acc_montgomery_avx2)
  23. void polyvec_basemul_acc_montgomery_avx2(poly *r, const polyvec *a, const polyvec *b);
  24. #define polyvec_reduce_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_reduce_avx2)
  25. void polyvec_reduce_avx2(polyvec *r);
  26. #define polyvec_add_avx2 S2N_KYBER_512_R3_NAMESPACE(polyvec_add_avx2)
  27. void polyvec_add_avx2(polyvec *r, const polyvec *a, const polyvec *b);
  28. #endif