hdt: Removing builting sleep support in say
[syslinux.git] / com32 / lib / lrand48.c
blobff496ecd0f236abd1bb9caee43607d7cabd04d16
1 /*
2 * lrand48.c
3 */
5 #include <stdlib.h>
6 #include <stdint.h>
8 unsigned short __rand48_seed[3];
10 long jrand48(unsigned short xsubi[3])
12 uint64_t x;
14 /* The xsubi[] array is littleendian by spec */
15 x = (uint64_t) xsubi[0] +
16 ((uint64_t) xsubi[1] << 16) + ((uint64_t) xsubi[2] << 32);
18 x = (0x5deece66dULL * x) + 0xb;
20 xsubi[0] = (unsigned short)x;
21 xsubi[1] = (unsigned short)(x >> 16);
22 xsubi[2] = (unsigned short)(x >> 32);
24 return (long)(int32_t) (x >> 16);
27 long mrand48(void)
29 return jrand48(__rand48_seed);
32 long nrand48(unsigned short xsubi[3])
34 return (long)((uint32_t) jrand48(xsubi) >> 1);
37 long lrand48(void)
39 return (long)((uint32_t) mrand48() >> 1);