2019-04-25 18:15:44 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 ML!PA Consulting GmbH
|
|
|
|
*
|
|
|
|
* 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_sam0_common
|
|
|
|
* @ingroup drivers_periph_hwrng
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Low-level random number generator driver implementation
|
|
|
|
*
|
|
|
|
* @author Benjamin Valentin <benjamin.valentin@ml-pa.com>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "periph_conf.h"
|
|
|
|
#include "periph/hwrng.h"
|
|
|
|
|
|
|
|
void hwrng_init(void)
|
|
|
|
{
|
|
|
|
/* Enable the MCLK */
|
2024-06-10 16:45:34 +02:00
|
|
|
MCLK->APBCMASK.reg |= MCLK_APBCMASK_TRNG;
|
2019-04-25 18:15:44 +02:00
|
|
|
|
|
|
|
/* Enable the TRNG */
|
2024-06-10 16:45:34 +02:00
|
|
|
TRNG->CTRLA.reg |= TRNG_CTRLA_ENABLE;
|
|
|
|
|
2019-04-25 18:15:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t hwrand(void)
|
|
|
|
{
|
2024-06-10 16:45:34 +02:00
|
|
|
while (!(TRNG->INTFLAG.reg & TRNG_INTFLAG_DATARDY)) {}
|
2019-04-25 18:15:44 +02:00
|
|
|
return TRNG->DATA.reg;
|
|
|
|
}
|
|
|
|
|
|
|
|
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 = hwrand();
|
|
|
|
|
|
|
|
/* copy data into result vector */
|
|
|
|
for (int i = 0; i < 4 && count < num; i++) {
|
|
|
|
b[count++] = (uint8_t)tmp;
|
|
|
|
tmp = tmp >> 8;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|