ge_p3
ge_p3 u;
ge_p3 P;
ge_p3 mask;
ge_p3 Qmasked;
ge_p3 peers_mask;
ge_p3 Qunmasked;
static int x25519_ge_frombytes_vartime(ge_p3 *h, const uint8_t s[32]) {
static void ge_p3_0(ge_p3 *h) {
static void ge_p3_to_p2(ge_p2 *r, const ge_p3 *p) {
static void x25519_ge_p3_to_cached(ge_cached *r, const ge_p3 *p) {
static void x25519_ge_p1p1_to_p3(ge_p3 *r, const ge_p1p1 *p) {
ge_p3 t;
static void ge_p3_dbl(ge_p1p1 *r, const ge_p3 *p) {
static void ge_madd(ge_p1p1 *r, const ge_p3 *p, const ge_precomp *q) {
static void x25519_ge_add(ge_p1p1 *r, const ge_p3 *p, const ge_cached *q) {
static void x25519_ge_sub(ge_p1p1 *r, const ge_p3 *p, const ge_cached *q) {
ge_p3 *h, const uint8_t a[32], const uint8_t precomp_table[15 * 2 * 32]) {
static void x25519_ge_scalarmult_base(ge_p3 *h, const uint8_t a[32]) {
static void x25519_ge_scalarmult_base(ge_p3 *h, const uint8_t *a) {
const ge_p3 *A) {
static void ge_p3_tobytes(uint8_t *s, const ge_p3 *h)
static int ge_frombytes_vartime(ge_p3 *h, const uint8_t *s)
static void ge_p3_0(ge_p3 *h)
static void ge_p3_to_p2(ge_p2 *r, const ge_p3 *p)
static void ge_p3_to_cached(ge_cached *r, const ge_p3 *p)
static void ge_p1p1_to_p3(ge_p3 *r, const ge_p1p1 *p)
static void ge_p3_dbl(ge_p1p1 *r, const ge_p3 *p)
static void ge_madd(ge_p1p1 *r, const ge_p3 *p, const ge_precomp *q)
static void ge_msub(ge_p1p1 *r, const ge_p3 *p, const ge_precomp *q)
static void ge_add(ge_p1p1 *r, const ge_p3 *p, const ge_cached *q)
static void ge_sub(ge_p1p1 *r, const ge_p3 *p, const ge_cached *q)
static void ge_scalarmult_base(ge_p3 *h, const uint8_t *a)
const ge_p3 *A, const uint8_t *b)
ge_p3 u;
ge_p3 A2;
ge_p3 R;
ge_p3 A;
ge_p3 A;
ge_p3 A;
ge_p3 A;