summaryrefslogtreecommitdiffstats
path: root/3rd_party/ed25519/keypair.c
blob: dc1b8eccc28db4254c59774eefbc8d164e22bbf2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include "ed25519.h"
#include "sha512.h"
#include "ge.h"


void ed25519_create_keypair(unsigned char *public_key, unsigned char *private_key, const unsigned char *seed) {
    ge_p3 A;

    sha512(seed, 32, private_key);
    private_key[0] &= 248;
    private_key[31] &= 63;
    private_key[31] |= 64;

    ge_scalarmult_base(&A, private_key);
    ge_p3_tobytes(public_key, &A);
}