From a39e9010af50091561d45bf04bfedd10fb4cc70a Mon Sep 17 00:00:00 2001 From: Christian Grothoff Date: Wed, 23 Nov 2011 19:23:03 +0000 Subject: [PATCH] LRN: fixing 1956 by using a better random generator on W32 --- src/util/crypto_random.c | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/src/util/crypto_random.c b/src/util/crypto_random.c index 719acf07c..9fc14863c 100644 --- a/src/util/crypto_random.c +++ b/src/util/crypto_random.c @@ -34,6 +34,35 @@ #define LOG_STRERROR(kind,syscall) GNUNET_log_from_strerror (kind, "util", syscall) +/* TODO: ndurner, move this to plibc? */ +/* The code is derived from glibc, obviously */ +#if MINGW +#ifdef RANDOM +# undef RANDOM +#endif +#ifdef SRANDOM +# undef SRANDOM +#endif +#define RANDOM() glibc_weak_rand32() +#define SRANDOM(s) glibc_weak_srand32(s) +static int32_t glibc_weak_rand32_state = 1; + +void +glibc_weak_srand32 (int32_t s) +{ + glibc_weak_rand32_state = s; +} + +int32_t +glibc_weak_rand32 () +{ + int32_t val = glibc_weak_rand32_state; + val = ((glibc_weak_rand32_state * 1103515245) + 12345) & 0x7fffffff; + glibc_weak_rand32_state = val; + return val; +} +#endif + /** * Create a cryptographically weak pseudo-random number in the interval of 0 to 1. * -- 2.25.1