1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/random/tinymt32.c

81 lines
1.7 KiB
C
Raw Normal View History

2015-11-27 13:42:40 +01:00
/**
* Copyright (C) 2015 Kaspar Schleiser <kaspar@schleiser.de>
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
2017-09-27 14:11:33 +02:00
/**
2015-11-27 13:42:40 +01:00
* @ingroup sys_random
* @{
* @file
*
* @brief Glue-code for tinymt32
*
* See https://github.com/MersenneTwister-Lab/TinyMT for details.
*
* @author Kaspar Schleiser <kaspar@schleiser.de>
* @}
*/
#include <stdint.h>
2017-09-27 14:11:33 +02:00
#include <string.h>
2015-11-27 13:42:40 +01:00
#include "tinymt32/tinymt32.h"
2017-09-27 14:11:33 +02:00
#define _ALIGNMENT_MASK (sizeof(uint32_t) - 1)
/* fits size to byte alignment */
static inline uint8_t *_align(uint8_t *buf)
{
return (uint8_t *)(((size_t) buf + _ALIGNMENT_MASK) & ~(_ALIGNMENT_MASK));
}
2015-11-27 13:42:40 +01:00
static tinymt32_t _random;
void random_init(uint32_t seed)
2015-11-27 13:42:40 +01:00
{
tinymt32_init(&_random, seed);
}
uint32_t random_uint32(void)
2015-11-27 13:42:40 +01:00
{
return tinymt32_generate_uint32(&_random);
}
2017-09-27 14:11:33 +02:00
void random_bytes(uint8_t *buf, size_t size)
{
size_t iter = size;
size_t diff = _align(buf) - buf;
uint32_t tmp;
/* Fill first <4 unaligned bytes */
if (diff) {
tmp = tinymt32_generate_uint32(&_random);
if (diff > size) {
diff = size;
}
memcpy(buf, &tmp, diff);
iter -= diff;
}
/* Fill aligned bytes */
while (iter >= sizeof(uint32_t)) {
*((uint32_t *) buf) = tinymt32_generate_uint32(&_random);
buf += sizeof(uint32_t);
iter -= sizeof(uint32_t);
}
/* Fill last bytes */
if (iter) {
tmp = tinymt32_generate_uint32(&_random);
memcpy(buf, &tmp, iter);
}
}
void random_init_by_array(uint32_t init_key[], int key_length)
{
tinymt32_init_by_array(&_random, init_key, key_length);
}