Contiki-NG
Loading...
Searching...
No Matches
random.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2005, Swedish Institute of Computer Science
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 * 3. Neither the name of the Institute nor the names of its contributors
14 * may be used to endorse or promote products derived from this software
15 * without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27 * SUCH DAMAGE.
28 *
29 * This file is part of the Contiki operating system.
30 *
31 */
32
33/**
34 * \addtogroup lib
35 * @{
36 *
37 * \defgroup random Generation of non-cryptographic random numbers
38 * @{
39 *
40 * \file
41 * Header file for generating non-cryptographic random numbers.
42 * \author
43 * Konrad Krentz <konrad.krentz@gmail.com>
44 */
45
46#ifndef RANDOM_H_
47#define RANDOM_H_
48
49#include "contiki.h"
50#include <stdint.h>
51
52#ifdef RANDOM_CONF_PRNG
53#define RANDOM_PRNG RANDOM_CONF_PRNG
54#else /* RANDOM_CONF_PRNG */
55#define RANDOM_PRNG sfc32_prng
56#endif /* RANDOM_CONF_PRNG */
57
58/**
59 * Structure of PRNG drivers.
60 */
62
63 /**
64 * \brief Seeds the PRNG with a seed.
65 * \param seed The seed.
66 */
67 void (* seed)(uint64_t seed);
68
69 /**
70 * \brief Generates a 16-bit pseudo-random number.
71 * \return The 16-bit pseudo-random number.
72 */
73 uint_fast16_t (* rand)(void);
74};
75
76extern const struct random_prng RANDOM_PRNG;
77
78/*
79 * Seeds RANDOM_PRNG using the CSPRNG if enabled and else with the MAC address.
80 */
81void random_init(void);
82
83/*
84 * Calculate a pseudo random number between 0 and 65535.
85 *
86 * \return A pseudo-random number between 0 and 65535.
87 */
88static inline unsigned short
89random_rand(void)
90{
91 return RANDOM_PRNG.rand();
92}
93
94/* In gcc int rand() uses RAND_MAX and long random() uses RANDOM_MAX */
95/* Since random_rand casts to unsigned short, we'll use this maxmimum */
96#define RANDOM_RAND_MAX 65535U
97
98#endif /* RANDOM_H_ */
99
100/** @} */
101/** @} */
Structure of PRNG drivers.
Definition random.h:61
uint_fast16_t(* rand)(void)
Generates a 16-bit pseudo-random number.
Definition random.h:73
void(* seed)(uint64_t seed)
Seeds the PRNG with a seed.
Definition random.h:67