mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
65 lines
1.5 KiB
C
65 lines
1.5 KiB
C
|
/*
|
||
|
* Copyright (C) 2017 Bas Stottelaar <basstottelaar@gmail.com>
|
||
|
*
|
||
|
* 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_efm32_common
|
||
|
* @ingroup drivers_periph_hwrng
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief Low-level I2C driver implementation
|
||
|
*
|
||
|
* @author Bas Stottelaar <basstottelaar@gmail.com>
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#include "cpu.h"
|
||
|
|
||
|
#include "periph_conf.h"
|
||
|
#include "periph/hwrng.h"
|
||
|
|
||
|
#include "em_cmu.h"
|
||
|
|
||
|
#include <string.h>
|
||
|
|
||
|
void hwrng_init(void)
|
||
|
{
|
||
|
/* enable clocks */
|
||
|
CMU_ClockEnable(cmuClock_HFPER, true);
|
||
|
CMU_ClockEnable(cmuClock_TRNG0, true);
|
||
|
|
||
|
/* reset and initialize peripheral */
|
||
|
TRNG0->CONTROL = TRNG_CONTROL_ENABLE |
|
||
|
TRNG_CONTROL_REPCOUNTIEN |
|
||
|
TRNG_CONTROL_APT64IEN |
|
||
|
TRNG_CONTROL_APT4096IEN |
|
||
|
TRNG_CONTROL_PREIEN |
|
||
|
TRNG_CONTROL_ALMIEN;
|
||
|
|
||
|
/* wait for TRNG to become available */
|
||
|
while (TRNG0->FIFOLEVEL == 0) {}
|
||
|
}
|
||
|
|
||
|
void hwrng_read(void *buf, unsigned int num)
|
||
|
{
|
||
|
uint32_t *out_buf = (uint32_t *) buf;
|
||
|
uint32_t tmp;
|
||
|
|
||
|
/* read known good available data */
|
||
|
while (num >= 4) {
|
||
|
*out_buf++ = TRNG0->FIFO;
|
||
|
num -= 4;
|
||
|
}
|
||
|
|
||
|
/* read remaining data (not multiple of 4) */
|
||
|
if (num) {
|
||
|
tmp = TRNG0->FIFO;
|
||
|
memcpy((uint8_t *)out_buf, (const uint8_t *) &tmp, num);
|
||
|
}
|
||
|
}
|