2019-06-25 11:12:58 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2010-2014 Intel Corporation
|
2017-04-21 10:43:26 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _RTE_RANDOM_H_
|
|
|
|
#define _RTE_RANDOM_H_
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
*
|
|
|
|
* Pseudo-random Generators in RTE
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2020-06-18 16:55:50 +00:00
|
|
|
|
|
|
|
#include <rte_compat.h>
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Seed the pseudo-random generator.
|
|
|
|
*
|
|
|
|
* The generator is automatically seeded by the EAL init with a timer
|
|
|
|
* value. It may need to be re-seeded by the user with a real random
|
|
|
|
* value.
|
|
|
|
*
|
2020-06-18 16:55:50 +00:00
|
|
|
* This function is not multi-thread safe in regards to other
|
|
|
|
* rte_srand() calls, nor is it in relation to concurrent rte_rand()
|
|
|
|
* calls.
|
|
|
|
*
|
2017-04-21 10:43:26 +00:00
|
|
|
* @param seedval
|
|
|
|
* The value of the seed.
|
|
|
|
*/
|
2020-06-18 16:55:50 +00:00
|
|
|
void
|
|
|
|
rte_srand(uint64_t seedval);
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a pseudo-random value.
|
|
|
|
*
|
2020-06-18 16:55:50 +00:00
|
|
|
* The generator is not cryptographically secure.
|
|
|
|
*
|
|
|
|
* If called from lcore threads, this function is thread-safe.
|
2017-04-21 10:43:26 +00:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* A pseudo-random value between 0 and (1<<64)-1.
|
|
|
|
*/
|
2020-06-18 16:55:50 +00:00
|
|
|
uint64_t
|
|
|
|
rte_rand(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generates a pseudo-random number with an upper bound.
|
|
|
|
*
|
|
|
|
* This function returns an uniformly distributed (unbiased) random
|
|
|
|
* number less than a user-specified maximum value.
|
|
|
|
*
|
|
|
|
* If called from lcore threads, this function is thread-safe.
|
|
|
|
*
|
|
|
|
* @param upper_bound
|
|
|
|
* The upper bound of the generated number.
|
|
|
|
* @return
|
|
|
|
* A pseudo-random value between 0 and (upper_bound-1).
|
|
|
|
*/
|
|
|
|
__rte_experimental
|
|
|
|
uint64_t
|
|
|
|
rte_rand_max(uint64_t upper_bound);
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
#endif /* _RTE_RANDOM_H_ */
|