]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/libkern/random.c
xnu-201.tar.gz
[apple/xnu.git] / bsd / libkern / random.c
index aed1b355b176c9f942f863cb128ec3677a5983ef..8a002af2c22aa1465e897724e1820c3d608cf48b 100644 (file)
  *     @(#)random.c    8.1 (Berkeley) 6/10/93
  */
 
-/*
- * Modification History
- *
- * Feb 22, 1999        Dieter Siegmund (dieter@apple.com)
- * - the first time, set the random seed to the microsecond time value
- *   to make the random numbers less predictable
- */
-#include <libkern/libkern.h>
-#include <sys/time.h>
+#include <sys/types.h>
+#include <sys/random.h>
 
 /*
  * Pseudo-random number generator for randomizing the profiling clock,
 u_long
 random()
 {
-       static int first = 1;
-       static u_long randseed = 1;
-
-       register long x, hi, lo, t;
-
-       if (first) {
-           struct timeval tv;
-           microtime(&tv);
-           randseed = tv.tv_usec;
-           if(!randseed)
-               randseed=1;
-           first = 0;
-       }
-
-       /*
-        * Compute x[n + 1] = (7^5 * x[n]) mod (2^31 - 1).
-        * From "Random number generators: good ones are hard to find",
-        * Park and Miller, Communications of the ACM, vol. 31, no. 10,
-        * October 1988, p. 1195.
-        */
-       x = randseed;
-       hi = x / 127773;
-       lo = x % 127773;
-       t = 16807 * lo - 2836 * hi;
-       if (t <= 0)
-               t += 0x7fffffff;
-       randseed = t;
-       return (t);
+       return RandomULong();
 }
+