From 8ddc359780af4ceb54c38b891c6bfc7f865ac737 Mon Sep 17 00:00:00 2001 From: deadprogram Date: Wed, 18 Dec 2024 12:15:29 +0100 Subject: feature: make RNG implementation shared for rp2040/rp2350 Signed-off-by: deadprogram --- src/machine/machine_rp2040_rng.go | 41 --------------------------------------- src/machine/machine_rp2_rng.go | 41 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 41 deletions(-) delete mode 100644 src/machine/machine_rp2040_rng.go create mode 100644 src/machine/machine_rp2_rng.go diff --git a/src/machine/machine_rp2040_rng.go b/src/machine/machine_rp2040_rng.go deleted file mode 100644 index 1706785d0..000000000 --- a/src/machine/machine_rp2040_rng.go +++ /dev/null @@ -1,41 +0,0 @@ -//go:build rp2040 - -// Implementation based on code located here: -// https://github.com/raspberrypi/pico-sdk/blob/master/src/rp2_common/pico_lwip/random.c - -package machine - -import ( - "device/rp" -) - -const numberOfCycles = 32 - -// GetRNG returns 32 bits of semi-random data based on ring oscillator. -// -// Unlike some other implementations of GetRNG, these random numbers are not -// cryptographically secure and must not be used for cryptographic operations -// (nonces, etc). -func GetRNG() (uint32, error) { - var val uint32 - for i := 0; i < 4; i++ { - val = (val << 8) | uint32(roscRandByte()) - } - return val, nil -} - -var randomByte uint8 - -func roscRandByte() uint8 { - var poly uint8 - for i := 0; i < numberOfCycles; i++ { - if randomByte&0x80 != 0 { - poly = 0x35 - } else { - poly = 0 - } - randomByte = ((randomByte << 1) | uint8(rp.ROSC.GetRANDOMBIT()) ^ poly) - // TODO: delay a little because the random bit is a little slow - } - return randomByte -} diff --git a/src/machine/machine_rp2_rng.go b/src/machine/machine_rp2_rng.go new file mode 100644 index 000000000..e619f0500 --- /dev/null +++ b/src/machine/machine_rp2_rng.go @@ -0,0 +1,41 @@ +//go:build rp2040 || rp2350 + +// Implementation based on code located here: +// https://github.com/raspberrypi/pico-sdk/blob/master/src/rp2_common/pico_lwip/random.c + +package machine + +import ( + "device/rp" +) + +const numberOfCycles = 32 + +// GetRNG returns 32 bits of semi-random data based on ring oscillator. +// +// Unlike some other implementations of GetRNG, these random numbers are not +// cryptographically secure and must not be used for cryptographic operations +// (nonces, etc). +func GetRNG() (uint32, error) { + var val uint32 + for i := 0; i < 4; i++ { + val = (val << 8) | uint32(roscRandByte()) + } + return val, nil +} + +var randomByte uint8 + +func roscRandByte() uint8 { + var poly uint8 + for i := 0; i < numberOfCycles; i++ { + if randomByte&0x80 != 0 { + poly = 0x35 + } else { + poly = 0 + } + randomByte = ((randomByte << 1) | uint8(rp.ROSC.GetRANDOMBIT()) ^ poly) + // TODO: delay a little because the random bit is a little slow + } + return randomByte +} -- cgit v1.2.3