summaryrefslogtreecommitdiff
path: root/c_src/include/linux/random.h
diff options
context:
space:
mode:
authorKent Overstreet <kent.overstreet@linux.dev>2024-01-16 17:00:02 -0500
committerKent Overstreet <kent.overstreet@linux.dev>2024-01-16 17:17:23 -0500
commitb5fd066153c40a70a29caa1ea7987723ab687763 (patch)
tree6d43a8b0a90d549a54c65565ac96c92b3e84b594 /c_src/include/linux/random.h
parent06ff8b55b70fda44d91b31b5511fafd1680a8934 (diff)
Move c_src dirs back to toplevel
We just wanted c sourcefiles out of the top level, not c source directories. Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
Diffstat (limited to 'c_src/include/linux/random.h')
-rw-r--r--c_src/include/linux/random.h70
1 files changed, 0 insertions, 70 deletions
diff --git a/c_src/include/linux/random.h b/c_src/include/linux/random.h
deleted file mode 100644
index 3203d13c..00000000
--- a/c_src/include/linux/random.h
+++ /dev/null
@@ -1,70 +0,0 @@
-/*
- * include/linux/random.h
- *
- * Include file for the random number generator.
- */
-#ifndef _LINUX_RANDOM_H
-#define _LINUX_RANDOM_H
-
-#include <unistd.h>
-#include <sys/syscall.h>
-#include <linux/bug.h>
-#include <linux/log2.h>
-
-#ifdef SYS_getrandom
-static inline int getrandom(void *buf, size_t buflen, unsigned int flags)
-{
- return syscall(SYS_getrandom, buf, buflen, flags);
-}
-#else
-extern int urandom_fd;
-
-static inline int getrandom(void *buf, size_t buflen, unsigned int flags)
-{
- return read(urandom_fd, buf, buflen);
-}
-#endif
-
-static inline void get_random_bytes(void *buf, int nbytes)
-{
- BUG_ON(getrandom(buf, nbytes, 0) != nbytes);
-}
-
-#define get_random_type(type) \
-static inline type get_random_##type(void) \
-{ \
- type v; \
- \
- get_random_bytes(&v, sizeof(v)); \
- return v; \
-}
-
-get_random_type(int);
-get_random_type(long);
-get_random_type(u8);
-get_random_type(u16);
-get_random_type(u32);
-get_random_type(u64);
-
-static inline u32 get_random_u32_below(u32 ceil)
-{
- if (ceil <= 1)
- return 0;
- for (;;) {
- if (ceil <= 1U << 8) {
- u32 mult = ceil * get_random_u8();
- if (likely(is_power_of_2(ceil) || (u8)mult >= (1U << 8) % ceil))
- return mult >> 8;
- } else if (ceil <= 1U << 16) {
- u32 mult = ceil * get_random_u16();
- if (likely(is_power_of_2(ceil) || (u16)mult >= (1U << 16) % ceil))
- return mult >> 16;
- } else {
- u64 mult = (u64)ceil * get_random_u32();
- if (likely(is_power_of_2(ceil) || (u32)mult >= -ceil % ceil))
- return mult >> 32;
- }
- }
-}
-
-#endif /* _LINUX_RANDOM_H */