diff options
author | Adam Ierymenko <adam.ierymenko@gmail.com> | 2018-03-13 06:51:17 -0700 |
---|---|---|
committer | Adam Ierymenko <adam.ierymenko@gmail.com> | 2018-03-13 06:51:17 -0700 |
commit | beb170e4fb4a42cf3770a731f222a63f0bdfe0f3 (patch) | |
tree | 11cde6c7374affaaf88a3eed48bd0018d6268fc4 /ext/ed25519-amd64-asm/keypair.c | |
parent | a59912f3afa7627f3da79804a9be693a7d314ebc (diff) | |
download | infinitytier-beb170e4fb4a42cf3770a731f222a63f0bdfe0f3.tar.gz infinitytier-beb170e4fb4a42cf3770a731f222a63f0bdfe0f3.zip |
Use X64 ASM ed25519 signatures on Linux/x64, which are about 10X faster. Will matter a lot for network controllers, not so much for other things.
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; +} |