tinygo/src/machine/machine_stm32_rng.go
deadprogram e1df2510d4 machine/stm32f4, stm32f7, stm32l4: implement TRNG for randomness
Signed-off-by: deadprogram <ron@hybridgroup.com>
2021-12-15 11:38:40 +01:00

29 строки
512 Б
Go

//go:build stm32f4 || stm32f7 || stm32l4
// +build stm32f4 stm32f7 stm32l4
package machine
import "device/stm32"
var rngInitDone = false
const RNG_MAX_READ_RETRIES = 1000
// GetRNG returns 32 bits of cryptographically secure random data
func GetRNG() (uint32, error) {
if !rngInitDone {
initRNG()
rngInitDone = true
}
cnt := RNG_MAX_READ_RETRIES
for !stm32.RNG.SR.HasBits(stm32.RNG_SR_DRDY) {
cnt--
if cnt == 0 {
return 0, ErrTimeoutRNG
}
}
ret := stm32.RNG.DR.Get()
return ret, nil
}