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;
58
59pub const FUTEX_WAIT: usize = 0;
60pub const FUTEX_WAKE: usize = 1;
61pub const FUTEX_REQUEUE: usize = 2;
62pub const FUTEX_WAIT64: usize = 3;
63
64bitflags::bitflags! {
66 #[derive(Clone, Copy, Debug)]
67 pub struct SendFdFlags: usize {
68 const EXCLUSIVE = 1;
74
75 const CLONE = 2;
78 }
79}
80bitflags::bitflags! {
81 #[derive(Clone, Copy, Debug)]
82 pub struct FobtainFdFlags: usize {
83 const MANUAL_FD = 1;
87
88 const EXCLUSIVE = 2;
91
92 const UPPER_TBL = 4;
94
95 const CLOEXEC = 8;
97
98 }
101}
102bitflags::bitflags! {
103 #[derive(Clone, Copy, Debug)]
104 pub struct RecvFdFlags: usize {
105 const MANUAL_FD = 1;
109
110 const UPPER_TBL = 2;
112
113 const CLOEXEC = 4;
115 }
116}
117bitflags::bitflags! {
118 #[derive(Clone, Copy, Debug)]
119 pub struct FmoveFdFlags: usize {
120 const EXCLUSIVE = 1;
126
127 const CLONE = 2;
130 }
131}
132
133bitflags! {
134 pub struct MapFlags: usize {
135 const PROT_NONE = 0x0000_0000;
138
139 const PROT_EXEC = 0x0001_0000;
140 const PROT_WRITE = 0x0002_0000;
141 const PROT_READ = 0x0004_0000;
142
143 const MAP_SHARED = 0x0001;
144 const MAP_PRIVATE = 0x0002;
145
146 const MAP_FIXED = 0x0004;
147 const MAP_FIXED_NOREPLACE = 0x000C;
148
149 const MAP_LAZY = 0x0010;
161 }
162}
163bitflags! {
164 pub struct MunmapFlags: usize {
165 const NEEDS_SYNC = 1;
170 }
171}
172
173pub const MODE_TYPE: u16 = 0xF000;
174pub const MODE_DIR: u16 = 0x4000;
175pub const MODE_FILE: u16 = 0x8000;
176pub const MODE_SYMLINK: u16 = 0xA000;
177pub const MODE_FIFO: u16 = 0x1000;
178pub const MODE_CHR: u16 = 0x2000;
179pub const MODE_SOCK: u16 = 0xC000;
180
181pub const MODE_PERM: u16 = 0x0FFF;
182pub const MODE_SETUID: u16 = 0o4000;
183pub const MODE_SETGID: u16 = 0o2000;
184
185pub const O_RDONLY: usize = 0x0001_0000;
186pub const O_WRONLY: usize = 0x0002_0000;
187pub const O_RDWR: usize = 0x0003_0000;
188pub const O_NONBLOCK: usize = 0x0004_0000;
189pub const O_APPEND: usize = 0x0008_0000;
190pub const O_SHLOCK: usize = 0x0010_0000;
191pub const O_EXLOCK: usize = 0x0020_0000;
192pub const O_ASYNC: usize = 0x0040_0000;
193pub const O_FSYNC: usize = 0x0080_0000;
194pub const O_CREAT: usize = 0x0200_0000;
195pub const O_TRUNC: usize = 0x0400_0000;
196pub const O_EXCL: usize = 0x0800_0000;
197pub const O_DIRECTORY: usize = 0x1000_0000;
198pub const O_STAT: usize = 0x2000_0000;
199pub const O_SYMLINK: usize = 0x4000_0000;
200pub const O_NOFOLLOW: usize = 0x8000_0000;
201pub const O_ACCMODE: usize = O_RDONLY | O_WRONLY | O_RDWR;
202pub const O_FCNTL_MASK: usize = O_NONBLOCK | O_APPEND | O_ASYNC | O_FSYNC;
203
204pub const AT_REMOVEDIR: usize = 0x200;
206
207#[derive(Clone, Copy, Debug, Default, Eq, PartialEq)]
211#[repr(usize)]
212pub enum ContextStatus {
213 Runnable,
214 Blocked,
215 NotYetStarted,
216 Dead,
217 ForceKilled,
218 Stopped,
219 UnhandledExcp,
220 #[default]
221 Other, }
223
224#[derive(Clone, Copy, Debug, Eq, PartialEq)]
225#[repr(usize)]
226pub enum ContextVerb {
227 Stop = 1,
228 Unstop = 2,
229 Interrupt = 3,
230 ForceKill = usize::MAX,
231}
232impl ContextVerb {
233 pub fn try_from_raw(raw: usize) -> Option<Self> {
234 Some(match raw {
235 1 => Self::Stop,
236 2 => Self::Unstop,
237 3 => Self::Interrupt,
238 usize::MAX => Self::ForceKill,
239 _ => return None,
240 })
241 }
242}
243
244#[derive(Clone, Copy, Debug, Eq, PartialEq)]
246#[repr(u8)]
247pub enum AddrSpaceVerb {
248 MmapMin = 255,
249}
250impl AddrSpaceVerb {
251 pub fn try_from_raw(verb: u8) -> Option<Self> {
252 Some(match verb {
253 255 => Self::MmapMin,
254
255 _ => return None,
256 })
257 }
258}
259
260#[derive(Clone, Copy, Debug, Eq, PartialEq)]
262#[repr(u8)]
263pub enum ProcSchemeVerb {
264 RegsInt = 250,
265 RegsFloat = 251,
266 RegsEnv = 252,
267 SchedAffinity = 253,
268 Start = 254,
269 Iopl = 255,
270}
271impl ProcSchemeVerb {
272 pub fn try_from_raw(verb: u8) -> Option<Self> {
273 Some(match verb {
274 250 => Self::RegsInt,
275 251 => Self::RegsFloat,
276 252 => Self::RegsEnv,
277 253 => Self::SchedAffinity,
278 254 => Self::Start,
279 255 => Self::Iopl,
280 _ => return None,
281 })
282 }
283}
284
285#[derive(Clone, Copy, Debug, Eq, PartialEq)]
286pub enum FileTableVerb {
287 Close = 1,
288 Dup2 = 2,
289 Reserved1 = 3,
290 Resize = 4,
291}
292impl FileTableVerb {
293 pub fn try_from_raw(value: u8) -> Option<Self> {
294 Some(match value {
295 1 => Self::Close,
296 2 => Self::Dup2,
297 3 => Self::Reserved1,
298 4 => Self::Resize,
299 _ => return None,
300 })
301 }
302}
303
304#[derive(Clone, Copy, Debug, Eq, PartialEq)]
306#[repr(u64)]
307pub enum AcpiVerb {
308 ReadRxsdt = 1,
311 CheckShutdown = 2,
313}
314impl AcpiVerb {
315 pub const fn try_from_raw(value: u64) -> Option<Self> {
316 Some(match value {
317 1 => Self::ReadRxsdt,
318 2 => Self::CheckShutdown,
319 _ => return None,
320 })
321 }
322}
323
324#[derive(Clone, Copy, Debug, Eq, PartialEq)]
325#[repr(usize)]
326pub enum SchemeSocketCall {
327 ObtainFd = 0,
328 MoveFd = 1,
329}
330impl SchemeSocketCall {
331 pub fn try_from_raw(raw: usize) -> Option<Self> {
332 Some(match raw {
333 0 => Self::ObtainFd,
334 1 => Self::MoveFd,
335 _ => return None,
336 })
337 }
338}
339
340#[derive(Clone, Copy, Debug, Eq, PartialEq)]
341#[repr(usize)]
342#[non_exhaustive]
343pub enum FsCall {
344 Connect = 0,
345}
346impl FsCall {
347 pub fn try_from_raw(raw: usize) -> Option<Self> {
348 Some(match raw {
349 0 => Self::Connect,
350 _ => return None,
351 })
352 }
353}
354
355bitflags! {
356 pub struct PtraceFlags: u64 {
357 const PTRACE_STOP_PRE_SYSCALL = 0x0000_0000_0000_0001;
360 const PTRACE_STOP_POST_SYSCALL = 0x0000_0000_0000_0002;
362 const PTRACE_STOP_SINGLESTEP = 0x0000_0000_0000_0004;
365 const PTRACE_STOP_SIGNAL = 0x0000_0000_0000_0008;
368 const PTRACE_STOP_BREAKPOINT = 0x0000_0000_0000_0010;
371 const PTRACE_STOP_EXIT = 0x0000_0000_0000_0020;
373
374 const PTRACE_STOP_MASK = 0x0000_0000_0000_00FF;
375
376
377 const PTRACE_EVENT_CLONE = 0x0000_0000_0000_0100;
380
381 const PTRACE_EVENT_ADDRSPACE_SWITCH = 0x0000_0000_0000_0200;
383
384 const PTRACE_EVENT_MASK = 0x0000_0000_0000_0F00;
385
386 const PTRACE_FLAG_IGNORE = 0x0000_0000_0000_1000;
389
390 const PTRACE_FLAG_MASK = 0x0000_0000_0000_F000;
391 }
392}
393impl Deref for PtraceFlags {
394 type Target = [u8];
395 fn deref(&self) -> &Self::Target {
396 unsafe {
398 slice::from_raw_parts(&self.bits() as *const _ as *const u8, mem::size_of::<u64>())
399 }
400 }
401}
402
403pub const SEEK_SET: usize = 0;
404pub const SEEK_CUR: usize = 1;
405pub const SEEK_END: usize = 2;
406
407pub const SIGCHLD: usize = 17;
408pub const SIGTSTP: usize = 20;
409pub const SIGTTIN: usize = 21;
410pub const SIGTTOU: usize = 22;
411
412pub const ADDRSPACE_OP_MMAP: usize = 0;
413pub const ADDRSPACE_OP_MUNMAP: usize = 1;
414pub const ADDRSPACE_OP_MPROTECT: usize = 2;
415pub const ADDRSPACE_OP_TRANSFER: usize = 3;
416
417bitflags! {
418 pub struct MremapFlags: usize {
419 const FIXED = 1;
420 const FIXED_REPLACE = 3;
421 const KEEP_OLD = 1 << 2;
424 }
426}
427bitflags! {
428 pub struct RwFlags: u32 {
429 const NONBLOCK = 1;
430 const APPEND = 2;
431 }
434}
435bitflags! {
436 pub struct SigcontrolFlags: usize {
437 const INHIBIT_DELIVERY = 1;
441 }
442}
443bitflags! {
444 pub struct CallFlags: usize {
445 const RSVD0 = 1 << 0;
447 const RSVD1 = 1 << 1;
448 const RSVD2 = 1 << 2;
449 const RSVD3 = 1 << 3;
450 const RSVD4 = 1 << 4;
451 const RSVD5 = 1 << 5;
452 const RSVD6 = 1 << 6;
453 const RSVD7 = 1 << 7;
454
455 const CONSUME = 1 << 8;
457
458 const WRITE = 1 << 9;
459 const READ = 1 << 10;
460
461 const FD = 1 << 11;
463 const FD_EXCLUSIVE = 1 << 12;
465 const FD_CLONE = 1 << 13;
466 const FD_UPPER = 1 << 14;
467 const FD_CLOEXEC = 1 << 15;
468
469 const STD_FS = 1 << 16;
471
472 const MULTIPLE_FDS = 1 << 17;
474 }
475}
476
477#[repr(u8)]
478#[derive(Clone, Copy, Debug, PartialEq, Eq, PartialOrd, Ord)]
479pub enum StdFsCallKind {
480 Fchmod = 1,
482 Fchown = 2,
483 Getdents = 3,
484 Fstat = 4,
485 Fstatvfs = 5,
486 Fsync = 6,
487 Ftruncate = 7,
488 Futimens = 8,
489 Relpathat = 11,
492 Lock = 12,
493 Unlock = 13,
494 GetLock = 14,
495}
496
497impl StdFsCallKind {
498 pub fn try_from_raw(raw: u8) -> Option<Self> {
499 use StdFsCallKind::*;
500
501 Some(match raw {
503 1 => Fchmod,
504 2 => Fchown,
505 3 => Getdents,
506 4 => Fstat,
507 5 => Fstatvfs,
508 6 => Fsync,
509 7 => Ftruncate,
510 8 => Futimens,
511 11 => Relpathat,
514 12 => Lock,
515 13 => Unlock,
516 14 => GetLock,
517 _ => return None,
518 })
519 }
520}
521
522pub const UPPER_FDTBL_TAG: usize = 1 << (usize::BITS - 2);
524
525pub const EVENT_TIMEOUT_ID: usize = usize::MAX - 2;