|
|
@ -44,16 +44,17 @@ add_l64(unsigned char * const S) |
|
|
|
int |
|
|
|
main(void) |
|
|
|
{ |
|
|
|
unsigned char *r; |
|
|
|
unsigned char *h, *r; |
|
|
|
unsigned char *p, *p2, *p3; |
|
|
|
unsigned char *sc, *sc2, *sc3; |
|
|
|
unsigned char *sc64; |
|
|
|
char *hex; |
|
|
|
unsigned int i, j; |
|
|
|
|
|
|
|
h = (unsigned char *) sodium_malloc(crypto_core_ed25519_HASHBYTES); |
|
|
|
r = (unsigned char *) sodium_malloc(crypto_core_ed25519_UNIFORMBYTES); |
|
|
|
p = (unsigned char *) sodium_malloc(crypto_core_ed25519_BYTES); |
|
|
|
for (i = 0; i < 1000; i++) { |
|
|
|
for (i = 0; i < 500; i++) { |
|
|
|
randombytes_buf(r, crypto_core_ed25519_UNIFORMBYTES); |
|
|
|
if (crypto_core_ed25519_from_uniform(p, r) != 0) { |
|
|
|
printf("crypto_core_ed25519_from_uniform() failed\n"); |
|
|
@ -62,6 +63,14 @@ main(void) |
|
|
|
printf("crypto_core_ed25519_from_uniform() returned an invalid point\n"); |
|
|
|
} |
|
|
|
|
|
|
|
randombytes_buf(h, crypto_core_ed25519_HASHBYTES); |
|
|
|
if (crypto_core_ed25519_from_hash(p, h) != 0) { |
|
|
|
printf("crypto_core_ed25519_from_hash() failed\n"); |
|
|
|
} |
|
|
|
if (crypto_core_ed25519_is_valid_point(p) == 0) { |
|
|
|
printf("crypto_core_ed25519_from_hash() returned an invalid point\n"); |
|
|
|
} |
|
|
|
|
|
|
|
crypto_core_ed25519_random(p); |
|
|
|
if (crypto_core_ed25519_is_valid_point(p) == 0) { |
|
|
|
printf("crypto_core_ed25519_random() returned an invalid point\n"); |
|
|
@ -387,6 +396,7 @@ main(void) |
|
|
|
sodium_free(p2); |
|
|
|
sodium_free(p); |
|
|
|
sodium_free(r); |
|
|
|
sodium_free(h); |
|
|
|
|
|
|
|
assert(crypto_core_ed25519_BYTES == crypto_core_ed25519_bytes()); |
|
|
|
assert(crypto_core_ed25519_SCALARBYTES == crypto_core_ed25519_scalarbytes()); |
|
|
@ -394,6 +404,8 @@ main(void) |
|
|
|
assert(crypto_core_ed25519_NONREDUCEDSCALARBYTES >= crypto_core_ed25519_SCALARBYTES); |
|
|
|
assert(crypto_core_ed25519_UNIFORMBYTES == crypto_core_ed25519_uniformbytes()); |
|
|
|
assert(crypto_core_ed25519_UNIFORMBYTES >= crypto_core_ed25519_BYTES); |
|
|
|
assert(crypto_core_ed25519_HASHBYTES == crypto_core_ed25519_hashbytes()); |
|
|
|
assert(crypto_core_ed25519_HASHBYTES >= 2 * crypto_core_ed25519_BYTES); |
|
|
|
|
|
|
|
printf("OK\n"); |
|
|
|
|
|
|
|