1*8fb009dcSAndroid Build Coastguard Worker /* Copyright (c) 2018, Google Inc. 2*8fb009dcSAndroid Build Coastguard Worker * 3*8fb009dcSAndroid Build Coastguard Worker * Permission to use, copy, modify, and/or distribute this software for any 4*8fb009dcSAndroid Build Coastguard Worker * purpose with or without fee is hereby granted, provided that the above 5*8fb009dcSAndroid Build Coastguard Worker * copyright notice and this permission notice appear in all copies. 6*8fb009dcSAndroid Build Coastguard Worker * 7*8fb009dcSAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 8*8fb009dcSAndroid Build Coastguard Worker * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 9*8fb009dcSAndroid Build Coastguard Worker * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY 10*8fb009dcSAndroid Build Coastguard Worker * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 11*8fb009dcSAndroid Build Coastguard Worker * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION 12*8fb009dcSAndroid Build Coastguard Worker * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 13*8fb009dcSAndroid Build Coastguard Worker * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ 14*8fb009dcSAndroid Build Coastguard Worker 15*8fb009dcSAndroid Build Coastguard Worker #ifndef OPENSSL_HEADER_HRSS_INTERNAL_H 16*8fb009dcSAndroid Build Coastguard Worker #define OPENSSL_HEADER_HRSS_INTERNAL_H 17*8fb009dcSAndroid Build Coastguard Worker 18*8fb009dcSAndroid Build Coastguard Worker #include <openssl/base.h> 19*8fb009dcSAndroid Build Coastguard Worker #include "../internal.h" 20*8fb009dcSAndroid Build Coastguard Worker 21*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 22*8fb009dcSAndroid Build Coastguard Worker extern "C" { 23*8fb009dcSAndroid Build Coastguard Worker #endif 24*8fb009dcSAndroid Build Coastguard Worker 25*8fb009dcSAndroid Build Coastguard Worker 26*8fb009dcSAndroid Build Coastguard Worker #define N 701 27*8fb009dcSAndroid Build Coastguard Worker #define BITS_PER_WORD (sizeof(crypto_word_t) * 8) 28*8fb009dcSAndroid Build Coastguard Worker #define WORDS_PER_POLY ((N + BITS_PER_WORD - 1) / BITS_PER_WORD) 29*8fb009dcSAndroid Build Coastguard Worker #define BITS_IN_LAST_WORD (N % BITS_PER_WORD) 30*8fb009dcSAndroid Build Coastguard Worker 31*8fb009dcSAndroid Build Coastguard Worker struct poly2 { 32*8fb009dcSAndroid Build Coastguard Worker crypto_word_t v[WORDS_PER_POLY]; 33*8fb009dcSAndroid Build Coastguard Worker }; 34*8fb009dcSAndroid Build Coastguard Worker 35*8fb009dcSAndroid Build Coastguard Worker struct poly3 { 36*8fb009dcSAndroid Build Coastguard Worker struct poly2 s, a; 37*8fb009dcSAndroid Build Coastguard Worker }; 38*8fb009dcSAndroid Build Coastguard Worker 39*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void HRSS_poly3_mul(struct poly3 *out, const struct poly3 *x, 40*8fb009dcSAndroid Build Coastguard Worker const struct poly3 *y); 41*8fb009dcSAndroid Build Coastguard Worker OPENSSL_EXPORT void HRSS_poly3_invert(struct poly3 *out, 42*8fb009dcSAndroid Build Coastguard Worker const struct poly3 *in); 43*8fb009dcSAndroid Build Coastguard Worker 44*8fb009dcSAndroid Build Coastguard Worker // On x86-64, we can use the AVX2 code from [HRSS]. (The authors have given 45*8fb009dcSAndroid Build Coastguard Worker // explicit permission for this and signed a CLA.) However it's 57KB of object 46*8fb009dcSAndroid Build Coastguard Worker // code, so it's not used if |OPENSSL_SMALL| is defined. 47*8fb009dcSAndroid Build Coastguard Worker #if !defined(OPENSSL_NO_ASM) && !defined(OPENSSL_SMALL) && \ 48*8fb009dcSAndroid Build Coastguard Worker defined(OPENSSL_X86_64) && defined(OPENSSL_LINUX) 49*8fb009dcSAndroid Build Coastguard Worker #define POLY_RQ_MUL_ASM 50*8fb009dcSAndroid Build Coastguard Worker // POLY_MUL_RQ_SCRATCH_SPACE is the number of bytes of scratch space needed 51*8fb009dcSAndroid Build Coastguard Worker // by the assembly function poly_Rq_mul. 52*8fb009dcSAndroid Build Coastguard Worker #define POLY_MUL_RQ_SCRATCH_SPACE (6144 + 6144 + 12288 + 512 + 9408 + 32) 53*8fb009dcSAndroid Build Coastguard Worker 54*8fb009dcSAndroid Build Coastguard Worker // poly_Rq_mul is defined in assembly. Inputs and outputs must be 16-byte- 55*8fb009dcSAndroid Build Coastguard Worker // aligned. 56*8fb009dcSAndroid Build Coastguard Worker extern void poly_Rq_mul( 57*8fb009dcSAndroid Build Coastguard Worker uint16_t r[N + 3], const uint16_t a[N + 3], const uint16_t b[N + 3], 58*8fb009dcSAndroid Build Coastguard Worker // The following should be `scratch[POLY_MUL_RQ_SCRATCH_SPACE]` but 59*8fb009dcSAndroid Build Coastguard Worker // GCC 11.1 has a bug with unions that breaks that. 60*8fb009dcSAndroid Build Coastguard Worker uint8_t scratch[]); 61*8fb009dcSAndroid Build Coastguard Worker #endif 62*8fb009dcSAndroid Build Coastguard Worker 63*8fb009dcSAndroid Build Coastguard Worker 64*8fb009dcSAndroid Build Coastguard Worker #if defined(__cplusplus) 65*8fb009dcSAndroid Build Coastguard Worker } // extern "C" 66*8fb009dcSAndroid Build Coastguard Worker #endif 67*8fb009dcSAndroid Build Coastguard Worker 68*8fb009dcSAndroid Build Coastguard Worker #endif // !OPENSSL_HEADER_HRSS_INTERNAL_H 69