stm32/rng: Use Yasmarang for rng_get() if MCU doesn't have HW RNG.
This commit is contained in:
parent
cda964198a
commit
f68e722005
|
@ -60,4 +60,30 @@ STATIC mp_obj_t pyb_rng_get(void) {
|
||||||
}
|
}
|
||||||
MP_DEFINE_CONST_FUN_OBJ_0(pyb_rng_get_obj, pyb_rng_get);
|
MP_DEFINE_CONST_FUN_OBJ_0(pyb_rng_get_obj, pyb_rng_get);
|
||||||
|
|
||||||
|
#else // MICROPY_HW_ENABLE_RNG
|
||||||
|
|
||||||
|
// For MCUs that don't have an RNG we still need to provide a rng_get() function,
|
||||||
|
// eg for lwIP. A pseudo-RNG is not really ideal but we go with it for now. We
|
||||||
|
// don't want to use urandom's pRNG because then the user won't see a reproducible
|
||||||
|
// random stream.
|
||||||
|
|
||||||
|
// Yasmarang random number generator by Ilya Levin
|
||||||
|
// http://www.literatecode.com/yasmarang
|
||||||
|
STATIC uint32_t pyb_rng_yasmarang(void) {
|
||||||
|
static uint32_t pad = 0xeda4baba, n = 69, d = 233;
|
||||||
|
static uint8_t dat = 0;
|
||||||
|
|
||||||
|
pad += dat + d * n;
|
||||||
|
pad = (pad << 3) + (pad >> 29);
|
||||||
|
n = pad | 2;
|
||||||
|
d ^= (pad << 31) + (pad >> 1);
|
||||||
|
dat ^= (char)pad ^ (d >> 8) ^ 1;
|
||||||
|
|
||||||
|
return pad ^ (d << 5) ^ (pad >> 18) ^ (dat << 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t rng_get(void) {
|
||||||
|
return pyb_rng_yasmarang();
|
||||||
|
}
|
||||||
|
|
||||||
#endif // MICROPY_HW_ENABLE_RNG
|
#endif // MICROPY_HW_ENABLE_RNG
|
||||||
|
|
Loading…
Reference in New Issue