#include "cbd.h" #include "fips202.h" #include "pack_unpack.h" #include "poly.h" void PQCLEAN_FIRESABER_AVX2_MatrixVectorMul(poly c[SABER_L], const poly A[SABER_L][SABER_L], const toom4_points s_eval[SABER_L], int transpose) { size_t i, j; toom4_points_product c_eval; if (transpose) { for (i = 0; i < SABER_L; i++) { PQCLEAN_FIRESABER_AVX2_toom4_mul_A_by_B_eval(&c_eval, &A[0][i], &s_eval[0], 0); for (j = 1; j < SABER_L; j++) { PQCLEAN_FIRESABER_AVX2_toom4_mul_A_by_B_eval(&c_eval, &A[j][i], &s_eval[j], 1); } PQCLEAN_FIRESABER_AVX2_toom4_interp(&c[i], &c_eval); } } else { for (i = 0; i < SABER_L; i++) { PQCLEAN_FIRESABER_AVX2_toom4_mul_A_by_B_eval(&c_eval, &A[i][0], &s_eval[0], 0); for (j = 1; j < SABER_L; j++) { PQCLEAN_FIRESABER_AVX2_toom4_mul_A_by_B_eval(&c_eval, &A[i][j], &s_eval[j], 1); } PQCLEAN_FIRESABER_AVX2_toom4_interp(&c[i], &c_eval); } } } void PQCLEAN_FIRESABER_AVX2_InnerProd(poly *c, const poly b[SABER_L], const toom4_points s_eval[SABER_L]) { size_t i; toom4_points_product c_eval; //Holds results for 9 Karatsuba at a time PQCLEAN_FIRESABER_AVX2_toom4_mul_A_by_B_eval(&c_eval, &b[0], &s_eval[0], 0); for (i = 1; i < SABER_L; i++) { PQCLEAN_FIRESABER_AVX2_toom4_mul_A_by_B_eval(&c_eval, &b[i], &s_eval[i], 1); } PQCLEAN_FIRESABER_AVX2_toom4_interp(c, &c_eval); } void PQCLEAN_FIRESABER_AVX2_GenMatrix(poly A[SABER_L][SABER_L], const uint8_t seed[SABER_SEEDBYTES]) { size_t i; uint8_t buf[SABER_L * SABER_POLYVECBYTES]; shake128(buf, sizeof(buf), seed, SABER_SEEDBYTES); for (i = 0; i < SABER_L; i++) { PQCLEAN_FIRESABER_AVX2_BS2POLVECq(A[i], buf + i * SABER_POLYVECBYTES); } } void PQCLEAN_FIRESABER_AVX2_GenSecret(poly s[SABER_L], const uint8_t seed[SABER_NOISESEEDBYTES]) { size_t i; uint8_t buf[SABER_L * SABER_POLYCOINBYTES]; shake128(buf, sizeof(buf), seed, SABER_NOISESEEDBYTES); for (i = 0; i < SABER_L; i++) { PQCLEAN_FIRESABER_AVX2_cbd(s[i].coeffs, buf + i * SABER_POLYCOINBYTES); } }