20#if defined(__ZEPHYR__)
21#include <zephyr/random/random.h>
22#elif defined(HAVE_GETRANDOM)
23#include <sys/random.h>
24#elif defined(WITH_CONTIKI)
25#include "lib/csprng.h"
30#if defined(MBEDTLS_ENTROPY_HARDWARE_ALT)
31#include <entropy_poll.h>
36errno_t __cdecl rand_s(_Out_
unsigned int *_RandomValue);
43coap_prng_impl(
unsigned char *buf,
size_t len) {
50 for (i = 0; i < len && i < 4; i++) {
78#if defined(WITH_LWIP) && defined(LWIP_RAND)
87 unsigned char *buf = (
unsigned char *)bufp;
88 u32_t v = LWIP_RAND();
90 while (len >
sizeof(v)) {
91 memcpy(buf, &v,
sizeof(v));
109#if defined(MBEDTLS_ENTROPY_HARDWARE_ALT)
111 return (mbedtls_hardware_poll(NULL, buf, len, NULL) ? 0 : 1);
113#elif defined(__ZEPHYR__)
115 if (!buf || len == 0) {
119 sys_rand_get(buf, len);
122#elif defined(HAVE_GETRANDOM)
123 return (getrandom(buf, len, 0) > 0) ? 1 : 0;
125#elif defined(HAVE_RANDOM)
126#define RAND_BYTES (RAND_MAX >= 0xffffff ? 3 : (RAND_MAX >= 0xffff ? 2 : 1))
127 unsigned char *dst = (
unsigned char *)buf;
130 uint8_t byte_counter = RAND_BYTES;
131 uint32_t r_v = random();
138 if (--byte_counter) {
142 byte_counter = RAND_BYTES;
147#elif defined(RIOT_VERSION)
149 random_bytes(buf, len);
152#elif defined(WITH_CONTIKI)
153 return csprng_rand(buf, len);
156 return coap_prng_impl(buf,len);
160#error "CVE-2021-34430: using rand() for crypto randoms is not secure!"
161#error "Please update you C-library and rerun the auto-configuration."
162 unsigned char *dst = (
unsigned char *)buf;
164 *dst++ = rand() & 0xFF;
182#elif defined(HAVE_RANDOM)
Library specific build wrapper for coap_internal.h.
static int coap_prng_default(void *buf, size_t len)
static coap_rand_func_t rand_func
void coap_prng_init_lkd(unsigned int seed)
Seeds the default random number generation function with the given seed.
int coap_prng_lkd(void *buf, size_t len)
Fills buf with len random bytes using the default pseudo random number generator.
int(* coap_rand_func_t)(void *out, size_t len)
Data type for random number generator function.
void coap_set_prng(coap_rand_func_t rng)
Replaces the current random number generation function with the default function rng.
COAP_API int coap_prng(void *buf, size_t len)
Fills buf with len random bytes using the default pseudo random number generator.
COAP_API void coap_prng_init(unsigned int seed)
Seeds the default random number generation function with the given seed.
#define coap_lock_unlock()
Dummy for no thread-safe code.
#define coap_lock_lock(failed)
Dummy for no thread-safe code.
#define COAP_STATIC_INLINE