File: lrand48.c

package info (click to toggle)
syslinux 3%3A6.04~git20190206.bf6db5b4%2Bdfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 16,912 kB
  • sloc: ansic: 189,344; asm: 5,148; pascal: 4,825; perl: 1,980; makefile: 1,973; python: 266; sh: 176; xml: 39
file content (40 lines) | stat: -rw-r--r-- 715 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/*
 * lrand48.c
 */

#include <stdlib.h>
#include <stdint.h>

unsigned short __rand48_seed[3];

long jrand48(unsigned short xsubi[3])
{
    uint64_t x;

    /* The xsubi[] array is littleendian by spec */
    x = (uint64_t) xsubi[0] +
	((uint64_t) xsubi[1] << 16) + ((uint64_t) xsubi[2] << 32);

    x = (0x5deece66dULL * x) + 0xb;

    xsubi[0] = (unsigned short)x;
    xsubi[1] = (unsigned short)(x >> 16);
    xsubi[2] = (unsigned short)(x >> 32);

    return (long)(int32_t) (x >> 16);
}

long mrand48(void)
{
    return jrand48(__rand48_seed);
}

long nrand48(unsigned short xsubi[3])
{
    return (long)((uint32_t) jrand48(xsubi) >> 1);
}

long lrand48(void)
{
    return (long)((uint32_t) mrand48() >> 1);
}