blob: c4eb44c133bb836e4b6d30ba497639444f49610b [file] [log] [blame]
Denys Vlasenko3ea2e822009-10-09 20:59:04 +02001/* vi: set sw=4 ts=4: */
2/*
3 * $RANDOM support.
4 *
Denys Vlasenkoe3c6e192009-10-09 23:35:30 +02005 * Copyright (C) 2009 Denys Vlasenko
Denys Vlasenko3ea2e822009-10-09 20:59:04 +02006 *
Denys Vlasenko0ef64bd2010-08-16 20:14:46 +02007 * Licensed under GPLv2, see file LICENSE in this source tree.
Denys Vlasenko3ea2e822009-10-09 20:59:04 +02008 */
Denys Vlasenko73067272010-01-12 22:11:24 +01009#ifndef SHELL_RANDOM_H
10#define SHELL_RANDOM_H 1
11
12PUSH_AND_SET_FUNCTION_VISIBILITY_TO_HIDDEN
Denys Vlasenko3ea2e822009-10-09 20:59:04 +020013
14typedef struct random_t {
Denys Vlasenkofb183072014-03-13 12:52:43 +010015 /* State of random number generators: */
16
17 /* Galois LFSR (fast but weak) */
18 int32_t galois_LFSR; /* must be signed! */
19
20 /* LCG (fast but weak) */
21 uint32_t LCG;
22
23 /* 64-bit xorshift (fast, moderate strength) */
24 uint32_t xs64_x;
25 uint32_t xs64_y;
Denys Vlasenko3ea2e822009-10-09 20:59:04 +020026} random_t;
27
Denys Vlasenko76ace252009-10-12 15:25:01 +020028#define UNINITED_RANDOM_T(rnd) \
29 ((rnd)->galois_LFSR == 0)
30
Denys Vlasenko3ea2e822009-10-09 20:59:04 +020031#define INIT_RANDOM_T(rnd, nonzero, v) \
Denys Vlasenkofb183072014-03-13 12:52:43 +010032 ((rnd)->galois_LFSR = (rnd)->xs64_x = (nonzero), (rnd)->LCG = (rnd)->xs64_y = (v))
Denys Vlasenko3ea2e822009-10-09 20:59:04 +020033
Denys Vlasenko76ace252009-10-12 15:25:01 +020034#define CLEAR_RANDOM_T(rnd) \
35 ((rnd)->galois_LFSR = 0)
36
Denys Vlasenko3ea2e822009-10-09 20:59:04 +020037uint32_t next_random(random_t *rnd) FAST_FUNC;
Denys Vlasenko73067272010-01-12 22:11:24 +010038
39POP_SAVED_FUNCTION_VISIBILITY
40
41#endif