devwstat,
};
-static ulong randn;
-
-int
-rand(void)
-{
- if(randn == 0)
- randomread((void*)&randn, sizeof(randn));
- randn = randn*1103515245 + 12345 + MACHP(0)->ticks;
- return randn;
-}
-
-int
-nrand(int n)
-{
- rand();
- return (randn>>16) % n;
-}
-
static uvlong uvorder = 0x0001020304050607ULL;
static uchar*
extern int utfnlen(char*, long);
extern int runelen(long);
+/*
+ * random number
+ */
+extern int rand(void);
+extern int nrand(int);
+extern long lrand(void);
+extern long lnrand(long);
+
extern int abs(int);
/*
Proc* newproc(void);
void nexterror(void);
int notify(Ureg*);
-int nrand(int);
uvlong ns2fastticks(uvlong);
int okaddr(uintptr, ulong, int);
int openmode(ulong);
int qwindow(Queue*);
int qwrite(Queue*, void*, int);
void qnoblock(Queue*, int);
-int rand(void);
void randominit(void);
ulong randomread(void*, ulong);
void rdb(void);
{
randomread(p, n);
}
+
+/* used by rand(),nrand() */
+long
+lrand(void)
+{
+ /* xoroshiro128+ algorithm */
+ static int seeded = 0;
+ static uvlong s[2];
+ static Lock lk;
+ ulong r;
+
+ if(seeded == 0){
+ randomread(s, sizeof(s));
+ seeded = (s[0] | s[1]) != 0;
+ }
+
+ lock(&lk);
+ r = (s[0] + s[1]) >> 33;
+ s[1] ^= s[0];
+ s[0] = (s[0] << 55 | s[0] >> 9) ^ s[1] ^ (s[1] << 14);
+ s[1] = (s[1] << 36 | s[1] >> 28);
+ unlock(&lk);
+
+ return r;
+}