mirror of
https://github.com/tillitis/tillitis-key1.git
synced 2025-11-27 10:50:32 -05:00
- Add REUSE configuration - Add compliant licenses in LICENSES/ - Add copyright SPDX tags - Run REUSE complicance check in CI - Remove spdx-ensure
28 lines
656 B
C
28 lines
656 B
C
// SPDX-FileCopyrightText: 2024 Tillitis AB <tillitis.se>
|
|
// SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
#include "rng.h"
|
|
#include <tkey/tk1_mem.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
// clang-format off
|
|
static volatile uint32_t *trng_status = (volatile uint32_t *)TK1_MMIO_TRNG_STATUS;
|
|
static volatile uint32_t *trng_entropy = (volatile uint32_t *)TK1_MMIO_TRNG_ENTROPY;
|
|
// clang-format on
|
|
|
|
uint32_t rng_get_word(void)
|
|
{
|
|
while ((*trng_status & (1 << TK1_MMIO_TRNG_STATUS_READY_BIT)) == 0) {
|
|
}
|
|
return *trng_entropy;
|
|
}
|
|
|
|
uint32_t rng_xorwow(uint32_t state, uint32_t acc)
|
|
{
|
|
state ^= state << 13;
|
|
state ^= state >> 17;
|
|
state ^= state << 5;
|
|
state += acc;
|
|
return state;
|
|
}
|