1// We only test the RDRAND-based RNG source on supported architectures.
2#![cfg(any(target_arch = "x86_64", target_arch = "x86"))]
3
4// rdrand.rs expects to be part of the getrandom main crate, so we need these
5// additional imports to get rdrand.rs to compile.
6use getrandom::Error;
7#[macro_use]
8extern crate cfg_if;
9#[path = "../src/rdrand.rs"]
10mod rdrand;
11#[path = "../src/util.rs"]
12mod util;
13
14// The rdrand implementation has the signature of getrandom_uninit(), but our
15// tests expect getrandom_impl() to have the signature of getrandom().
16fn getrandom_impl(dest: &mut [u8]) -> Result<(), Error> {
17 rdrand::getrandom_inner(unsafe { util::slice_as_uninit_mut(dest) })?;
18 Ok(())
19}
20mod common;
21