| @@ -8,7 +8,7 @@ f_field_h = gen_file( | |||
| code = """ | |||
| #include "constant_time.h" | |||
| #include <string.h> | |||
| #include <assert.h> | |||
| #include "decaf/decaf_%(gf_bits)s.h" /* HACK in genheader */ | |||
| #include "word.h" | |||
| @@ -1,23 +1,9 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P25519_H__ | |||
| #define __P25519_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #include <string.h> | |||
| #define FIELD_LITERAL(a,b,c,d,e) {{ a,b,c,d,e }} | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<5; i++) { | |||
| out->limb[i] = a->limb[i] + b->limb[i]; | |||
| @@ -47,8 +33,3 @@ void gf_weak_reduce (gf a) { | |||
| a->limb[0] = (a->limb[0] & mask) + tmp*19; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P25519_H__ */ | |||
| @@ -1,19 +1,9 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P25519_H__ | |||
| #define __P25519_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #include <string.h> | |||
| #define FIELD_LITERAL(a,b,c,d,e) {{ a,b,c,d,e }} | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<5; i++) { | |||
| out->limb[i] = a->limb[i] + b->limb[i]; | |||
| @@ -41,9 +31,3 @@ void gf_weak_reduce (gf a) { | |||
| } | |||
| a->limb[0] = (a->limb[0] & mask) + tmp*19; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P25519_H__ */ | |||
| @@ -1,24 +1,11 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P448_H__ | |||
| #define __P448_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #define LIMB(x) (x##ull)&((1ull<<28)-1), (x##ull)>>28 | |||
| #define FIELD_LITERAL(a,b,c,d,e,f,g,h) \ | |||
| {{LIMB(a),LIMB(b),LIMB(c),LIMB(d),LIMB(e),LIMB(f),LIMB(g),LIMB(h)}} | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint32xn_t); i++) { | |||
| ((uint32xn_t*)out)[i] = ((const uint32xn_t*)a)[i] + ((const uint32xn_t*)b)[i]; | |||
| @@ -63,8 +50,3 @@ void gf_weak_reduce (gf a) { | |||
| a->limb[0] = (a->limb[0] & mask) + tmp; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P448_H__ */ | |||
| @@ -1,24 +1,11 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P448_H__ | |||
| #define __P448_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #define LIMB(x) (x##ull)&((1ull<<28)-1), (x##ull)>>28 | |||
| #define FIELD_LITERAL(a,b,c,d,e,f,g,h) \ | |||
| {{LIMB(a),LIMB(b),LIMB(c),LIMB(d),LIMB(e),LIMB(f),LIMB(g),LIMB(h)}} | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint32xn_t); i++) { | |||
| ((uint32xn_t*)out)[i] = ((const uint32xn_t*)a)[i] + ((const uint32xn_t*)b)[i]; | |||
| @@ -61,8 +48,3 @@ void gf_weak_reduce (gf a) { | |||
| a->limb[0] = (a->limb[0] & mask) + tmp; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P448_H__ */ | |||
| @@ -1,13 +1,6 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P448_H__ | |||
| #define __P448_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #define LIMBPERM(x) (((x)<<1 | (x)>>3) & 15) | |||
| #define USE_NEON_PERM 1 | |||
| @@ -19,12 +12,6 @@ | |||
| LIMBLO(c),LIMBLO(g), LIMBHI(c),LIMBHI(g), \ | |||
| LIMBLO(d),LIMBLO(h), LIMBHI(d),LIMBHI(h)}} | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint32xn_t); i++) { | |||
| ((uint32xn_t*)out)[i] = ((const uint32xn_t*)a)[i] + ((const uint32xn_t*)b)[i]; | |||
| @@ -64,8 +51,3 @@ void gf_weak_reduce (gf a) { | |||
| aa[0] = (aa[0] & vmask) + vrev64_u32(tmp) + (tmp&vm2); | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P448_H__ */ | |||
| @@ -1,31 +1,17 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P448_H__ | |||
| #define __P448_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #include <string.h> | |||
| #define FIELD_LITERAL(a,b,c,d,e,f,g,h) {{a,b,c,d,e,f,g,h}} | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<8; i++) { | |||
| out->limb[i] = a->limb[i] + b->limb[i]; | |||
| } | |||
| gf_weak_reduce(out); | |||
| } | |||
| void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| uint64_t co1 = ((1ull<<56)-1)*2, co2 = co1-2; | |||
| for (unsigned int i=0; i<8; i++) { | |||
| out->limb[i] = a->limb[i] - b->limb[i] + ((i==4) ? co2 : co1); | |||
| @@ -33,12 +19,12 @@ void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| gf_weak_reduce(out); | |||
| } | |||
| void gf_bias (gf a, int amt) { | |||
| void gf_bias (gf a, int amt) { | |||
| (void) a; | |||
| (void) amt; | |||
| } | |||
| void gf_weak_reduce (gf a) { | |||
| void gf_weak_reduce (gf a) { | |||
| uint64_t mask = (1ull<<56) - 1; | |||
| uint64_t tmp = a->limb[7] >> 56; | |||
| a->limb[4] += tmp; | |||
| @@ -47,9 +33,3 @@ void gf_weak_reduce (gf a) { | |||
| } | |||
| a->limb[0] = (a->limb[0] & mask) + tmp; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P448_H__ */ | |||
| @@ -1,23 +1,10 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P448_H__ | |||
| #define __P448_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #define FIELD_LITERAL(a,b,c,d,e,f,g,h) {{a,b,c,d,e,f,g,h}} | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint64xn_t); i++) { | |||
| ((uint64xn_t*)out)[i] = ((const uint64xn_t*)a)[i] + ((const uint64xn_t*)b)[i]; | |||
| } | |||
| @@ -29,7 +16,7 @@ void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| */ | |||
| } | |||
| void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint64xn_t); i++) { | |||
| ((uint64xn_t*)out)[i] = ((const uint64xn_t*)a)[i] - ((const uint64xn_t*)b)[i]; | |||
| } | |||
| @@ -41,7 +28,7 @@ void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| */ | |||
| } | |||
| void gf_bias (gf a, int amt) { | |||
| void gf_bias (gf a, int amt) { | |||
| uint64_t co1 = ((1ull<<56)-1)*amt, co2 = co1-amt; | |||
| #if __AVX2__ | |||
| @@ -63,7 +50,7 @@ void gf_bias (gf a, int amt) { | |||
| #endif | |||
| } | |||
| void gf_weak_reduce (gf a) { | |||
| void gf_weak_reduce (gf a) { | |||
| /* PERF: use pshufb/palignr if anyone cares about speed of this */ | |||
| uint64_t mask = (1ull<<56) - 1; | |||
| uint64_t tmp = a->limb[7] >> 56; | |||
| @@ -74,8 +61,3 @@ void gf_weak_reduce (gf a) { | |||
| a->limb[0] = (a->limb[0] & mask) + tmp; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P448_H__ */ | |||
| @@ -1,23 +1,8 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __gf_H__ | |||
| #define __gf_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #include "word.h" | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf *out, const gf *a, const gf *b) { | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint64xn_t); i++) { | |||
| ((uint64xn_t*)out)[i] = ((const uint64xn_t*)a)[i] + ((const uint64xn_t*)b)[i]; | |||
| } | |||
| @@ -29,7 +14,7 @@ void gf_add_RAW (gf *out, const gf *a, const gf *b) { | |||
| */ | |||
| } | |||
| void gf_sub_RAW (gf *out, const gf *a, const gf *b) { | |||
| void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint64xn_t); i++) { | |||
| ((uint64xn_t*)out)[i] = ((const uint64xn_t*)a)[i] - ((const uint64xn_t*)b)[i]; | |||
| } | |||
| @@ -41,14 +26,14 @@ void gf_sub_RAW (gf *out, const gf *a, const gf *b) { | |||
| */ | |||
| } | |||
| void gf_copy (gf *out, const gf *a) { | |||
| void gf_copy (gf out, const gf a) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(big_register_t); i++) { | |||
| ((big_register_t *)out)[i] = ((const big_register_t *)a)[i]; | |||
| } | |||
| } | |||
| void gf_bias ( | |||
| gf *a, int amt | |||
| gf a, int amt | |||
| ) { | |||
| uint64_t co1 = ((1ull<<60)-1)*amt, co2 = co1-amt; | |||
| @@ -71,7 +56,7 @@ void gf_bias ( | |||
| #endif | |||
| } | |||
| void gf_weak_reduce (gf *a) { | |||
| void gf_weak_reduce (gf a) { | |||
| /* PERF: use pshufb/palignr if anyone cares about speed of this */ | |||
| uint64_t mask = (1ull<<60) - 1; | |||
| uint64_t tmp = a->limb[7] >> 60; | |||
| @@ -81,9 +66,3 @@ void gf_weak_reduce (gf *a) { | |||
| } | |||
| a->limb[0] = (a->limb[0] & mask) + tmp; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __gf_H__ */ | |||
| @@ -1,29 +1,15 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P521_H__ | |||
| #define __P521_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #include <string.h> | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| void gf_add_RAW (gf *out, const gf *a, const gf *b) { | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<9; i++) { | |||
| out->limb[i] = a->limb[i] + b->limb[i]; | |||
| } | |||
| gf_weak_reduce(out); | |||
| } | |||
| void gf_sub_RAW (gf *out, const gf *a, const gf *b) { | |||
| void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| uint64_t co1 = ((1ull<<58)-1)*4, co2 = ((1ull<<57)-1)*4; | |||
| for (unsigned int i=0; i<9; i++) { | |||
| out->limb[i] = a->limb[i] - b->limb[i] + ((i==8) ? co2 : co1); | |||
| @@ -31,12 +17,12 @@ void gf_sub_RAW (gf *out, const gf *a, const gf *b) { | |||
| gf_weak_reduce(out); | |||
| } | |||
| void gf_bias (gf *a, int amt) { | |||
| void gf_bias (gf a, int amt) { | |||
| (void) a; | |||
| (void) amt; | |||
| } | |||
| void gf_weak_reduce (gf *a) { | |||
| void gf_weak_reduce (gf a) { | |||
| uint64_t mask = (1ull<<58) - 1; | |||
| uint64_t tmp = a->limb[8] >> 57; | |||
| for (unsigned int i=8; i>0; i--) { | |||
| @@ -44,9 +30,3 @@ void gf_weak_reduce (gf *a) { | |||
| } | |||
| a->limb[0] = (a->limb[0] & mask) + tmp; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P521_H__ */ | |||
| @@ -1,27 +1,11 @@ | |||
| /* Copyright (c) 2014 Cryptography Research, Inc. | |||
| /* Copyright (c) 2014-2016 Cryptography Research, Inc. | |||
| * Released under the MIT License. See LICENSE.txt for license information. | |||
| */ | |||
| #ifndef __P521_H__ | |||
| #define __P521_H__ 1 | |||
| #include "f_field.h" | |||
| #include <stdint.h> | |||
| #include <assert.h> | |||
| #include <string.h> | |||
| #include "constant_time.h" | |||
| /* FIXME: Currenmtlty desn't work at all, because the struct is declared [9] and not [12] */ | |||
| /* FIXME: Currently this file desn't work at all, because the struct is declared [9] and not [12] */ | |||
| #define LIMBPERM(x) (((x)%3)*4 + (x)/3) | |||
| #define USE_P521_3x3_TRANSPOSE | |||
| #ifdef __cplusplus | |||
| extern "C" { | |||
| #endif | |||
| /* -------------- Inline functions begin here -------------- */ | |||
| typedef uint64x4_t uint64x3_t; /* fit it in a vector register */ | |||
| static const uint64x3_t mask58 = { (1ull<<58) - 1, (1ull<<58) - 1, (1ull<<58) - 1, 0 }; | |||
| @@ -31,19 +15,19 @@ static inline uint64x3_t timesW (uint64x3_t u) { | |||
| return u.zxyw + u.zwww; | |||
| } | |||
| void gf_add_RAW (gf *out, const gf *a, const gf *b) { | |||
| void gf_add_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint64xn_t); i++) { | |||
| ((uint64xn_t*)out)[i] = ((const uint64xn_t*)a)[i] + ((const uint64xn_t*)b)[i]; | |||
| } | |||
| } | |||
| void gf_sub_RAW (gf *out, const gf *a, const gf *b) { | |||
| void gf_sub_RAW (gf out, const gf a, const gf b) { | |||
| for (unsigned int i=0; i<sizeof(*out)/sizeof(uint64xn_t); i++) { | |||
| ((uint64xn_t*)out)[i] = ((const uint64xn_t*)a)[i] - ((const uint64xn_t*)b)[i]; | |||
| } | |||
| } | |||
| void gf_bias (gf *a, int amt) { | |||
| void gf_bias (gf a, int amt) { | |||
| uint64_t co0 = ((1ull<<58)-2)*amt, co1 = ((1ull<<58)-1)*amt; | |||
| uint64x4_t vlo = { co0, co1, co1, 0 }, vhi = { co1, co1, co1, 0 }; | |||
| ((uint64x4_t*)a)[0] += vlo; | |||
| @@ -51,7 +35,7 @@ void gf_bias (gf *a, int amt) { | |||
| ((uint64x4_t*)a)[2] += vhi; | |||
| } | |||
| void gf_weak_reduce (gf *a) { | |||
| void gf_weak_reduce (gf a) { | |||
| #if 0 | |||
| int i; | |||
| assert(a->limb[3] == 0 && a->limb[7] == 0 && a->limb[11] == 0); | |||
| @@ -72,9 +56,3 @@ void gf_weak_reduce (gf *a) { | |||
| ((uint64x4_t*)a)[1] = out1; | |||
| ((uint64x4_t*)a)[2] = out2; | |||
| } | |||
| #ifdef __cplusplus | |||
| }; /* extern "C" */ | |||
| #endif | |||
| #endif /* __P521_H__ */ | |||