1use bitflags::bitflags as inner_bitflags;
2use core::{mem, ops::Deref, slice};
3
4macro_rules! bitflags {
5 (
6 $(#[$outer:meta])*
7 pub struct $BitFlags:ident: $T:ty {
8 $(
9 $(#[$inner:ident $($args:tt)*])*
10 const $Flag:ident = $value:expr;
11 )+
12 }
13 ) => {
14 inner_bitflags! {
16 #[derive(PartialEq, Eq, PartialOrd, Ord, Hash, Debug, Clone, Copy, Default)]
17 $(#[$outer])*
18 pub struct $BitFlags: $T {
19 $(
20 $(#[$inner $($args)*])*
21 const $Flag = $value;
22 )+
23 }
24 }
25
26 impl $BitFlags {
27 #[deprecated = "use the safe `from_bits_retain` method instead"]
28 pub unsafe fn from_bits_unchecked(bits: $T) -> Self {
29 Self::from_bits_retain(bits)
30 }
31 }
32
33 $(
36 $(#[$inner $($args)*])*
37 pub const $Flag: $BitFlags = $BitFlags::$Flag;
38 )+
39 }
40}
41
42pub const CLOCK_REALTIME: usize = 1;
43pub const CLOCK_MONOTONIC: usize = 4;
44
45bitflags! {
46 pub struct EventFlags: usize {
47 const EVENT_NONE = 0;
48 const EVENT_READ = 1;
49 const EVENT_WRITE = 2;
50 }
51}
52
53pub const F_DUPFD: usize = 0;
54pub const F_GETFD: usize = 1;
55pub const F_SETFD: usize = 2;
56pub const F_GETFL: usize = 3;
57pub const F_SETFL: usize = 4;
58pub const F_DUPFD_CLOEXEC: usize = 1030;
59
60pub const FUTEX_WAIT: usize = 0;
61pub const FUTEX_WAKE: usize = 1;
62pub const FUTEX_REQUEUE: usize = 2;
63pub const FUTEX_WAIT64: usize = 3;
64
65pub const SKMSG_FRETURNFD: usize = 0;
67
68pub const SKMSG_PROVIDE_MMAP: usize = 1;
70
71pub const SKMSG_FOBTAINFD: usize = 2;
73
74bitflags::bitflags! {
76 #[derive(Clone, Copy, Debug)]
77 pub struct SendFdFlags: usize {
78 const EXCLUSIVE = 1;
84
85 const CLONE = 2;
88 }
89}
90bitflags::bitflags! {
91 #[derive(Clone, Copy, Debug)]
92 pub struct FobtainFdFlags: usize {
93 const MANUAL_FD = 1;
97
98 const EXCLUSIVE = 2;
101
102 const UPPER_TBL = 4;
104
105 }
108}
109bitflags::bitflags! {
110 #[derive(Clone, Copy, Debug)]
111 pub struct RecvFdFlags: usize {
112 const MANUAL_FD = 1;
116
117 const UPPER_TBL = 2;
119 }
120}
121bitflags::bitflags! {
122 #[derive(Clone, Copy, Debug)]
123 pub struct FmoveFdFlags: usize {
124 const EXCLUSIVE = 1;
130
131 const CLONE = 2;
134 }
135}
136
137bitflags! {
138 pub struct MapFlags: usize {
139 const PROT_NONE = 0x0000_0000;
142
143 const PROT_EXEC = 0x0001_0000;
144 const PROT_WRITE = 0x0002_0000;
145 const PROT_READ = 0x0004_0000;
146
147 const MAP_SHARED = 0x0001;
148 const MAP_PRIVATE = 0x0002;
149
150 const MAP_FIXED = 0x0004;
151 const MAP_FIXED_NOREPLACE = 0x000C;
152
153 const MAP_LAZY = 0x0010;
165 }
166}
167bitflags! {
168 pub struct MunmapFlags: usize {
169 const NEEDS_SYNC = 1;
174 }
175}
176
177pub const MODE_TYPE: u16 = 0xF000;
178pub const MODE_DIR: u16 = 0x4000;
179pub const MODE_FILE: u16 = 0x8000;
180pub const MODE_SYMLINK: u16 = 0xA000;
181pub const MODE_FIFO: u16 = 0x1000;
182pub const MODE_CHR: u16 = 0x2000;
183pub const MODE_SOCK: u16 = 0xC000;
184
185pub const MODE_PERM: u16 = 0x0FFF;
186pub const MODE_SETUID: u16 = 0o4000;
187pub const MODE_SETGID: u16 = 0o2000;
188
189pub const O_RDONLY: usize = 0x0001_0000;
190pub const O_WRONLY: usize = 0x0002_0000;
191pub const O_RDWR: usize = 0x0003_0000;
192pub const O_NONBLOCK: usize = 0x0004_0000;
193pub const O_APPEND: usize = 0x0008_0000;
194pub const O_SHLOCK: usize = 0x0010_0000;
195pub const O_EXLOCK: usize = 0x0020_0000;
196pub const O_ASYNC: usize = 0x0040_0000;
197pub const O_FSYNC: usize = 0x0080_0000;
198pub const O_CLOEXEC: usize = 0x0100_0000;
199pub const O_CREAT: usize = 0x0200_0000;
200pub const O_TRUNC: usize = 0x0400_0000;
201pub const O_EXCL: usize = 0x0800_0000;
202pub const O_DIRECTORY: usize = 0x1000_0000;
203pub const O_STAT: usize = 0x2000_0000;
204pub const O_SYMLINK: usize = 0x4000_0000;
205pub const O_NOFOLLOW: usize = 0x8000_0000;
206pub const O_ACCMODE: usize = O_RDONLY | O_WRONLY | O_RDWR;
207pub const O_FCNTL_MASK: usize = O_NONBLOCK | O_APPEND | O_ASYNC | O_FSYNC;
208
209pub const AT_REMOVEDIR: usize = 0x200;
211
212#[derive(Clone, Copy, Debug, Default, Eq, PartialEq)]
216#[repr(usize)]
217pub enum ContextStatus {
218 Runnable,
219 Blocked,
220 NotYetStarted,
221 Dead,
222 ForceKilled,
223 Stopped,
224 UnhandledExcp,
225 #[default]
226 Other, }
228
229#[derive(Clone, Copy, Debug, Eq, PartialEq)]
230#[repr(usize)]
231pub enum ContextVerb {
232 Stop = 1,
233 Unstop = 2,
234 Interrupt = 3,
235 ForceKill = usize::MAX,
236}
237impl ContextVerb {
238 pub fn try_from_raw(raw: usize) -> Option<Self> {
239 Some(match raw {
240 1 => Self::Stop,
241 2 => Self::Unstop,
242 3 => Self::Interrupt,
243 usize::MAX => Self::ForceKill,
244 _ => return None,
245 })
246 }
247}
248
249#[derive(Clone, Copy, Debug, Eq, PartialEq)]
251#[repr(u8)]
252pub enum ProcSchemeVerb {
253 Iopl = 255,
254}
255impl ProcSchemeVerb {
256 pub fn try_from_raw(verb: u8) -> Option<Self> {
257 Some(match verb {
258 255 => Self::Iopl,
259 _ => return None,
260 })
261 }
262}
263
264#[derive(Clone, Copy, Debug, Eq, PartialEq)]
265#[repr(usize)]
266pub enum SchemeSocketCall {
267 ObtainFd = 0,
268 MoveFd = 1,
269}
270impl SchemeSocketCall {
271 pub fn try_from_raw(raw: usize) -> Option<Self> {
272 Some(match raw {
273 0 => Self::ObtainFd,
274 1 => Self::MoveFd,
275 _ => return None,
276 })
277 }
278}
279
280#[derive(Clone, Copy, Debug, Eq, PartialEq)]
281#[repr(usize)]
282#[non_exhaustive]
283pub enum FsCall {
284 Connect = 0,
285}
286impl FsCall {
287 pub fn try_from_raw(raw: usize) -> Option<Self> {
288 Some(match raw {
289 0 => Self::Connect,
290 _ => return None,
291 })
292 }
293}
294
295bitflags! {
296 pub struct PtraceFlags: u64 {
297 const PTRACE_STOP_PRE_SYSCALL = 0x0000_0000_0000_0001;
300 const PTRACE_STOP_POST_SYSCALL = 0x0000_0000_0000_0002;
302 const PTRACE_STOP_SINGLESTEP = 0x0000_0000_0000_0004;
305 const PTRACE_STOP_SIGNAL = 0x0000_0000_0000_0008;
308 const PTRACE_STOP_BREAKPOINT = 0x0000_0000_0000_0010;
311 const PTRACE_STOP_EXIT = 0x0000_0000_0000_0020;
313
314 const PTRACE_STOP_MASK = 0x0000_0000_0000_00FF;
315
316
317 const PTRACE_EVENT_CLONE = 0x0000_0000_0000_0100;
320
321 const PTRACE_EVENT_ADDRSPACE_SWITCH = 0x0000_0000_0000_0200;
323
324 const PTRACE_EVENT_MASK = 0x0000_0000_0000_0F00;
325
326 const PTRACE_FLAG_IGNORE = 0x0000_0000_0000_1000;
329
330 const PTRACE_FLAG_MASK = 0x0000_0000_0000_F000;
331 }
332}
333impl Deref for PtraceFlags {
334 type Target = [u8];
335 fn deref(&self) -> &Self::Target {
336 unsafe {
338 slice::from_raw_parts(&self.bits() as *const _ as *const u8, mem::size_of::<u64>())
339 }
340 }
341}
342
343pub const SEEK_SET: usize = 0;
344pub const SEEK_CUR: usize = 1;
345pub const SEEK_END: usize = 2;
346
347pub const SIGCHLD: usize = 17;
348pub const SIGTSTP: usize = 20;
349pub const SIGTTIN: usize = 21;
350pub const SIGTTOU: usize = 22;
351
352pub const ADDRSPACE_OP_MMAP: usize = 0;
353pub const ADDRSPACE_OP_MUNMAP: usize = 1;
354pub const ADDRSPACE_OP_MPROTECT: usize = 2;
355pub const ADDRSPACE_OP_TRANSFER: usize = 3;
356
357bitflags! {
358 pub struct MremapFlags: usize {
359 const FIXED = 1;
360 const FIXED_REPLACE = 3;
361 const KEEP_OLD = 1 << 2;
364 }
366}
367bitflags! {
368 pub struct RwFlags: u32 {
369 const NONBLOCK = 1;
370 const APPEND = 2;
371 }
374}
375bitflags! {
376 pub struct SigcontrolFlags: usize {
377 const INHIBIT_DELIVERY = 1;
381 }
382}
383bitflags! {
384 pub struct CallFlags: usize {
385 const RSVD0 = 1 << 0;
387 const RSVD1 = 1 << 1;
388 const RSVD2 = 1 << 2;
389 const RSVD3 = 1 << 3;
390 const RSVD4 = 1 << 4;
391 const RSVD5 = 1 << 5;
392 const RSVD6 = 1 << 6;
393 const RSVD7 = 1 << 7;
394
395 const CONSUME = 1 << 8;
397
398 const WRITE = 1 << 9;
399 const READ = 1 << 10;
400
401 const FD = 1 << 11;
403 const FD_EXCLUSIVE = 1 << 12;
405 const FD_CLONE = 1 << 13;
406 const FD_UPPER = 1 << 14;
407 }
408}
409
410pub const UPPER_FDTBL_TAG: usize = 1 << (usize::BITS - 2);