1 unstable release

0.1.0 Aug 24, 2024

#1407 in Algorithms

BSD-2-Clause

20KB
251 lines

Low-quality entropy generator for no_std crates

This crate provides a reliable entropy source to crates that cannot depend on the Rust standard library. The design goals for this crate are simplicity and ease of use.

The entropy generated is not suitable for security or cryptography (see Limitations and How It Works below for details), although it may be combined with other entropy sources to produce a higher security level. This crate may be used for testing or for all sort of randomizations where security is not a constraint.

Highlights

  • Zero external dependencies
  • No dependency on the Rust standard library: this is a no_std crate
  • Works on all modern architectures: x86, AArch64, RISC-V 64, LoongArch64

Usage and Examples

get() returns some entropy as a u64:

let e = poorentropy::get();

fill() and bytes() can be used to obtain the entropy as bytes.

Generally speaking, entropy sources should not be used directly, but should rather be used as a seed for a pseudo-random number generator. Here is an example using the rand crate:

use rand::RngCore;
use rand::SeedableRng;
use rand::rngs::SmallRng;

let mut seed = <SmallRng as SeedableRng>::Seed::default();
poorentropy::fill(&mut seed);
let mut rng = SmallRng::from_seed(seed);

// Use the `rng`...
let r = rng.next_u32();

How It Works

The crate works by reading the CPU "clock" or "cycle counter", and mixing it to produce a pseudo-random value.

This table describes how the CPU clock/counter value is obtained for each supported architecture:

Target Source
AArch64 cntvct_el0
LoongArch64 rdtime.d
RISC-V 64 rdcycle
x86 / x86_64 rdtsc

The value obtained from the CPU is also added to an internal counter, with the goal to avoid returning the same entropy values to concurrent threads that call get() at the same time.

The resulting value is then fed into the SplitMix64 generator to make it appear random.

Limitations

  • Because the crate relies on the CPU clock, the values that it produces may be easy to predict. As such, this crate alone may not be used for security applications, because attackers may be able to guess the entropy values produced. It can however be combined with other entropy sources to increase the security level.

  • This crate tries to make it hard for two threads in the same process to obtain the same entropy value. However no guarantees are made for two distinct processes.

  • On some CPUs, the clock may start from a fixed value at boot. As such, if this crates is used in applications that run early on boot (such as firmwares, bootloaders, or kernels), it is possible that the crate will yield the same entropy values at every boot.

  • On some CPUs, the clock may be disabled or reset at runtime, and this may result in very low-quality entropy values being returned.

No runtime deps