1295367Sdes/* $OpenBSD: ge25519.h,v 1.4 2015/02/16 18:26:26 miod Exp $ */ 2261287Sdes 3261287Sdes/* 4261287Sdes * Public Domain, Authors: Daniel J. Bernstein, Niels Duif, Tanja Lange, 5261287Sdes * Peter Schwabe, Bo-Yin Yang. 6261287Sdes * Copied from supercop-20130419/crypto_sign/ed25519/ref/ge25519.h 7261287Sdes */ 8261287Sdes 9261287Sdes#ifndef GE25519_H 10261287Sdes#define GE25519_H 11261287Sdes 12261287Sdes#include "fe25519.h" 13261287Sdes#include "sc25519.h" 14261287Sdes 15261287Sdes#define ge25519 crypto_sign_ed25519_ref_ge25519 16261287Sdes#define ge25519_base crypto_sign_ed25519_ref_ge25519_base 17261287Sdes#define ge25519_unpackneg_vartime crypto_sign_ed25519_ref_unpackneg_vartime 18261287Sdes#define ge25519_pack crypto_sign_ed25519_ref_pack 19261287Sdes#define ge25519_isneutral_vartime crypto_sign_ed25519_ref_isneutral_vartime 20261287Sdes#define ge25519_double_scalarmult_vartime crypto_sign_ed25519_ref_double_scalarmult_vartime 21261287Sdes#define ge25519_scalarmult_base crypto_sign_ed25519_ref_scalarmult_base 22261287Sdes 23261287Sdestypedef struct 24261287Sdes{ 25261287Sdes fe25519 x; 26261287Sdes fe25519 y; 27261287Sdes fe25519 z; 28261287Sdes fe25519 t; 29261287Sdes} ge25519; 30261287Sdes 31295367Sdesextern const ge25519 ge25519_base; 32261287Sdes 33261287Sdesint ge25519_unpackneg_vartime(ge25519 *r, const unsigned char p[32]); 34261287Sdes 35261287Sdesvoid ge25519_pack(unsigned char r[32], const ge25519 *p); 36261287Sdes 37261287Sdesint ge25519_isneutral_vartime(const ge25519 *p); 38261287Sdes 39261287Sdesvoid ge25519_double_scalarmult_vartime(ge25519 *r, const ge25519 *p1, const sc25519 *s1, const ge25519 *p2, const sc25519 *s2); 40261287Sdes 41261287Sdesvoid ge25519_scalarmult_base(ge25519 *r, const sc25519 *s); 42261287Sdes 43261287Sdes#endif 44