-rw-r--r-- 1392 lib25519-20220426/crypto_dh/x25519/amd64-51/mont25519.c raw
#include "randombytes.h" #include "crypto_dh.h" #include "fe25519.h" #define work_cswap CRYPTO_NAMESPACE(work_cswap) #define ladderstep CRYPTO_NAMESPACE(ladderstep) extern void work_cswap(fe25519 *, unsigned long long); extern void ladderstep(fe25519 *work); static void mladder(fe25519 *xr, fe25519 *zr, const unsigned char s[32]) { fe25519 work[5]; unsigned char bit, prevbit=0; unsigned long long swap; int j; int i; work[0] = *xr; fe25519_setint(work+1,1); fe25519_setint(work+2,0); work[3] = *xr; fe25519_setint(work+4,1); j = 6; for(i=31;i>=0;i--) { while(j >= 0) { bit = 1&(s[i]>>j); swap = bit ^ prevbit; prevbit = bit; work_cswap(work+1, swap); ladderstep(work); j -= 1; } j = 7; } *xr = work[1]; *zr = work[2]; } void crypto_dh(unsigned char *r, const unsigned char *p, const unsigned char *s) { unsigned char e[32]; int i; for(i=0;i<32;i++) e[i] = s[i]; e[0] &= 248; e[31] &= 127; e[31] |= 64; fe25519 t; fe25519 z; fe25519_unpack(&t, p); mladder(&t, &z, e); fe25519_invert(&z, &z); fe25519_mul(&t, &t, &z); fe25519_pack(r, &t); } 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); }