2022-01-05 16:10:18 +00:00
|
|
|
#include "furi_hal_random.h"
|
2021-12-22 20:04:08 +00:00
|
|
|
#include <furi.h>
|
2022-01-05 16:10:18 +00:00
|
|
|
#include <furi_hal.h>
|
2021-12-22 20:04:08 +00:00
|
|
|
|
|
|
|
#include <stm32wbxx_ll_rng.h>
|
|
|
|
#include <stm32wbxx_ll_hsem.h>
|
|
|
|
|
|
|
|
#include <hw_conf.h>
|
|
|
|
|
|
|
|
uint32_t furi_hal_random_get() {
|
2022-01-05 16:10:18 +00:00
|
|
|
while(LL_HSEM_1StepLock(HSEM, CFG_HW_RNG_SEMID))
|
|
|
|
;
|
2021-12-22 20:04:08 +00:00
|
|
|
LL_RNG_Enable(RNG);
|
|
|
|
|
2022-01-05 16:10:18 +00:00
|
|
|
while(!LL_RNG_IsActiveFlag_DRDY(RNG))
|
|
|
|
;
|
2021-12-22 20:04:08 +00:00
|
|
|
|
2022-01-05 16:10:18 +00:00
|
|
|
if((LL_RNG_IsActiveFlag_CECS(RNG)) || (LL_RNG_IsActiveFlag_SECS(RNG))) {
|
2021-12-22 20:04:08 +00:00
|
|
|
furi_crash("TRNG error");
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t random_val = LL_RNG_ReadRandData32(RNG);
|
|
|
|
|
|
|
|
LL_RNG_Disable(RNG);
|
|
|
|
LL_HSEM_ReleaseLock(HSEM, CFG_HW_RNG_SEMID, 0);
|
|
|
|
|
|
|
|
return random_val;
|
|
|
|
}
|
|
|
|
|
|
|
|
void furi_hal_random_fill_buf(uint8_t* buf, uint32_t len) {
|
2022-01-05 16:10:18 +00:00
|
|
|
while(LL_HSEM_1StepLock(HSEM, CFG_HW_RNG_SEMID))
|
|
|
|
;
|
2021-12-22 20:04:08 +00:00
|
|
|
LL_RNG_Enable(RNG);
|
|
|
|
|
2022-01-05 16:10:18 +00:00
|
|
|
for(uint32_t i = 0; i < len; i += 4) {
|
|
|
|
while(!LL_RNG_IsActiveFlag_DRDY(RNG))
|
|
|
|
;
|
2021-12-22 20:04:08 +00:00
|
|
|
|
2022-01-05 16:10:18 +00:00
|
|
|
if((LL_RNG_IsActiveFlag_CECS(RNG)) || (LL_RNG_IsActiveFlag_SECS(RNG))) {
|
2021-12-22 20:04:08 +00:00
|
|
|
furi_crash("TRNG error");
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t random_val = LL_RNG_ReadRandData32(RNG);
|
|
|
|
|
2022-01-05 16:10:18 +00:00
|
|
|
uint8_t len_cur = ((i + 4) < len) ? (4) : (len - i);
|
2021-12-22 20:04:08 +00:00
|
|
|
memcpy(&buf[i], &random_val, len_cur);
|
|
|
|
}
|
|
|
|
|
|
|
|
LL_RNG_Disable(RNG);
|
|
|
|
LL_HSEM_ReleaseLock(HSEM, CFG_HW_RNG_SEMID, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void srand(unsigned seed) {
|
|
|
|
}
|
|
|
|
|
|
|
|
int rand() {
|
|
|
|
return (furi_hal_random_get() & RAND_MAX);
|
|
|
|
}
|