summaryrefslogtreecommitdiffstats
path: root/vendor/rustix/src/rand
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/rustix/src/rand')
-rw-r--r--vendor/rustix/src/rand/getrandom.rs21
-rw-r--r--vendor/rustix/src/rand/mod.rs7
2 files changed, 28 insertions, 0 deletions
diff --git a/vendor/rustix/src/rand/getrandom.rs b/vendor/rustix/src/rand/getrandom.rs
new file mode 100644
index 000000000..f5d7e365d
--- /dev/null
+++ b/vendor/rustix/src/rand/getrandom.rs
@@ -0,0 +1,21 @@
+use crate::{imp, io};
+
+/// `GRND_*`
+pub use imp::rand::types::GetRandomFlags;
+
+/// `getrandom(buf, flags)`—Reads a sequence of random bytes.
+///
+/// This is a very low-level API which may be difficult to use correctly. Most
+/// users should prefer to use [`getrandom`] or [`rand`] APIs instead.
+///
+/// [`getrandom`]: https://crates.io/crates/getrandom
+/// [`rand`]: https://crates.io/crates/rand
+///
+/// # References
+/// - [Linux]
+///
+/// [Linux]: https://man7.org/linux/man-pages/man2/getrandom.2.html
+#[inline]
+pub fn getrandom(buf: &mut [u8], flags: GetRandomFlags) -> io::Result<usize> {
+ imp::rand::syscalls::getrandom(buf, flags)
+}
diff --git a/vendor/rustix/src/rand/mod.rs b/vendor/rustix/src/rand/mod.rs
new file mode 100644
index 000000000..b8a1320a8
--- /dev/null
+++ b/vendor/rustix/src/rand/mod.rs
@@ -0,0 +1,7 @@
+//! Random-related operations.
+
+#[cfg(any(linux_raw, all(libc, target_os = "linux")))]
+mod getrandom;
+
+#[cfg(any(linux_raw, all(libc, target_os = "linux")))]
+pub use getrandom::{getrandom, GetRandomFlags};