diff options
author | Riccardo Spagni <ric@spagni.net> | 2015-08-24 19:21:24 +0200 |
---|---|---|
committer | Riccardo Spagni <ric@spagni.net> | 2015-08-24 19:21:31 +0200 |
commit | 32077d381013ce19fb9824105a1d348fc8975658 (patch) | |
tree | b2fbd2123b601e14350a9ada57212aa60e8836a0 /src/crypto/shen_ed25519_ref/randombytes.c | |
parent | Merge pull request #383 (diff) | |
parent | Added ref10 shen_ed25519_ref code, which includes code that can replace crypt... (diff) | |
download | monero-32077d381013ce19fb9824105a1d348fc8975658.tar.xz |
Merge pull request #385
0a4bc84 Added ref10 shen_ed25519_ref code, which includes code that can replace crypto-ops with a version straight from Bernstein's ref 10 (ShenNoether)
0d70fdc revert to 776b4fc91a821be152f0f23e6873aabb78a72029 (ShenNoether)
b01f286 Added shen_ed25519_ref to crypto ops subfolder, the point is to directly have bitmonero's crypto code come from bernstein et al's ref 10 code (ShenNoether)
Diffstat (limited to 'src/crypto/shen_ed25519_ref/randombytes.c')
-rwxr-xr-x | src/crypto/shen_ed25519_ref/randombytes.c | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/src/crypto/shen_ed25519_ref/randombytes.c b/src/crypto/shen_ed25519_ref/randombytes.c new file mode 100755 index 000000000..fa7d42149 --- /dev/null +++ b/src/crypto/shen_ed25519_ref/randombytes.c @@ -0,0 +1,52 @@ +#ifndef _WIN32 +#include <sys/types.h> +#include <sys/stat.h> +#include <fcntl.h> +#include <unistd.h> + +/* it's really stupid that there isn't a syscall for this */ + +static int ed25519_random_fd = -1; + +static inline void ed25519_randombytes(unsigned char *x,unsigned long long xlen) +{ + int i; + + if (ed25519_random_fd == -1) { + for (;;) { + ed25519_random_fd = open("/dev/urandom",O_RDONLY); + if (ed25519_random_fd != -1) break; + sleep(1); + } + } + + while (xlen > 0) { + if (xlen < 1048576) i = xlen; else i = 1048576; + + i = read(ed25519_random_fd,x,i); + if (i < 1) { + sleep(1); + continue; + } + + x += i; + xlen -= i; + } +} + +#else +#include <windows.h> +#include <wincrypt.h> + +static inline void ed25519_randombytes(unsigned char *x,unsigned long long xlen) +{ + HCRYPTPROV prov = 0; + + CryptAcquireContextW(&prov, NULL, NULL, + PROV_RSA_FULL, CRYPT_VERIFYCONTEXT | CRYPT_SILENT); + + CryptGenRandom(prov, xlen, x); + CryptReleaseContext(prov, 0); +} + +#endif /* _WIN32 */ |