2017-05-19 01:02:19 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 Fundacion Inria Chile
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @{
|
|
|
|
* @ingroup net
|
|
|
|
* @file
|
|
|
|
* @brief Implementation of OpenThread random platform abstraction
|
|
|
|
*
|
|
|
|
* @author Jose Ignacio Alamos <jialamos@uc.cl>
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#include "openthread/platform/random.h"
|
|
|
|
#include "periph/cpuid.h"
|
|
|
|
#include "random.h"
|
|
|
|
|
2020-10-22 11:35:04 +02:00
|
|
|
#define ENABLE_DEBUG 0
|
2017-05-19 01:02:19 +02:00
|
|
|
#include "debug.h"
|
|
|
|
|
|
|
|
/* init random */
|
|
|
|
void ot_random_init(void)
|
|
|
|
{
|
|
|
|
#ifdef CPUID_LEN
|
|
|
|
char cpu_id[CPUID_LEN];
|
|
|
|
cpuid_get(cpu_id);
|
|
|
|
uint32_t seed = 0;
|
|
|
|
for (unsigned i = 0; i < CPUID_LEN; i++) {
|
|
|
|
seed += cpu_id[i];
|
|
|
|
}
|
|
|
|
random_init(seed);
|
|
|
|
#else
|
|
|
|
#error "CPU not supported (current CPU doesn't provide CPUID, required for entropy)"
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
/* OpenThread will call this to get a random number */
|
|
|
|
uint32_t otPlatRandomGet(void)
|
|
|
|
{
|
|
|
|
uint32_t rand_val = random_uint32();
|
|
|
|
|
|
|
|
DEBUG("otPlatRandomGet: %i\n", (int) rand_val);
|
|
|
|
return rand_val;
|
|
|
|
}
|
2018-06-12 17:40:27 +02:00
|
|
|
|
|
|
|
otError otPlatRandomGetTrue(uint8_t *aOutput, uint16_t aOutputLength)
|
|
|
|
{
|
|
|
|
for (uint16_t index = 0; index < aOutputLength; index++) {
|
|
|
|
aOutput[index] = 0;
|
|
|
|
uint32_t rand_val = random_uint32();
|
|
|
|
aOutput[index] = (uint8_t) rand_val;
|
|
|
|
}
|
|
|
|
return OT_ERROR_NONE;
|
|
|
|
}
|