Sha256: 739266564e9e9dfc2b72aada6af1ad0974afd46b8607ed976ea7b24e95bc2061

Contents?: true

Size: 1.06 KB

Versions: 1

Compression:

Stored size: 1.06 KB

Contents

// 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

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
dualcone-1.0.0 vendor/libhydrogen/impl/random/stm32.h