| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- // Use hardware RNG peripheral
- // Working with HAL, LL Driver (untested)
- #ifdef STM32F4
- #include "stm32f4xx.h"
- static int
- hydro_random_init(void)
- {
- const char ctx[hydro_hash_CONTEXTBYTES] = { 'h', 'y', 'd', 'r', 'o', 'P', 'R', 'G' };
- hydro_hash_state st;
- uint16_t ebits = 0;
- __IO uint32_t tmpreg;
- // Enable RNG clock source
- SET_BIT(RCC->AHB2ENR, RCC_AHB2ENR_RNGEN);
- // Delay after an RCC peripheral clock enabling
- tmpreg = READ_BIT(RCC->AHB2ENR, RCC_AHB2ENR_RNGEN);
- UNUSED(tmpreg);
- // RNG Peripheral enable
- SET_BIT(RNG->CR, RNG_CR_RNGEN);
- hydro_hash_init(&st, ctx, NULL);
- while (ebits < 256) {
- while (!(READ_BIT(RNG->SR, RNG_SR_DRDY))) {
- }
- uint32_t r = RNG->DR;
- hydro_hash_update(&st, (const uint32_t*) &r, sizeof r);
- ebits += 32;
- }
- hydro_hash_final(&st, hydro_random_context.state, sizeof hydro_random_context.state);
- hydro_random_context.counter = ~LOAD64_LE(hydro_random_context.state);
- return 0;
- }
- #else
- # error SMT32 implementation missing!
- #endif
|