diff options
| author | Adam Ierymenko <adam.ierymenko@gmail.com> | 2018-03-19 11:18:54 -0700 |
|---|---|---|
| committer | Adam Ierymenko <adam.ierymenko@gmail.com> | 2018-03-19 11:18:54 -0700 |
| commit | 209f6d9d2d6f826fa37ca841ef51c5d6e065ff5e (patch) | |
| tree | 181342018acb72d37ddc57412a4727d168345a89 /ext/ed25519-amd64-asm/keypair.c | |
| parent | b601041b5bd82aca1e52967c37c78ed953be7751 (diff) | |
| parent | 916077012ed4810492d6e45ed07222cdbb750fc0 (diff) | |
| download | infinitytier-209f6d9d2d6f826fa37ca841ef51c5d6e065ff5e.tar.gz infinitytier-209f6d9d2d6f826fa37ca841ef51c5d6e065ff5e.zip | |
Merge branch 'dev' into edge
Diffstat (limited to 'ext/ed25519-amd64-asm/keypair.c')
| -rw-r--r-- | ext/ed25519-amd64-asm/keypair.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/ext/ed25519-amd64-asm/keypair.c b/ext/ed25519-amd64-asm/keypair.c new file mode 100644 index 00000000..7e094710 --- /dev/null +++ b/ext/ed25519-amd64-asm/keypair.c @@ -0,0 +1,25 @@ +#include <string.h> +#include "crypto_sign.h" +#include "crypto_hash_sha512.h" +#include "randombytes.h" +#include "ge25519.h" + +int crypto_sign_keypair(unsigned char *pk,unsigned char *sk) +{ + unsigned char az[64]; + sc25519 scsk; + ge25519 gepk; + + randombytes(sk,32); + crypto_hash_sha512(az,sk,32); + az[0] &= 248; + az[31] &= 127; + az[31] |= 64; + + sc25519_from32bytes(&scsk,az); + + ge25519_scalarmult_base(&gepk, &scsk); + ge25519_pack(pk, &gepk); + memmove(sk + 32,pk,32); + return 0; +} |
