aboutsummaryrefslogtreecommitdiff
path: root/src/prng/rand_r.c
blob: 459e579b5e7e4f921426a5e626137805d583c090 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <stdlib.h>

static unsigned temper(unsigned x)
{
	x ^= x>>11;
	x ^= x<<7 & 0x9D2C5680;
	x ^= x<<15 & 0xEFC60000;
	x ^= x>>18;
	return x;
}

int rand_r(unsigned *seed)
{
	return temper(*seed = *seed * 1103515245 + 12345)/2;
}


#ifdef TEST
int
main(void) {
	return 0;
}
#endif