commit | 921e542ce0721ee8f687b5f36a9002016be6f996 | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <[email protected]> | Sat Mar 05 04:05:27 2022 +0000 |
committer | Android Build Coastguard Worker <[email protected]> | Sat Mar 05 04:05:27 2022 +0000 |
tree | 7f215f77477d12c6dfd9ac8c21badfa0038ba77c | |
parent | 894bc7c53a1bc23b0d1b1653c3d4b3bfa89a7425 [diff] | |
parent | 67ee42f84fb56bd3a9278b1062bc12f6639988ae [diff] |
Snap for 8254899 from 67ee42f84fb56bd3a9278b1062bc12f6639988ae to tm-d1-release Change-Id: I6efaf9cf75791cc52c047a41a27a2b0c1bba62d1
A Rust library for retrieving random data from (operating) system source. It is assumed that system always provides high-quality cryptographically secure random data, ideally backed by hardware entropy sources. This crate derives its name from Linux‘s getrandom
function, but is cross platform, roughly supporting the same set of platforms as Rust’s std
lib.
This is a low-level API. Most users should prefer using high-level random-number library like rand
.
Add this to your Cargo.toml
:
[dependencies] getrandom = "0.2"
Then invoke the getrandom
function:
fn get_random_buf() -> Result<[u8; 32], getrandom::Error> { let mut buf = [0u8; 32]; getrandom::getrandom(&mut buf)?; Ok(buf) }
For more information about supported targets, entropy sources, no_std
targets, crate features, WASM support and Custom RNGs see the getrandom
documentation and getrandom::Error
documentation.
This crate requires Rust 1.34.0 or later.
The getrandom
library is distributed under either of
at your option.