#include "randombytes.h" #include "crypto_dh.h" #include "fe25519.h" #include "crypto_uint64_vec4x1.h" #define mladder CRYPTO_NAMESPACE(mladder) extern void mladder(crypto_uint64_vec4x1 *,crypto_uint64_vec4x1 *,const unsigned char *); void crypto_dh(unsigned char *r, const unsigned char *p, const unsigned char *s) { unsigned char e[32]; int i; crypto_uint64_vec4x1 a[9] = {{0}}; crypto_uint64_vec4x1 b[9] = {{0}}; fe25519_9l u,v; fe25519_5l z[2]; fe25519 w; for(i=0;i<32;i++) e[i] = s[i]; e[0] &= 248; e[31] &= 127; e[31] |= 64; fe25519_unpack(&w,p); fe25519_to_9l(&u,&w); b[0][0] = b[0][3] = a[0][2] = 1; for (i=0;i<9;i++) {b[i][2] = u.l[i]; a[i][3] = u.l[i];} mladder(b,a,e); for (i=0;i<9;i++) {u.l[i] = b[i][0]; v.l[i] = b[i][1];} fe25519_9l_to_5l(z,&u); fe25519_9l_to_5l(z+1,&v); fe25519_invert(z+1, z+1); fe25519_mul(z, z, z+1); fe25519_from_5l(&w, z); fe25519_pack(r, &w); } static const unsigned char basepoint[32] = {9}; void crypto_dh_keypair(unsigned char *pk,unsigned char *sk) { randombytes(sk,crypto_dh_SECRETKEYBYTES); crypto_dh(pk,basepoint,sk); }