aboutsummaryrefslogtreecommitdiff
path: root/src/crypto/shen_ed25519_ref/randombytes.c
diff options
context:
space:
mode:
authorRiccardo Spagni <ric@spagni.net>2015-08-24 19:21:24 +0200
committerRiccardo Spagni <ric@spagni.net>2015-08-24 19:21:31 +0200
commit32077d381013ce19fb9824105a1d348fc8975658 (patch)
treeb2fbd2123b601e14350a9ada57212aa60e8836a0 /src/crypto/shen_ed25519_ref/randombytes.c
parentMerge pull request #383 (diff)
parentAdded ref10 shen_ed25519_ref code, which includes code that can replace crypt... (diff)
downloadmonero-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-xsrc/crypto/shen_ed25519_ref/randombytes.c52
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 */