/* * Copyright (C) 2019 Gunar Schorcht * * 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 cpu_esp_common * @ingroup drivers_periph_hwrng * @{ * * @file * @brief Low-level random number generator driver implementation for ESP SoCs * * @author Gunar Schorcht * * @} */ #include "cpu.h" #include "periph_conf.h" #include "periph/hwrng.h" #define RNG_DATA_REG (*(volatile uint32_t *)RNG_DATA_REG_ADDR) void hwrng_init(void) { /* no need for initialization */ } void hwrng_read(void *buf, unsigned int num) { unsigned int count = 0; uint8_t *b = (uint8_t *)buf; while (count < num) { /* read next 4 bytes of random data */ uint32_t tmp = RNG_DATA_REG; /* copy data into result vector */ for (int i = 0; i < 4 && count < num; i++) { b[count++] = (uint8_t)tmp; tmp = tmp >> 8; } } } uint32_t hwrand(void) { uint32_t _tmp; hwrng_read(&_tmp, sizeof(uint32_t)); return _tmp; }