-rw-r--r-- 559 libmceliece-20241009/crypto_kem/348864/avx/gf_2m_mul2.c raw
// 20240809 djb: split out of gf.h // linker define gf_mul2 #include "gf.h" #include "crypto_int64.h" /* 2 field multiplications */ uint64_t gf_mul2(gf a, gf b0, gf b1) { int i; uint64_t tmp=0; uint64_t t0; uint64_t t1; uint64_t t; t0 = a; t1 = b1; t1 = (t1 << 32) | b0; for (i = 0; i < GFBITS; i++) { tmp ^= t1 & crypto_int64_bottombit_mask(t0); t1 <<= 1; t0 >>= 1; } // t = tmp & 0x007FC000007FC000; tmp ^= (t >> 9) ^ (t >> 12); t = tmp & 0x0000300000003000; tmp ^= (t >> 9) ^ (t >> 12); return tmp & 0x00000FFF00000FFF; }