summaryrefslogtreecommitdiffstats
path: root/third_party/rust/getrandom/tests/rdrand.rs
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/rust/getrandom/tests/rdrand.rs')
-rw-r--r--third_party/rust/getrandom/tests/rdrand.rs20
1 files changed, 20 insertions, 0 deletions
diff --git a/third_party/rust/getrandom/tests/rdrand.rs b/third_party/rust/getrandom/tests/rdrand.rs
new file mode 100644
index 0000000000..25678683f3
--- /dev/null
+++ b/third_party/rust/getrandom/tests/rdrand.rs
@@ -0,0 +1,20 @@
+// We only test the RDRAND-based RNG source on supported architectures.
+#![cfg(any(target_arch = "x86_64", target_arch = "x86"))]
+
+// rdrand.rs expects to be part of the getrandom main crate, so we need these
+// additional imports to get rdrand.rs to compile.
+use getrandom::Error;
+#[macro_use]
+extern crate cfg_if;
+#[path = "../src/rdrand.rs"]
+mod rdrand;
+#[path = "../src/util.rs"]
+mod util;
+
+// The rdrand implementation has the signature of getrandom_uninit(), but our
+// tests expect getrandom_impl() to have the signature of getrandom().
+fn getrandom_impl(dest: &mut [u8]) -> Result<(), Error> {
+ rdrand::getrandom_inner(unsafe { util::slice_as_uninit_mut(dest) })?;
+ Ok(())
+}
+mod common;