rustix/backend/linux_raw/thread/futex.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
bitflags::bitflags! {
/// `FUTEX_*` flags for use with the functions in [`futex`].
///
/// [`futex`]: mod@crate::thread::futex
#[repr(transparent)]
#[derive(Copy, Clone, Eq, PartialEq, Hash, Debug)]
pub struct Flags: u32 {
/// `FUTEX_PRIVATE_FLAG`
const PRIVATE = linux_raw_sys::general::FUTEX_PRIVATE_FLAG;
/// `FUTEX_CLOCK_REALTIME`
const CLOCK_REALTIME = linux_raw_sys::general::FUTEX_CLOCK_REALTIME;
// This deliberately lacks a `const _ = !0`, so that users can use
// `from_bits_truncate` to extract the `SocketFlags` from a flags
// value that also includes a `SocketType`.
}
}
/// `FUTEX_*` operations for use with the futex syscall wrappers.
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
#[repr(u32)]
pub(crate) enum Operation {
/// `FUTEX_WAIT`
Wait = linux_raw_sys::general::FUTEX_WAIT,
/// `FUTEX_WAKE`
Wake = linux_raw_sys::general::FUTEX_WAKE,
/// `FUTEX_FD`
Fd = linux_raw_sys::general::FUTEX_FD,
/// `FUTEX_REQUEUE`
Requeue = linux_raw_sys::general::FUTEX_REQUEUE,
/// `FUTEX_CMP_REQUEUE`
CmpRequeue = linux_raw_sys::general::FUTEX_CMP_REQUEUE,
/// `FUTEX_WAKE_OP`
WakeOp = linux_raw_sys::general::FUTEX_WAKE_OP,
/// `FUTEX_LOCK_PI`
LockPi = linux_raw_sys::general::FUTEX_LOCK_PI,
/// `FUTEX_UNLOCK_PI`
UnlockPi = linux_raw_sys::general::FUTEX_UNLOCK_PI,
/// `FUTEX_TRYLOCK_PI`
TrylockPi = linux_raw_sys::general::FUTEX_TRYLOCK_PI,
/// `FUTEX_WAIT_BITSET`
WaitBitset = linux_raw_sys::general::FUTEX_WAIT_BITSET,
/// `FUTEX_WAKE_BITSET`
WakeBitset = linux_raw_sys::general::FUTEX_WAKE_BITSET,
/// `FUTEX_WAIT_REQUEUE_PI`
WaitRequeuePi = linux_raw_sys::general::FUTEX_WAIT_REQUEUE_PI,
/// `FUTEX_CMP_REQUEUE_PI`
CmpRequeuePi = linux_raw_sys::general::FUTEX_CMP_REQUEUE_PI,
/// `FUTEX_LOCK_PI2`
LockPi2 = linux_raw_sys::general::FUTEX_LOCK_PI2,
}
/// `FUTEX_*` operations for use with the [`futex`] function.
///
/// [`futex`]: fn@crate::thread::futex
// TODO: Deprecate this now that we have a new typed API.
/*
#[deprecated(
since = "0.38.35",
note = "
The `futex` function and `FutexOperation` enum are deprecated. There are
individual functions available to perform futex operations with improved
type safety. See the `rustix::thread::futex` module."
)]
*/
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
#[repr(u32)]
pub enum FutexOperation {
/// `FUTEX_WAIT`
Wait = linux_raw_sys::general::FUTEX_WAIT,
/// `FUTEX_WAKE`
Wake = linux_raw_sys::general::FUTEX_WAKE,
/// `FUTEX_FD`
Fd = linux_raw_sys::general::FUTEX_FD,
/// `FUTEX_REQUEUE`
Requeue = linux_raw_sys::general::FUTEX_REQUEUE,
/// `FUTEX_CMP_REQUEUE`
CmpRequeue = linux_raw_sys::general::FUTEX_CMP_REQUEUE,
/// `FUTEX_WAKE_OP`
WakeOp = linux_raw_sys::general::FUTEX_WAKE_OP,
/// `FUTEX_LOCK_PI`
LockPi = linux_raw_sys::general::FUTEX_LOCK_PI,
/// `FUTEX_UNLOCK_PI`
UnlockPi = linux_raw_sys::general::FUTEX_UNLOCK_PI,
/// `FUTEX_TRYLOCK_PI`
TrylockPi = linux_raw_sys::general::FUTEX_TRYLOCK_PI,
/// `FUTEX_WAIT_BITSET`
WaitBitset = linux_raw_sys::general::FUTEX_WAIT_BITSET,
}
/// `FUTEX_WAITERS`
pub const WAITERS: u32 = linux_raw_sys::general::FUTEX_WAITERS;
/// `FUTEX_OWNER_DIED`
pub const OWNER_DIED: u32 = linux_raw_sys::general::FUTEX_OWNER_DIED;