• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //! Android-specific definitions for linux-like values
2 
3 pub type clock_t = ::c_long;
4 pub type time_t = ::c_long;
5 pub type suseconds_t = ::c_long;
6 pub type off_t = ::c_long;
7 pub type blkcnt_t = ::c_ulong;
8 pub type blksize_t = ::c_ulong;
9 pub type nlink_t = u32;
10 pub type useconds_t = u32;
11 pub type pthread_t = ::c_long;
12 pub type pthread_mutexattr_t = ::c_long;
13 pub type pthread_rwlockattr_t = ::c_long;
14 pub type pthread_barrierattr_t = ::c_int;
15 pub type pthread_condattr_t = ::c_long;
16 pub type pthread_key_t = ::c_int;
17 pub type fsfilcnt_t = ::c_ulong;
18 pub type fsblkcnt_t = ::c_ulong;
19 pub type nfds_t = ::c_uint;
20 pub type rlim_t = ::c_ulong;
21 pub type dev_t = ::c_ulong;
22 pub type ino_t = ::c_ulong;
23 pub type ino64_t = u64;
24 pub type __CPU_BITTYPE = ::c_ulong;
25 pub type idtype_t = ::c_int;
26 pub type loff_t = ::c_longlong;
27 pub type __kernel_loff_t = ::c_longlong;
28 pub type __kernel_pid_t = ::c_int;
29 
30 pub type __u8 = ::c_uchar;
31 pub type __u16 = ::c_ushort;
32 pub type __s16 = ::c_short;
33 pub type __u32 = ::c_uint;
34 pub type __s32 = ::c_int;
35 
36 // linux/elf.h
37 
38 pub type Elf32_Addr = u32;
39 pub type Elf32_Half = u16;
40 pub type Elf32_Off = u32;
41 pub type Elf32_Word = u32;
42 
43 pub type Elf64_Addr = u64;
44 pub type Elf64_Half = u16;
45 pub type Elf64_Off = u64;
46 pub type Elf64_Word = u32;
47 pub type Elf64_Xword = u64;
48 
49 pub type eventfd_t = u64;
50 
51 s! {
52     pub struct stack_t {
53         pub ss_sp: *mut ::c_void,
54         pub ss_flags: ::c_int,
55         pub ss_size: ::size_t
56     }
57 
58     pub struct __fsid_t {
59         __val: [::c_int; 2],
60     }
61 
62     pub struct msghdr {
63         pub msg_name: *mut ::c_void,
64         pub msg_namelen: ::socklen_t,
65         pub msg_iov: *mut ::iovec,
66         pub msg_iovlen: ::size_t,
67         pub msg_control: *mut ::c_void,
68         pub msg_controllen: ::size_t,
69         pub msg_flags: ::c_int,
70     }
71 
72     pub struct cmsghdr {
73         pub cmsg_len: ::size_t,
74         pub cmsg_level: ::c_int,
75         pub cmsg_type: ::c_int,
76     }
77 
78     pub struct termios {
79         pub c_iflag: ::tcflag_t,
80         pub c_oflag: ::tcflag_t,
81         pub c_cflag: ::tcflag_t,
82         pub c_lflag: ::tcflag_t,
83         pub c_line: ::cc_t,
84         pub c_cc: [::cc_t; ::NCCS],
85     }
86 
87     pub struct termios2 {
88         pub c_iflag: ::tcflag_t,
89         pub c_oflag: ::tcflag_t,
90         pub c_cflag: ::tcflag_t,
91         pub c_lflag: ::tcflag_t,
92         pub c_line: ::cc_t,
93         pub c_cc: [::cc_t; 19],
94         pub c_ispeed: ::speed_t,
95         pub c_ospeed: ::speed_t,
96     }
97 
98     pub struct mallinfo {
99         pub arena: ::size_t,
100         pub ordblks: ::size_t,
101         pub smblks: ::size_t,
102         pub hblks: ::size_t,
103         pub hblkhd: ::size_t,
104         pub usmblks: ::size_t,
105         pub fsmblks: ::size_t,
106         pub uordblks: ::size_t,
107         pub fordblks: ::size_t,
108         pub keepcost: ::size_t,
109     }
110 
111     pub struct flock {
112         pub l_type: ::c_short,
113         pub l_whence: ::c_short,
114         pub l_start: ::off_t,
115         pub l_len: ::off_t,
116         pub l_pid: ::pid_t,
117     }
118 
119     pub struct flock64 {
120         pub l_type: ::c_short,
121         pub l_whence: ::c_short,
122         pub l_start: ::__kernel_loff_t,
123         pub l_len: ::__kernel_loff_t,
124         pub l_pid: ::__kernel_pid_t,
125     }
126 
127     pub struct cpu_set_t {
128         #[cfg(target_pointer_width = "64")]
129         __bits: [__CPU_BITTYPE; 16],
130         #[cfg(target_pointer_width = "32")]
131         __bits: [__CPU_BITTYPE; 1],
132     }
133 
134     pub struct sem_t {
135         count: ::c_uint,
136         #[cfg(target_pointer_width = "64")]
137         __reserved: [::c_int; 3],
138     }
139 
140     pub struct exit_status {
141         pub e_termination: ::c_short,
142         pub e_exit: ::c_short,
143     }
144 
145     pub struct statvfs {
146         pub f_bsize: ::c_ulong,
147         pub f_frsize: ::c_ulong,
148         pub f_blocks: ::fsblkcnt_t,
149         pub f_bfree: ::fsblkcnt_t,
150         pub f_bavail: ::fsblkcnt_t,
151         pub f_files: ::fsfilcnt_t,
152         pub f_ffree: ::fsfilcnt_t,
153         pub f_favail: ::fsfilcnt_t,
154         pub f_fsid: ::c_ulong,
155         pub f_flag: ::c_ulong,
156         pub f_namemax: ::c_ulong,
157         #[cfg(target_pointer_width = "64")]
158         __f_reserved: [u32; 6],
159     }
160 
161     pub struct signalfd_siginfo {
162         pub ssi_signo: u32,
163         pub ssi_errno: i32,
164         pub ssi_code: i32,
165         pub ssi_pid: u32,
166         pub ssi_uid: u32,
167         pub ssi_fd: i32,
168         pub ssi_tid: u32,
169         pub ssi_band: u32,
170         pub ssi_overrun: u32,
171         pub ssi_trapno: u32,
172         pub ssi_status: i32,
173         pub ssi_int: i32,
174         pub ssi_ptr: ::c_ulonglong,
175         pub ssi_utime: ::c_ulonglong,
176         pub ssi_stime: ::c_ulonglong,
177         pub ssi_addr: ::c_ulonglong,
178         pub ssi_addr_lsb: u16,
179         _pad2: u16,
180         pub ssi_syscall: i32,
181         pub ssi_call_addr: u64,
182         pub ssi_arch: u32,
183         _pad: [u8; 28],
184     }
185 
186     pub struct itimerspec {
187         pub it_interval: ::timespec,
188         pub it_value: ::timespec,
189     }
190 
191     pub struct ucred {
192         pub pid: ::pid_t,
193         pub uid: ::uid_t,
194         pub gid: ::gid_t,
195     }
196 
197     pub struct genlmsghdr {
198         pub cmd: u8,
199         pub version: u8,
200         pub reserved: u16,
201     }
202 
203     pub struct nlmsghdr {
204         pub nlmsg_len: u32,
205         pub nlmsg_type: u16,
206         pub nlmsg_flags: u16,
207         pub nlmsg_seq: u32,
208         pub nlmsg_pid: u32,
209     }
210 
211     pub struct nlmsgerr {
212         pub error: ::c_int,
213         pub msg: nlmsghdr,
214     }
215 
216     pub struct nl_pktinfo {
217         pub group: u32,
218     }
219 
220     pub struct nl_mmap_req {
221         pub nm_block_size: ::c_uint,
222         pub nm_block_nr: ::c_uint,
223         pub nm_frame_size: ::c_uint,
224         pub nm_frame_nr: ::c_uint,
225     }
226 
227     pub struct nl_mmap_hdr {
228         pub nm_status: ::c_uint,
229         pub nm_len: ::c_uint,
230         pub nm_group: u32,
231         pub nm_pid: u32,
232         pub nm_uid: u32,
233         pub nm_gid: u32,
234     }
235 
236     pub struct nlattr {
237         pub nla_len: u16,
238         pub nla_type: u16,
239     }
240 
241     pub struct in6_pktinfo {
242         pub ipi6_addr: ::in6_addr,
243         pub ipi6_ifindex: ::c_int,
244     }
245 
246     pub struct inotify_event {
247         pub wd: ::c_int,
248         pub mask: u32,
249         pub cookie: u32,
250         pub len: u32
251     }
252 
253     pub struct sock_extended_err {
254         pub ee_errno: u32,
255         pub ee_origin: u8,
256         pub ee_type: u8,
257         pub ee_code: u8,
258         pub ee_pad: u8,
259         pub ee_info: u32,
260         pub ee_data: u32,
261     }
262 
263     pub struct regex_t {
264         re_magic: ::c_int,
265         re_nsub: ::size_t,
266         re_endp: *const ::c_char,
267         re_guts: *mut ::c_void,
268     }
269 
270     pub struct regmatch_t {
271         pub rm_so: ::ssize_t,
272         pub rm_eo: ::ssize_t,
273     }
274 
275     pub struct sockaddr_vm {
276         pub svm_family: ::sa_family_t,
277         pub svm_reserved1: ::c_ushort,
278         pub svm_port: ::c_uint,
279         pub svm_cid: ::c_uint,
280         pub svm_zero: [u8; 4]
281     }
282 
283     // linux/elf.h
284 
285     pub struct Elf32_Phdr {
286         pub p_type: Elf32_Word,
287         pub p_offset: Elf32_Off,
288         pub p_vaddr: Elf32_Addr,
289         pub p_paddr: Elf32_Addr,
290         pub p_filesz: Elf32_Word,
291         pub p_memsz: Elf32_Word,
292         pub p_flags: Elf32_Word,
293         pub p_align: Elf32_Word,
294     }
295 
296     pub struct Elf64_Phdr {
297         pub p_type: Elf64_Word,
298         pub p_flags: Elf64_Word,
299         pub p_offset: Elf64_Off,
300         pub p_vaddr: Elf64_Addr,
301         pub p_paddr: Elf64_Addr,
302         pub p_filesz: Elf64_Xword,
303         pub p_memsz: Elf64_Xword,
304         pub p_align: Elf64_Xword,
305     }
306 
307     // link.h
308 
309     pub struct dl_phdr_info {
310         #[cfg(target_pointer_width = "64")]
311         pub dlpi_addr: Elf64_Addr,
312         #[cfg(target_pointer_width = "32")]
313         pub dlpi_addr: Elf32_Addr,
314 
315         pub dlpi_name: *const ::c_char,
316 
317         #[cfg(target_pointer_width = "64")]
318         pub dlpi_phdr: *const Elf64_Phdr,
319         #[cfg(target_pointer_width = "32")]
320         pub dlpi_phdr: *const Elf32_Phdr,
321 
322         #[cfg(target_pointer_width = "64")]
323         pub dlpi_phnum: Elf64_Half,
324         #[cfg(target_pointer_width = "32")]
325         pub dlpi_phnum: Elf32_Half,
326 
327         // These fields were added in Android R
328         pub dlpi_adds: ::c_ulonglong,
329         pub dlpi_subs: ::c_ulonglong,
330         pub dlpi_tls_modid: ::size_t,
331         pub dlpi_tls_data: *mut ::c_void,
332     }
333 
334     // linux/filter.h
335     pub struct sock_filter {
336         pub code: ::__u16,
337         pub jt: ::__u8,
338         pub jf: ::__u8,
339         pub k: ::__u32,
340     }
341 
342     pub struct sock_fprog {
343         pub len: ::c_ushort,
344         pub filter: *mut sock_filter,
345     }
346 
347     // linux/seccomp.h
348     pub struct seccomp_data {
349         pub nr: ::c_int,
350         pub arch: ::__u32,
351         pub instruction_pointer: ::__u64,
352         pub args: [::__u64; 6],
353     }
354 
355     pub struct seccomp_metadata {
356         pub filter_off: ::__u64,
357         pub flags: ::__u64,
358     }
359 
360     pub struct ptrace_peeksiginfo_args {
361         pub off: ::__u64,
362         pub flags: ::__u32,
363         pub nr: ::__s32,
364     }
365 
366     // linux/input.h
367     pub struct input_event {
368         pub time: ::timeval,
369         pub type_: ::__u16,
370         pub code: ::__u16,
371         pub value: ::__s32,
372     }
373 
374     pub struct input_id {
375         pub bustype: ::__u16,
376         pub vendor: ::__u16,
377         pub product: ::__u16,
378         pub version: ::__u16,
379     }
380 
381     pub struct input_absinfo {
382         pub value: ::__s32,
383         pub minimum: ::__s32,
384         pub maximum: ::__s32,
385         pub fuzz: ::__s32,
386         pub flat: ::__s32,
387         pub resolution: ::__s32,
388     }
389 
390     pub struct input_keymap_entry {
391         pub flags: ::__u8,
392         pub len: ::__u8,
393         pub index: ::__u16,
394         pub keycode: ::__u32,
395         pub scancode: [::__u8; 32],
396     }
397 
398     pub struct input_mask {
399         pub type_: ::__u32,
400         pub codes_size: ::__u32,
401         pub codes_ptr: ::__u64,
402     }
403 
404     pub struct ff_replay {
405         pub length: ::__u16,
406         pub delay: ::__u16,
407     }
408 
409     pub struct ff_trigger {
410         pub button: ::__u16,
411         pub interval: ::__u16,
412     }
413 
414     pub struct ff_envelope {
415         pub attack_length: ::__u16,
416         pub attack_level: ::__u16,
417         pub fade_length: ::__u16,
418         pub fade_level: ::__u16,
419     }
420 
421     pub struct ff_constant_effect {
422         pub level: ::__s16,
423         pub envelope: ff_envelope,
424     }
425 
426     pub struct ff_ramp_effect {
427         pub start_level: ::__s16,
428         pub end_level: ::__s16,
429         pub envelope: ff_envelope,
430     }
431 
432     pub struct ff_condition_effect {
433         pub right_saturation: ::__u16,
434         pub left_saturation: ::__u16,
435 
436         pub right_coeff: ::__s16,
437         pub left_coeff: ::__s16,
438 
439         pub deadband: ::__u16,
440         pub center: ::__s16,
441     }
442 
443     pub struct ff_periodic_effect {
444         pub waveform: ::__u16,
445         pub period: ::__u16,
446         pub magnitude: ::__s16,
447         pub offset: ::__s16,
448         pub phase: ::__u16,
449 
450         pub envelope: ff_envelope,
451 
452         pub custom_len: ::__u32,
453         pub custom_data: *mut ::__s16,
454     }
455 
456     pub struct ff_rumble_effect {
457         pub strong_magnitude: ::__u16,
458         pub weak_magnitude: ::__u16,
459     }
460 
461     pub struct ff_effect {
462         pub type_: ::__u16,
463         pub id: ::__s16,
464         pub direction: ::__u16,
465         pub trigger: ff_trigger,
466         pub replay: ff_replay,
467         // FIXME this is actually a union
468         #[cfg(target_pointer_width = "64")]
469         pub u: [u64; 4],
470         #[cfg(target_pointer_width = "32")]
471         pub u: [u32; 7],
472     }
473 
474     // linux/uinput.h
475     pub struct uinput_ff_upload {
476         pub request_id: ::__u32,
477         pub retval: ::__s32,
478         pub effect: ff_effect,
479         pub old: ff_effect,
480     }
481 
482     pub struct uinput_ff_erase {
483         pub request_id: ::__u32,
484         pub retval: ::__s32,
485         pub effect_id: ::__u32,
486     }
487 
488     pub struct uinput_abs_setup {
489         pub code: ::__u16,
490         pub absinfo: input_absinfo,
491     }
492 
493     pub struct option {
494         pub name: *const ::c_char,
495         pub has_arg: ::c_int,
496         pub flag: *mut ::c_int,
497         pub val: ::c_int,
498     }
499 
500     pub struct __c_anonymous_ifru_map {
501         pub mem_start: ::c_ulong,
502         pub mem_end: ::c_ulong,
503         pub base_addr: ::c_ushort,
504         pub irq: ::c_uchar,
505         pub dma: ::c_uchar,
506         pub port: ::c_uchar,
507     }
508 
509     pub struct in6_ifreq {
510        pub ifr6_addr: ::in6_addr,
511        pub ifr6_prefixlen: u32,
512        pub ifr6_ifindex: ::c_int,
513    }
514 
515 }
516 
517 s_no_extra_traits! {
518     pub struct sockaddr_nl {
519         pub nl_family: ::sa_family_t,
520         nl_pad: ::c_ushort,
521         pub nl_pid: u32,
522         pub nl_groups: u32
523     }
524 
525     pub struct dirent {
526         pub d_ino: u64,
527         pub d_off: i64,
528         pub d_reclen: ::c_ushort,
529         pub d_type: ::c_uchar,
530         pub d_name: [::c_char; 256],
531     }
532 
533     pub struct dirent64 {
534         pub d_ino: u64,
535         pub d_off: i64,
536         pub d_reclen: ::c_ushort,
537         pub d_type: ::c_uchar,
538         pub d_name: [::c_char; 256],
539     }
540 
541     pub struct siginfo_t {
542         pub si_signo: ::c_int,
543         pub si_errno: ::c_int,
544         pub si_code: ::c_int,
545         pub _pad: [::c_int; 29],
546         _align: [usize; 0],
547     }
548 
549     pub struct lastlog {
550         ll_time: ::time_t,
551         ll_line: [::c_char; UT_LINESIZE],
552         ll_host: [::c_char; UT_HOSTSIZE],
553     }
554 
555     pub struct utmp {
556         pub ut_type: ::c_short,
557         pub ut_pid: ::pid_t,
558         pub ut_line: [::c_char; UT_LINESIZE],
559         pub ut_id: [::c_char; 4],
560         pub ut_user: [::c_char; UT_NAMESIZE],
561         pub ut_host: [::c_char; UT_HOSTSIZE],
562         pub ut_exit: exit_status,
563         pub ut_session: ::c_long,
564         pub ut_tv: ::timeval,
565         pub ut_addr_v6: [i32; 4],
566         unused: [::c_char; 20],
567     }
568 
569     pub struct sockaddr_alg {
570         pub salg_family: ::sa_family_t,
571         pub salg_type: [::c_uchar; 14],
572         pub salg_feat: u32,
573         pub salg_mask: u32,
574         pub salg_name: [::c_uchar; 64],
575     }
576 
577     pub struct uinput_setup {
578         pub id: input_id,
579         pub name: [::c_char; UINPUT_MAX_NAME_SIZE],
580         pub ff_effects_max: ::__u32,
581     }
582 
583     pub struct uinput_user_dev {
584         pub name: [::c_char; UINPUT_MAX_NAME_SIZE],
585         pub id: input_id,
586         pub ff_effects_max: ::__u32,
587         pub absmax: [::__s32; ABS_CNT],
588         pub absmin: [::__s32; ABS_CNT],
589         pub absfuzz: [::__s32; ABS_CNT],
590         pub absflat: [::__s32; ABS_CNT],
591     }
592 
593     /// WARNING: The `PartialEq`, `Eq` and `Hash` implementations of this
594     /// type are unsound and will be removed in the future.
595     #[deprecated(
596         note = "this struct has unsafe trait implementations that will be \
597                 removed in the future",
598         since = "0.2.80"
599     )]
600     pub struct af_alg_iv {
601         pub ivlen: u32,
602         pub iv: [::c_uchar; 0],
603     }
604 
605     pub struct prop_info {
606         __name: [::c_char; 32],
607         __serial: ::c_uint,
608         __value: [[::c_char; 4]; 23],
609     }
610 
611     #[cfg(libc_union)]
612     pub union __c_anonymous_ifr_ifru {
613         pub ifru_addr: ::sockaddr,
614         pub ifru_dstaddr: ::sockaddr,
615         pub ifru_broadaddr: ::sockaddr,
616         pub ifru_netmask: ::sockaddr,
617         pub ifru_hwaddr: ::sockaddr,
618         pub ifru_flags: ::c_short,
619         pub ifru_ifindex: ::c_int,
620         pub ifru_metric: ::c_int,
621         pub ifru_mtu: ::c_int,
622         pub ifru_map: __c_anonymous_ifru_map,
623         pub ifru_slave: [::c_char; ::IFNAMSIZ],
624         pub ifru_newname: [::c_char; ::IFNAMSIZ],
625         pub ifru_data: *mut ::c_char,
626     }
627 
628     pub struct ifreq {
629         /// interface name, e.g. "en0"
630         pub ifr_name: [::c_char; ::IFNAMSIZ],
631         #[cfg(libc_union)]
632         pub ifr_ifru: __c_anonymous_ifr_ifru,
633         #[cfg(not(libc_union))]
634         pub ifr_ifru: ::sockaddr,
635     }
636 
637     #[cfg(libc_union)]
638     pub union __c_anonymous_ifc_ifcu {
639         pub ifcu_buf: *mut ::c_char,
640         pub ifcu_req: *mut ::ifreq,
641     }
642 
643     /*  Structure used in SIOCGIFCONF request.  Used to retrieve interface
644     configuration for machine (useful for programs which must know all
645     networks accessible).  */
646     pub struct ifconf {
647         pub ifc_len: ::c_int,       /* Size of buffer.  */
648         #[cfg(libc_union)]
649         pub ifc_ifcu: __c_anonymous_ifc_ifcu,
650         #[cfg(not(libc_union))]
651         pub ifc_ifcu: *mut ::ifreq,
652     }
653 
654 }
655 
656 cfg_if! {
657     if #[cfg(feature = "extra_traits")] {
658         impl PartialEq for sockaddr_nl {
659             fn eq(&self, other: &sockaddr_nl) -> bool {
660                 self.nl_family == other.nl_family &&
661                     self.nl_pid == other.nl_pid &&
662                     self.nl_groups == other.nl_groups
663             }
664         }
665         impl Eq for sockaddr_nl {}
666         impl ::fmt::Debug for sockaddr_nl {
667             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
668                 f.debug_struct("sockaddr_nl")
669                     .field("nl_family", &self.nl_family)
670                     .field("nl_pid", &self.nl_pid)
671                     .field("nl_groups", &self.nl_groups)
672                     .finish()
673             }
674         }
675         impl ::hash::Hash for sockaddr_nl {
676             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
677                 self.nl_family.hash(state);
678                 self.nl_pid.hash(state);
679                 self.nl_groups.hash(state);
680             }
681         }
682 
683         impl PartialEq for dirent {
684             fn eq(&self, other: &dirent) -> bool {
685                 self.d_ino == other.d_ino
686                     && self.d_off == other.d_off
687                     && self.d_reclen == other.d_reclen
688                     && self.d_type == other.d_type
689                     && self
690                     .d_name
691                     .iter()
692                     .zip(other.d_name.iter())
693                     .all(|(a,b)| a == b)
694             }
695         }
696 
697         impl Eq for dirent {}
698 
699         impl ::fmt::Debug for dirent {
700             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
701                 f.debug_struct("dirent")
702                     .field("d_ino", &self.d_ino)
703                     .field("d_off", &self.d_off)
704                     .field("d_reclen", &self.d_reclen)
705                     .field("d_type", &self.d_type)
706                 // FIXME: .field("d_name", &self.d_name)
707                     .finish()
708             }
709         }
710 
711         impl ::hash::Hash for dirent {
712             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
713                 self.d_ino.hash(state);
714                 self.d_off.hash(state);
715                 self.d_reclen.hash(state);
716                 self.d_type.hash(state);
717                 self.d_name.hash(state);
718             }
719         }
720 
721         impl PartialEq for dirent64 {
722             fn eq(&self, other: &dirent64) -> bool {
723                 self.d_ino == other.d_ino
724                     && self.d_off == other.d_off
725                     && self.d_reclen == other.d_reclen
726                     && self.d_type == other.d_type
727                     && self
728                     .d_name
729                     .iter()
730                     .zip(other.d_name.iter())
731                     .all(|(a,b)| a == b)
732             }
733         }
734 
735         impl Eq for dirent64 {}
736 
737         impl ::fmt::Debug for dirent64 {
738             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
739                 f.debug_struct("dirent64")
740                     .field("d_ino", &self.d_ino)
741                     .field("d_off", &self.d_off)
742                     .field("d_reclen", &self.d_reclen)
743                     .field("d_type", &self.d_type)
744                 // FIXME: .field("d_name", &self.d_name)
745                     .finish()
746             }
747         }
748 
749         impl ::hash::Hash for dirent64 {
750             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
751                 self.d_ino.hash(state);
752                 self.d_off.hash(state);
753                 self.d_reclen.hash(state);
754                 self.d_type.hash(state);
755                 self.d_name.hash(state);
756             }
757         }
758 
759         impl PartialEq for siginfo_t {
760             fn eq(&self, other: &siginfo_t) -> bool {
761                 self.si_signo == other.si_signo
762                     && self.si_errno == other.si_errno
763                     && self.si_code == other.si_code
764                 // Ignore _pad
765                 // Ignore _align
766             }
767         }
768 
769         impl Eq for siginfo_t {}
770 
771         impl ::fmt::Debug for siginfo_t {
772             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
773                 f.debug_struct("siginfo_t")
774                     .field("si_signo", &self.si_signo)
775                     .field("si_errno", &self.si_errno)
776                     .field("si_code", &self.si_code)
777                 // Ignore _pad
778                 // Ignore _align
779                     .finish()
780             }
781         }
782 
783         impl ::hash::Hash for siginfo_t {
784             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
785                 self.si_signo.hash(state);
786                 self.si_errno.hash(state);
787                 self.si_code.hash(state);
788                 // Ignore _pad
789                 // Ignore _align
790             }
791         }
792 
793         impl PartialEq for lastlog {
794             fn eq(&self, other: &lastlog) -> bool {
795                 self.ll_time == other.ll_time
796                     && self
797                     .ll_line
798                     .iter()
799                     .zip(other.ll_line.iter())
800                     .all(|(a,b)| a == b)
801                     && self
802                     .ll_host
803                     .iter()
804                     .zip(other.ll_host.iter())
805                     .all(|(a,b)| a == b)
806             }
807         }
808 
809         impl Eq for lastlog {}
810 
811         impl ::fmt::Debug for lastlog {
812             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
813                 f.debug_struct("lastlog")
814                     .field("ll_time", &self.ll_time)
815                     .field("ll_line", &self.ll_line)
816                 // FIXME: .field("ll_host", &self.ll_host)
817                     .finish()
818             }
819         }
820 
821         impl ::hash::Hash for lastlog {
822             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
823                 self.ll_time.hash(state);
824                 self.ll_line.hash(state);
825                 self.ll_host.hash(state);
826             }
827         }
828 
829         impl PartialEq for utmp {
830             fn eq(&self, other: &utmp) -> bool {
831                 self.ut_type == other.ut_type
832                     && self.ut_pid == other.ut_pid
833                     && self
834                     .ut_line
835                     .iter()
836                     .zip(other.ut_line.iter())
837                     .all(|(a,b)| a == b)
838                     && self.ut_id == other.ut_id
839                     && self
840                     .ut_user
841                     .iter()
842                     .zip(other.ut_user.iter())
843                     .all(|(a,b)| a == b)
844                     && self
845                     .ut_host
846                     .iter()
847                     .zip(other.ut_host.iter())
848                     .all(|(a,b)| a == b)
849                     && self.ut_exit == other.ut_exit
850                     && self.ut_session == other.ut_session
851                     && self.ut_tv == other.ut_tv
852                     && self.ut_addr_v6 == other.ut_addr_v6
853                     && self.unused == other.unused
854             }
855         }
856 
857         impl Eq for utmp {}
858 
859         impl ::fmt::Debug for utmp {
860             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
861                 f.debug_struct("utmp")
862                     .field("ut_type", &self.ut_type)
863                     .field("ut_pid", &self.ut_pid)
864                     .field("ut_line", &self.ut_line)
865                     .field("ut_id", &self.ut_id)
866                     .field("ut_user", &self.ut_user)
867                 // FIXME: .field("ut_host", &self.ut_host)
868                     .field("ut_exit", &self.ut_exit)
869                     .field("ut_session", &self.ut_session)
870                     .field("ut_tv", &self.ut_tv)
871                     .field("ut_addr_v6", &self.ut_addr_v6)
872                     .field("unused", &self.unused)
873                     .finish()
874             }
875         }
876 
877         impl ::hash::Hash for utmp {
878             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
879                 self.ut_type.hash(state);
880                 self.ut_pid.hash(state);
881                 self.ut_line.hash(state);
882                 self.ut_id.hash(state);
883                 self.ut_user.hash(state);
884                 self.ut_host.hash(state);
885                 self.ut_exit.hash(state);
886                 self.ut_session.hash(state);
887                 self.ut_tv.hash(state);
888                 self.ut_addr_v6.hash(state);
889                 self.unused.hash(state);
890             }
891         }
892 
893         impl PartialEq for sockaddr_alg {
894             fn eq(&self, other: &sockaddr_alg) -> bool {
895                 self.salg_family == other.salg_family
896                     && self
897                     .salg_type
898                     .iter()
899                     .zip(other.salg_type.iter())
900                     .all(|(a, b)| a == b)
901                     && self.salg_feat == other.salg_feat
902                     && self.salg_mask == other.salg_mask
903                     && self
904                     .salg_name
905                     .iter()
906                     .zip(other.salg_name.iter())
907                     .all(|(a, b)| a == b)
908            }
909         }
910 
911         impl Eq for sockaddr_alg {}
912 
913         impl ::fmt::Debug for sockaddr_alg {
914             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
915                 f.debug_struct("sockaddr_alg")
916                     .field("salg_family", &self.salg_family)
917                     .field("salg_type", &self.salg_type)
918                     .field("salg_feat", &self.salg_feat)
919                     .field("salg_mask", &self.salg_mask)
920                     .field("salg_name", &&self.salg_name[..])
921                     .finish()
922             }
923         }
924 
925         impl ::hash::Hash for sockaddr_alg {
926             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
927                 self.salg_family.hash(state);
928                 self.salg_type.hash(state);
929                 self.salg_feat.hash(state);
930                 self.salg_mask.hash(state);
931                 self.salg_name.hash(state);
932             }
933         }
934 
935         impl PartialEq for uinput_setup {
936             fn eq(&self, other: &uinput_setup) -> bool {
937                 self.id == other.id
938                     && self.name[..] == other.name[..]
939                     && self.ff_effects_max == other.ff_effects_max
940            }
941         }
942         impl Eq for uinput_setup {}
943 
944         impl ::fmt::Debug for uinput_setup {
945             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
946                 f.debug_struct("uinput_setup")
947                     .field("id", &self.id)
948                     .field("name", &&self.name[..])
949                     .field("ff_effects_max", &self.ff_effects_max)
950                     .finish()
951             }
952         }
953 
954         impl ::hash::Hash for uinput_setup {
955             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
956                 self.id.hash(state);
957                 self.name.hash(state);
958                 self.ff_effects_max.hash(state);
959             }
960         }
961 
962         impl PartialEq for uinput_user_dev {
963             fn eq(&self, other: &uinput_user_dev) -> bool {
964                  self.name[..] == other.name[..]
965                     && self.id == other.id
966                     && self.ff_effects_max == other.ff_effects_max
967                     && self.absmax[..] == other.absmax[..]
968                     && self.absmin[..] == other.absmin[..]
969                     && self.absfuzz[..] == other.absfuzz[..]
970                     && self.absflat[..] == other.absflat[..]
971            }
972         }
973         impl Eq for uinput_user_dev {}
974 
975         impl ::fmt::Debug for uinput_user_dev {
976             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
977                 f.debug_struct("uinput_setup")
978                     .field("name", &&self.name[..])
979                     .field("id", &self.id)
980                     .field("ff_effects_max", &self.ff_effects_max)
981                     .field("absmax", &&self.absmax[..])
982                     .field("absmin", &&self.absmin[..])
983                     .field("absfuzz", &&self.absfuzz[..])
984                     .field("absflat", &&self.absflat[..])
985                     .finish()
986             }
987         }
988 
989         impl ::hash::Hash for uinput_user_dev {
990             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
991                 self.name.hash(state);
992                 self.id.hash(state);
993                 self.ff_effects_max.hash(state);
994                 self.absmax.hash(state);
995                 self.absmin.hash(state);
996                 self.absfuzz.hash(state);
997                 self.absflat.hash(state);
998             }
999         }
1000 
1001         #[cfg(libc_union)]
1002         impl ::fmt::Debug for __c_anonymous_ifr_ifru {
1003             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
1004                 f.debug_struct("ifr_ifru")
1005                     .field("ifru_addr", unsafe { &self.ifru_addr })
1006                     .field("ifru_dstaddr", unsafe { &self.ifru_dstaddr })
1007                     .field("ifru_broadaddr", unsafe { &self.ifru_broadaddr })
1008                     .field("ifru_netmask", unsafe { &self.ifru_netmask })
1009                     .field("ifru_hwaddr", unsafe { &self.ifru_hwaddr })
1010                     .field("ifru_flags", unsafe { &self.ifru_flags })
1011                     .field("ifru_ifindex", unsafe { &self.ifru_ifindex })
1012                     .field("ifru_metric", unsafe { &self.ifru_metric })
1013                     .field("ifru_mtu", unsafe { &self.ifru_mtu })
1014                     .field("ifru_map", unsafe { &self.ifru_map })
1015                     .field("ifru_slave", unsafe { &self.ifru_slave })
1016                     .field("ifru_newname", unsafe { &self.ifru_newname })
1017                     .field("ifru_data", unsafe { &self.ifru_data })
1018                     .finish()
1019             }
1020         }
1021         impl ::fmt::Debug for ifreq {
1022             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
1023                 f.debug_struct("ifreq")
1024                     .field("ifr_name", &self.ifr_name)
1025                     .field("ifr_ifru", &self.ifr_ifru)
1026                     .finish()
1027             }
1028         }
1029 
1030         #[cfg(libc_union)]
1031         impl ::fmt::Debug for __c_anonymous_ifc_ifcu {
1032             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
1033                 f.debug_struct("ifr_ifru")
1034                     .field("ifcu_buf", unsafe { &self.ifcu_buf })
1035                     .field("ifcu_req", unsafe { &self.ifcu_req })
1036                     .finish()
1037             }
1038         }
1039         impl ::fmt::Debug for ifconf {
1040             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
1041                 f.debug_struct("ifconf")
1042                     .field("ifc_len", &self.ifc_len)
1043                     .field("ifc_ifcu", &self.ifc_ifcu)
1044                     .finish()
1045             }
1046         }
1047 
1048         #[allow(deprecated)]
1049         impl af_alg_iv {
1050             fn as_slice(&self) -> &[u8] {
1051                 unsafe {
1052                     ::core::slice::from_raw_parts(
1053                         self.iv.as_ptr(),
1054                         self.ivlen as usize
1055                     )
1056                 }
1057             }
1058         }
1059 
1060         #[allow(deprecated)]
1061         impl PartialEq for af_alg_iv {
1062             fn eq(&self, other: &af_alg_iv) -> bool {
1063                 *self.as_slice() == *other.as_slice()
1064            }
1065         }
1066 
1067         #[allow(deprecated)]
1068         impl Eq for af_alg_iv {}
1069 
1070         #[allow(deprecated)]
1071         impl ::fmt::Debug for af_alg_iv {
1072             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
1073                 f.debug_struct("af_alg_iv")
1074                     .field("ivlen", &self.ivlen)
1075                     .finish()
1076             }
1077         }
1078 
1079         #[allow(deprecated)]
1080         impl ::hash::Hash for af_alg_iv {
1081             fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
1082                 self.as_slice().hash(state);
1083             }
1084         }
1085 
1086         impl PartialEq for prop_info {
1087             fn eq(&self, other: &prop_info) -> bool {
1088                 self.__name == other.__name &&
1089                     self.__serial == other.__serial &&
1090                     self.__value == other.__value
1091             }
1092         }
1093         impl Eq for prop_info {}
1094         impl ::fmt::Debug for prop_info {
1095             fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
1096                 f.debug_struct("prop_info")
1097                     .field("__name", &self.__name)
1098                     .field("__serial", &self.__serial)
1099                     .field("__value", &self.__value)
1100                     .finish()
1101             }
1102         }
1103     }
1104 }
1105 
1106 pub const MADV_SOFT_OFFLINE: ::c_int = 101;
1107 pub const MS_NOUSER: ::c_ulong = 0xffffffff80000000;
1108 pub const MS_RMT_MASK: ::c_ulong = 0x02800051;
1109 
1110 pub const O_TRUNC: ::c_int = 512;
1111 pub const O_CLOEXEC: ::c_int = 0x80000;
1112 pub const O_PATH: ::c_int = 0o10000000;
1113 pub const O_NOATIME: ::c_int = 0o1000000;
1114 
1115 pub const EBFONT: ::c_int = 59;
1116 pub const ENOSTR: ::c_int = 60;
1117 pub const ENODATA: ::c_int = 61;
1118 pub const ETIME: ::c_int = 62;
1119 pub const ENOSR: ::c_int = 63;
1120 pub const ENONET: ::c_int = 64;
1121 pub const ENOPKG: ::c_int = 65;
1122 pub const EREMOTE: ::c_int = 66;
1123 pub const ENOLINK: ::c_int = 67;
1124 pub const EADV: ::c_int = 68;
1125 pub const ESRMNT: ::c_int = 69;
1126 pub const ECOMM: ::c_int = 70;
1127 pub const EPROTO: ::c_int = 71;
1128 pub const EDOTDOT: ::c_int = 73;
1129 
1130 pub const EPOLL_CLOEXEC: ::c_int = 0x80000;
1131 
1132 // sys/eventfd.h
1133 pub const EFD_SEMAPHORE: ::c_int = 0x1;
1134 pub const EFD_CLOEXEC: ::c_int = O_CLOEXEC;
1135 pub const EFD_NONBLOCK: ::c_int = O_NONBLOCK;
1136 
1137 // sys/timerfd.h
1138 pub const TFD_CLOEXEC: ::c_int = O_CLOEXEC;
1139 pub const TFD_NONBLOCK: ::c_int = O_NONBLOCK;
1140 pub const TFD_TIMER_ABSTIME: ::c_int = 1;
1141 pub const TFD_TIMER_CANCEL_ON_SET: ::c_int = 2;
1142 
1143 pub const USER_PROCESS: ::c_short = 7;
1144 
1145 pub const _POSIX_VDISABLE: ::cc_t = 0;
1146 
1147 // linux/falloc.h
1148 pub const FALLOC_FL_KEEP_SIZE: ::c_int = 0x01;
1149 pub const FALLOC_FL_PUNCH_HOLE: ::c_int = 0x02;
1150 pub const FALLOC_FL_NO_HIDE_STALE: ::c_int = 0x04;
1151 pub const FALLOC_FL_COLLAPSE_RANGE: ::c_int = 0x08;
1152 pub const FALLOC_FL_ZERO_RANGE: ::c_int = 0x10;
1153 pub const FALLOC_FL_INSERT_RANGE: ::c_int = 0x20;
1154 pub const FALLOC_FL_UNSHARE_RANGE: ::c_int = 0x40;
1155 
1156 pub const BUFSIZ: ::c_uint = 1024;
1157 pub const FILENAME_MAX: ::c_uint = 4096;
1158 pub const FOPEN_MAX: ::c_uint = 20;
1159 pub const POSIX_FADV_DONTNEED: ::c_int = 4;
1160 pub const POSIX_FADV_NOREUSE: ::c_int = 5;
1161 pub const L_tmpnam: ::c_uint = 4096;
1162 pub const TMP_MAX: ::c_uint = 308915776;
1163 pub const _PC_LINK_MAX: ::c_int = 1;
1164 pub const _PC_MAX_CANON: ::c_int = 2;
1165 pub const _PC_MAX_INPUT: ::c_int = 3;
1166 pub const _PC_NAME_MAX: ::c_int = 4;
1167 pub const _PC_PATH_MAX: ::c_int = 5;
1168 pub const _PC_PIPE_BUF: ::c_int = 6;
1169 pub const _PC_2_SYMLINKS: ::c_int = 7;
1170 pub const _PC_ALLOC_SIZE_MIN: ::c_int = 8;
1171 pub const _PC_REC_INCR_XFER_SIZE: ::c_int = 9;
1172 pub const _PC_REC_MAX_XFER_SIZE: ::c_int = 10;
1173 pub const _PC_REC_MIN_XFER_SIZE: ::c_int = 11;
1174 pub const _PC_REC_XFER_ALIGN: ::c_int = 12;
1175 pub const _PC_SYMLINK_MAX: ::c_int = 13;
1176 pub const _PC_CHOWN_RESTRICTED: ::c_int = 14;
1177 pub const _PC_NO_TRUNC: ::c_int = 15;
1178 pub const _PC_VDISABLE: ::c_int = 16;
1179 pub const _PC_ASYNC_IO: ::c_int = 17;
1180 pub const _PC_PRIO_IO: ::c_int = 18;
1181 pub const _PC_SYNC_IO: ::c_int = 19;
1182 
1183 pub const FIONBIO: ::c_int = 0x5421;
1184 
1185 pub const _SC_ARG_MAX: ::c_int = 0;
1186 pub const _SC_BC_BASE_MAX: ::c_int = 1;
1187 pub const _SC_BC_DIM_MAX: ::c_int = 2;
1188 pub const _SC_BC_SCALE_MAX: ::c_int = 3;
1189 pub const _SC_BC_STRING_MAX: ::c_int = 4;
1190 pub const _SC_CHILD_MAX: ::c_int = 5;
1191 pub const _SC_CLK_TCK: ::c_int = 6;
1192 pub const _SC_COLL_WEIGHTS_MAX: ::c_int = 7;
1193 pub const _SC_EXPR_NEST_MAX: ::c_int = 8;
1194 pub const _SC_LINE_MAX: ::c_int = 9;
1195 pub const _SC_NGROUPS_MAX: ::c_int = 10;
1196 pub const _SC_OPEN_MAX: ::c_int = 11;
1197 pub const _SC_PASS_MAX: ::c_int = 12;
1198 pub const _SC_2_C_BIND: ::c_int = 13;
1199 pub const _SC_2_C_DEV: ::c_int = 14;
1200 pub const _SC_2_C_VERSION: ::c_int = 15;
1201 pub const _SC_2_CHAR_TERM: ::c_int = 16;
1202 pub const _SC_2_FORT_DEV: ::c_int = 17;
1203 pub const _SC_2_FORT_RUN: ::c_int = 18;
1204 pub const _SC_2_LOCALEDEF: ::c_int = 19;
1205 pub const _SC_2_SW_DEV: ::c_int = 20;
1206 pub const _SC_2_UPE: ::c_int = 21;
1207 pub const _SC_2_VERSION: ::c_int = 22;
1208 pub const _SC_JOB_CONTROL: ::c_int = 23;
1209 pub const _SC_SAVED_IDS: ::c_int = 24;
1210 pub const _SC_VERSION: ::c_int = 25;
1211 pub const _SC_RE_DUP_MAX: ::c_int = 26;
1212 pub const _SC_STREAM_MAX: ::c_int = 27;
1213 pub const _SC_TZNAME_MAX: ::c_int = 28;
1214 pub const _SC_XOPEN_CRYPT: ::c_int = 29;
1215 pub const _SC_XOPEN_ENH_I18N: ::c_int = 30;
1216 pub const _SC_XOPEN_SHM: ::c_int = 31;
1217 pub const _SC_XOPEN_VERSION: ::c_int = 32;
1218 pub const _SC_XOPEN_XCU_VERSION: ::c_int = 33;
1219 pub const _SC_XOPEN_REALTIME: ::c_int = 34;
1220 pub const _SC_XOPEN_REALTIME_THREADS: ::c_int = 35;
1221 pub const _SC_XOPEN_LEGACY: ::c_int = 36;
1222 pub const _SC_ATEXIT_MAX: ::c_int = 37;
1223 pub const _SC_IOV_MAX: ::c_int = 38;
1224 pub const _SC_PAGESIZE: ::c_int = 39;
1225 pub const _SC_PAGE_SIZE: ::c_int = 40;
1226 pub const _SC_XOPEN_UNIX: ::c_int = 41;
1227 pub const _SC_XBS5_ILP32_OFF32: ::c_int = 42;
1228 pub const _SC_XBS5_ILP32_OFFBIG: ::c_int = 43;
1229 pub const _SC_XBS5_LP64_OFF64: ::c_int = 44;
1230 pub const _SC_XBS5_LPBIG_OFFBIG: ::c_int = 45;
1231 pub const _SC_AIO_LISTIO_MAX: ::c_int = 46;
1232 pub const _SC_AIO_MAX: ::c_int = 47;
1233 pub const _SC_AIO_PRIO_DELTA_MAX: ::c_int = 48;
1234 pub const _SC_DELAYTIMER_MAX: ::c_int = 49;
1235 pub const _SC_MQ_OPEN_MAX: ::c_int = 50;
1236 pub const _SC_MQ_PRIO_MAX: ::c_int = 51;
1237 pub const _SC_RTSIG_MAX: ::c_int = 52;
1238 pub const _SC_SEM_NSEMS_MAX: ::c_int = 53;
1239 pub const _SC_SEM_VALUE_MAX: ::c_int = 54;
1240 pub const _SC_SIGQUEUE_MAX: ::c_int = 55;
1241 pub const _SC_TIMER_MAX: ::c_int = 56;
1242 pub const _SC_ASYNCHRONOUS_IO: ::c_int = 57;
1243 pub const _SC_FSYNC: ::c_int = 58;
1244 pub const _SC_MAPPED_FILES: ::c_int = 59;
1245 pub const _SC_MEMLOCK: ::c_int = 60;
1246 pub const _SC_MEMLOCK_RANGE: ::c_int = 61;
1247 pub const _SC_MEMORY_PROTECTION: ::c_int = 62;
1248 pub const _SC_MESSAGE_PASSING: ::c_int = 63;
1249 pub const _SC_PRIORITIZED_IO: ::c_int = 64;
1250 pub const _SC_PRIORITY_SCHEDULING: ::c_int = 65;
1251 pub const _SC_REALTIME_SIGNALS: ::c_int = 66;
1252 pub const _SC_SEMAPHORES: ::c_int = 67;
1253 pub const _SC_SHARED_MEMORY_OBJECTS: ::c_int = 68;
1254 pub const _SC_SYNCHRONIZED_IO: ::c_int = 69;
1255 pub const _SC_TIMERS: ::c_int = 70;
1256 pub const _SC_GETGR_R_SIZE_MAX: ::c_int = 71;
1257 pub const _SC_GETPW_R_SIZE_MAX: ::c_int = 72;
1258 pub const _SC_LOGIN_NAME_MAX: ::c_int = 73;
1259 pub const _SC_THREAD_DESTRUCTOR_ITERATIONS: ::c_int = 74;
1260 pub const _SC_THREAD_KEYS_MAX: ::c_int = 75;
1261 pub const _SC_THREAD_STACK_MIN: ::c_int = 76;
1262 pub const _SC_THREAD_THREADS_MAX: ::c_int = 77;
1263 pub const _SC_TTY_NAME_MAX: ::c_int = 78;
1264 pub const _SC_THREADS: ::c_int = 79;
1265 pub const _SC_THREAD_ATTR_STACKADDR: ::c_int = 80;
1266 pub const _SC_THREAD_ATTR_STACKSIZE: ::c_int = 81;
1267 pub const _SC_THREAD_PRIORITY_SCHEDULING: ::c_int = 82;
1268 pub const _SC_THREAD_PRIO_INHERIT: ::c_int = 83;
1269 pub const _SC_THREAD_PRIO_PROTECT: ::c_int = 84;
1270 pub const _SC_THREAD_SAFE_FUNCTIONS: ::c_int = 85;
1271 pub const _SC_NPROCESSORS_CONF: ::c_int = 96;
1272 pub const _SC_NPROCESSORS_ONLN: ::c_int = 97;
1273 pub const _SC_PHYS_PAGES: ::c_int = 98;
1274 pub const _SC_AVPHYS_PAGES: ::c_int = 99;
1275 pub const _SC_MONOTONIC_CLOCK: ::c_int = 100;
1276 
1277 pub const _SC_2_PBS: ::c_int = 101;
1278 pub const _SC_2_PBS_ACCOUNTING: ::c_int = 102;
1279 pub const _SC_2_PBS_CHECKPOINT: ::c_int = 103;
1280 pub const _SC_2_PBS_LOCATE: ::c_int = 104;
1281 pub const _SC_2_PBS_MESSAGE: ::c_int = 105;
1282 pub const _SC_2_PBS_TRACK: ::c_int = 106;
1283 pub const _SC_ADVISORY_INFO: ::c_int = 107;
1284 pub const _SC_BARRIERS: ::c_int = 108;
1285 pub const _SC_CLOCK_SELECTION: ::c_int = 109;
1286 pub const _SC_CPUTIME: ::c_int = 110;
1287 pub const _SC_HOST_NAME_MAX: ::c_int = 111;
1288 pub const _SC_IPV6: ::c_int = 112;
1289 pub const _SC_RAW_SOCKETS: ::c_int = 113;
1290 pub const _SC_READER_WRITER_LOCKS: ::c_int = 114;
1291 pub const _SC_REGEXP: ::c_int = 115;
1292 pub const _SC_SHELL: ::c_int = 116;
1293 pub const _SC_SPAWN: ::c_int = 117;
1294 pub const _SC_SPIN_LOCKS: ::c_int = 118;
1295 pub const _SC_SPORADIC_SERVER: ::c_int = 119;
1296 pub const _SC_SS_REPL_MAX: ::c_int = 120;
1297 pub const _SC_SYMLOOP_MAX: ::c_int = 121;
1298 pub const _SC_THREAD_CPUTIME: ::c_int = 122;
1299 pub const _SC_THREAD_PROCESS_SHARED: ::c_int = 123;
1300 pub const _SC_THREAD_ROBUST_PRIO_INHERIT: ::c_int = 124;
1301 pub const _SC_THREAD_ROBUST_PRIO_PROTECT: ::c_int = 125;
1302 pub const _SC_THREAD_SPORADIC_SERVER: ::c_int = 126;
1303 pub const _SC_TIMEOUTS: ::c_int = 127;
1304 pub const _SC_TRACE: ::c_int = 128;
1305 pub const _SC_TRACE_EVENT_FILTER: ::c_int = 129;
1306 pub const _SC_TRACE_EVENT_NAME_MAX: ::c_int = 130;
1307 pub const _SC_TRACE_INHERIT: ::c_int = 131;
1308 pub const _SC_TRACE_LOG: ::c_int = 132;
1309 pub const _SC_TRACE_NAME_MAX: ::c_int = 133;
1310 pub const _SC_TRACE_SYS_MAX: ::c_int = 134;
1311 pub const _SC_TRACE_USER_EVENT_MAX: ::c_int = 135;
1312 pub const _SC_TYPED_MEMORY_OBJECTS: ::c_int = 136;
1313 pub const _SC_V7_ILP32_OFF32: ::c_int = 137;
1314 pub const _SC_V7_ILP32_OFFBIG: ::c_int = 138;
1315 pub const _SC_V7_LP64_OFF64: ::c_int = 139;
1316 pub const _SC_V7_LPBIG_OFFBIG: ::c_int = 140;
1317 pub const _SC_XOPEN_STREAMS: ::c_int = 141;
1318 pub const _SC_XOPEN_UUCP: ::c_int = 142;
1319 
1320 pub const F_LOCK: ::c_int = 1;
1321 pub const F_TEST: ::c_int = 3;
1322 pub const F_TLOCK: ::c_int = 2;
1323 pub const F_ULOCK: ::c_int = 0;
1324 
1325 pub const F_SEAL_FUTURE_WRITE: ::c_int = 0x0010;
1326 
1327 pub const IFF_LOWER_UP: ::c_int = 0x10000;
1328 pub const IFF_DORMANT: ::c_int = 0x20000;
1329 pub const IFF_ECHO: ::c_int = 0x40000;
1330 
1331 pub const PTHREAD_MUTEX_NORMAL: ::c_int = 0;
1332 pub const PTHREAD_MUTEX_RECURSIVE: ::c_int = 1;
1333 pub const PTHREAD_MUTEX_ERRORCHECK: ::c_int = 2;
1334 pub const PTHREAD_MUTEX_DEFAULT: ::c_int = PTHREAD_MUTEX_NORMAL;
1335 
1336 pub const PTHREAD_EXPLICIT_SCHED: ::c_int = 0;
1337 pub const PTHREAD_INHERIT_SCHED: ::c_int = 1;
1338 
1339 // stdio.h
1340 pub const RENAME_NOREPLACE: ::c_int = 1;
1341 pub const RENAME_EXCHANGE: ::c_int = 2;
1342 pub const RENAME_WHITEOUT: ::c_int = 4;
1343 
1344 pub const FIOCLEX: ::c_int = 0x5451;
1345 pub const FIONCLEX: ::c_int = 0x5450;
1346 
1347 pub const SIGCHLD: ::c_int = 17;
1348 pub const SIGBUS: ::c_int = 7;
1349 pub const SIGUSR1: ::c_int = 10;
1350 pub const SIGUSR2: ::c_int = 12;
1351 pub const SIGCONT: ::c_int = 18;
1352 pub const SIGSTOP: ::c_int = 19;
1353 pub const SIGTSTP: ::c_int = 20;
1354 pub const SIGURG: ::c_int = 23;
1355 pub const SIGIO: ::c_int = 29;
1356 pub const SIGSYS: ::c_int = 31;
1357 pub const SIGSTKFLT: ::c_int = 16;
1358 #[deprecated(since = "0.2.55", note = "Use SIGSYS instead")]
1359 pub const SIGUNUSED: ::c_int = 31;
1360 pub const SIGTTIN: ::c_int = 21;
1361 pub const SIGTTOU: ::c_int = 22;
1362 pub const SIGXCPU: ::c_int = 24;
1363 pub const SIGXFSZ: ::c_int = 25;
1364 pub const SIGVTALRM: ::c_int = 26;
1365 pub const SIGPROF: ::c_int = 27;
1366 pub const SIGWINCH: ::c_int = 28;
1367 pub const SIGPOLL: ::c_int = 29;
1368 pub const SIGPWR: ::c_int = 30;
1369 pub const SIG_SETMASK: ::c_int = 2;
1370 pub const SIG_BLOCK: ::c_int = 0x000000;
1371 pub const SIG_UNBLOCK: ::c_int = 0x01;
1372 
1373 pub const RUSAGE_CHILDREN: ::c_int = -1;
1374 
1375 pub const LC_PAPER: ::c_int = 7;
1376 pub const LC_NAME: ::c_int = 8;
1377 pub const LC_ADDRESS: ::c_int = 9;
1378 pub const LC_TELEPHONE: ::c_int = 10;
1379 pub const LC_MEASUREMENT: ::c_int = 11;
1380 pub const LC_IDENTIFICATION: ::c_int = 12;
1381 pub const LC_PAPER_MASK: ::c_int = 1 << LC_PAPER;
1382 pub const LC_NAME_MASK: ::c_int = 1 << LC_NAME;
1383 pub const LC_ADDRESS_MASK: ::c_int = 1 << LC_ADDRESS;
1384 pub const LC_TELEPHONE_MASK: ::c_int = 1 << LC_TELEPHONE;
1385 pub const LC_MEASUREMENT_MASK: ::c_int = 1 << LC_MEASUREMENT;
1386 pub const LC_IDENTIFICATION_MASK: ::c_int = 1 << LC_IDENTIFICATION;
1387 pub const LC_ALL_MASK: ::c_int = ::LC_CTYPE_MASK
1388     | ::LC_NUMERIC_MASK
1389     | ::LC_TIME_MASK
1390     | ::LC_COLLATE_MASK
1391     | ::LC_MONETARY_MASK
1392     | ::LC_MESSAGES_MASK
1393     | LC_PAPER_MASK
1394     | LC_NAME_MASK
1395     | LC_ADDRESS_MASK
1396     | LC_TELEPHONE_MASK
1397     | LC_MEASUREMENT_MASK
1398     | LC_IDENTIFICATION_MASK;
1399 
1400 pub const MAP_ANON: ::c_int = 0x0020;
1401 pub const MAP_ANONYMOUS: ::c_int = 0x0020;
1402 pub const MAP_GROWSDOWN: ::c_int = 0x0100;
1403 pub const MAP_DENYWRITE: ::c_int = 0x0800;
1404 pub const MAP_EXECUTABLE: ::c_int = 0x01000;
1405 pub const MAP_LOCKED: ::c_int = 0x02000;
1406 pub const MAP_NORESERVE: ::c_int = 0x04000;
1407 pub const MAP_POPULATE: ::c_int = 0x08000;
1408 pub const MAP_NONBLOCK: ::c_int = 0x010000;
1409 pub const MAP_STACK: ::c_int = 0x020000;
1410 
1411 pub const EDEADLK: ::c_int = 35;
1412 pub const ENAMETOOLONG: ::c_int = 36;
1413 pub const ENOLCK: ::c_int = 37;
1414 pub const ENOSYS: ::c_int = 38;
1415 pub const ENOTEMPTY: ::c_int = 39;
1416 pub const ELOOP: ::c_int = 40;
1417 pub const ENOMSG: ::c_int = 42;
1418 pub const EIDRM: ::c_int = 43;
1419 pub const ECHRNG: ::c_int = 44;
1420 pub const EL2NSYNC: ::c_int = 45;
1421 pub const EL3HLT: ::c_int = 46;
1422 pub const EL3RST: ::c_int = 47;
1423 pub const ELNRNG: ::c_int = 48;
1424 pub const EUNATCH: ::c_int = 49;
1425 pub const ENOCSI: ::c_int = 50;
1426 pub const EL2HLT: ::c_int = 51;
1427 pub const EBADE: ::c_int = 52;
1428 pub const EBADR: ::c_int = 53;
1429 pub const EXFULL: ::c_int = 54;
1430 pub const ENOANO: ::c_int = 55;
1431 pub const EBADRQC: ::c_int = 56;
1432 pub const EBADSLT: ::c_int = 57;
1433 
1434 pub const EMULTIHOP: ::c_int = 72;
1435 pub const EBADMSG: ::c_int = 74;
1436 pub const EOVERFLOW: ::c_int = 75;
1437 pub const ENOTUNIQ: ::c_int = 76;
1438 pub const EBADFD: ::c_int = 77;
1439 pub const EREMCHG: ::c_int = 78;
1440 pub const ELIBACC: ::c_int = 79;
1441 pub const ELIBBAD: ::c_int = 80;
1442 pub const ELIBSCN: ::c_int = 81;
1443 pub const ELIBMAX: ::c_int = 82;
1444 pub const ELIBEXEC: ::c_int = 83;
1445 pub const EILSEQ: ::c_int = 84;
1446 pub const ERESTART: ::c_int = 85;
1447 pub const ESTRPIPE: ::c_int = 86;
1448 pub const EUSERS: ::c_int = 87;
1449 pub const ENOTSOCK: ::c_int = 88;
1450 pub const EDESTADDRREQ: ::c_int = 89;
1451 pub const EMSGSIZE: ::c_int = 90;
1452 pub const EPROTOTYPE: ::c_int = 91;
1453 pub const ENOPROTOOPT: ::c_int = 92;
1454 pub const EPROTONOSUPPORT: ::c_int = 93;
1455 pub const ESOCKTNOSUPPORT: ::c_int = 94;
1456 pub const EOPNOTSUPP: ::c_int = 95;
1457 pub const ENOTSUP: ::c_int = EOPNOTSUPP;
1458 pub const EPFNOSUPPORT: ::c_int = 96;
1459 pub const EAFNOSUPPORT: ::c_int = 97;
1460 pub const EADDRINUSE: ::c_int = 98;
1461 pub const EADDRNOTAVAIL: ::c_int = 99;
1462 pub const ENETDOWN: ::c_int = 100;
1463 pub const ENETUNREACH: ::c_int = 101;
1464 pub const ENETRESET: ::c_int = 102;
1465 pub const ECONNABORTED: ::c_int = 103;
1466 pub const ECONNRESET: ::c_int = 104;
1467 pub const ENOBUFS: ::c_int = 105;
1468 pub const EISCONN: ::c_int = 106;
1469 pub const ENOTCONN: ::c_int = 107;
1470 pub const ESHUTDOWN: ::c_int = 108;
1471 pub const ETOOMANYREFS: ::c_int = 109;
1472 pub const ETIMEDOUT: ::c_int = 110;
1473 pub const ECONNREFUSED: ::c_int = 111;
1474 pub const EHOSTDOWN: ::c_int = 112;
1475 pub const EHOSTUNREACH: ::c_int = 113;
1476 pub const EALREADY: ::c_int = 114;
1477 pub const EINPROGRESS: ::c_int = 115;
1478 pub const ESTALE: ::c_int = 116;
1479 pub const EUCLEAN: ::c_int = 117;
1480 pub const ENOTNAM: ::c_int = 118;
1481 pub const ENAVAIL: ::c_int = 119;
1482 pub const EISNAM: ::c_int = 120;
1483 pub const EREMOTEIO: ::c_int = 121;
1484 pub const EDQUOT: ::c_int = 122;
1485 pub const ENOMEDIUM: ::c_int = 123;
1486 pub const EMEDIUMTYPE: ::c_int = 124;
1487 pub const ECANCELED: ::c_int = 125;
1488 pub const ENOKEY: ::c_int = 126;
1489 pub const EKEYEXPIRED: ::c_int = 127;
1490 pub const EKEYREVOKED: ::c_int = 128;
1491 pub const EKEYREJECTED: ::c_int = 129;
1492 pub const EOWNERDEAD: ::c_int = 130;
1493 pub const ENOTRECOVERABLE: ::c_int = 131;
1494 
1495 pub const SOCK_STREAM: ::c_int = 1;
1496 pub const SOCK_DGRAM: ::c_int = 2;
1497 pub const SOCK_SEQPACKET: ::c_int = 5;
1498 pub const SOCK_DCCP: ::c_int = 6;
1499 pub const SOCK_PACKET: ::c_int = 10;
1500 
1501 pub const IPPROTO_MAX: ::c_int = 256;
1502 
1503 pub const SOL_SOCKET: ::c_int = 1;
1504 pub const SOL_SCTP: ::c_int = 132;
1505 pub const SOL_IPX: ::c_int = 256;
1506 pub const SOL_AX25: ::c_int = 257;
1507 pub const SOL_ATALK: ::c_int = 258;
1508 pub const SOL_NETROM: ::c_int = 259;
1509 pub const SOL_ROSE: ::c_int = 260;
1510 
1511 /* DCCP socket options */
1512 pub const DCCP_SOCKOPT_PACKET_SIZE: ::c_int = 1;
1513 pub const DCCP_SOCKOPT_SERVICE: ::c_int = 2;
1514 pub const DCCP_SOCKOPT_CHANGE_L: ::c_int = 3;
1515 pub const DCCP_SOCKOPT_CHANGE_R: ::c_int = 4;
1516 pub const DCCP_SOCKOPT_GET_CUR_MPS: ::c_int = 5;
1517 pub const DCCP_SOCKOPT_SERVER_TIMEWAIT: ::c_int = 6;
1518 pub const DCCP_SOCKOPT_SEND_CSCOV: ::c_int = 10;
1519 pub const DCCP_SOCKOPT_RECV_CSCOV: ::c_int = 11;
1520 pub const DCCP_SOCKOPT_AVAILABLE_CCIDS: ::c_int = 12;
1521 pub const DCCP_SOCKOPT_CCID: ::c_int = 13;
1522 pub const DCCP_SOCKOPT_TX_CCID: ::c_int = 14;
1523 pub const DCCP_SOCKOPT_RX_CCID: ::c_int = 15;
1524 pub const DCCP_SOCKOPT_QPOLICY_ID: ::c_int = 16;
1525 pub const DCCP_SOCKOPT_QPOLICY_TXQLEN: ::c_int = 17;
1526 pub const DCCP_SOCKOPT_CCID_RX_INFO: ::c_int = 128;
1527 pub const DCCP_SOCKOPT_CCID_TX_INFO: ::c_int = 192;
1528 
1529 /// maximum number of services provided on the same listening port
1530 pub const DCCP_SERVICE_LIST_MAX_LEN: ::c_int = 32;
1531 
1532 pub const SO_REUSEADDR: ::c_int = 2;
1533 pub const SO_TYPE: ::c_int = 3;
1534 pub const SO_ERROR: ::c_int = 4;
1535 pub const SO_DONTROUTE: ::c_int = 5;
1536 pub const SO_BROADCAST: ::c_int = 6;
1537 pub const SO_SNDBUF: ::c_int = 7;
1538 pub const SO_RCVBUF: ::c_int = 8;
1539 pub const SO_KEEPALIVE: ::c_int = 9;
1540 pub const SO_OOBINLINE: ::c_int = 10;
1541 pub const SO_PRIORITY: ::c_int = 12;
1542 pub const SO_LINGER: ::c_int = 13;
1543 pub const SO_BSDCOMPAT: ::c_int = 14;
1544 pub const SO_REUSEPORT: ::c_int = 15;
1545 pub const SO_PASSCRED: ::c_int = 16;
1546 pub const SO_PEERCRED: ::c_int = 17;
1547 pub const SO_RCVLOWAT: ::c_int = 18;
1548 pub const SO_SNDLOWAT: ::c_int = 19;
1549 pub const SO_RCVTIMEO: ::c_int = 20;
1550 pub const SO_SNDTIMEO: ::c_int = 21;
1551 pub const SO_BINDTODEVICE: ::c_int = 25;
1552 pub const SO_ATTACH_FILTER: ::c_int = 26;
1553 pub const SO_DETACH_FILTER: ::c_int = 27;
1554 pub const SO_GET_FILTER: ::c_int = SO_ATTACH_FILTER;
1555 pub const SO_TIMESTAMP: ::c_int = 29;
1556 pub const SO_ACCEPTCONN: ::c_int = 30;
1557 pub const SO_PEERSEC: ::c_int = 31;
1558 pub const SO_SNDBUFFORCE: ::c_int = 32;
1559 pub const SO_RCVBUFFORCE: ::c_int = 33;
1560 pub const SO_PASSSEC: ::c_int = 34;
1561 pub const SO_TIMESTAMPNS: ::c_int = 35;
1562 // pub const SO_TIMESTAMPNS_OLD: ::c_int = 35;
1563 pub const SO_MARK: ::c_int = 36;
1564 pub const SO_TIMESTAMPING: ::c_int = 37;
1565 // pub const SO_TIMESTAMPING_OLD: ::c_int = 37;
1566 pub const SO_PROTOCOL: ::c_int = 38;
1567 pub const SO_DOMAIN: ::c_int = 39;
1568 pub const SO_RXQ_OVFL: ::c_int = 40;
1569 pub const SO_PEEK_OFF: ::c_int = 42;
1570 pub const SO_BUSY_POLL: ::c_int = 46;
1571 pub const SCM_TIMESTAMPING_OPT_STATS: ::c_int = 54;
1572 pub const SCM_TIMESTAMPING_PKTINFO: ::c_int = 58;
1573 pub const SO_TIMESTAMP_NEW: ::c_int = 63;
1574 pub const SO_TIMESTAMPNS_NEW: ::c_int = 64;
1575 pub const SO_TIMESTAMPING_NEW: ::c_int = 65;
1576 
1577 // Defined in unix/linux_like/mod.rs
1578 // pub const SCM_TIMESTAMP: ::c_int = SO_TIMESTAMP;
1579 pub const SCM_TIMESTAMPNS: ::c_int = SO_TIMESTAMPNS;
1580 pub const SCM_TIMESTAMPING: ::c_int = SO_TIMESTAMPING;
1581 
1582 pub const IPTOS_ECN_NOTECT: u8 = 0x00;
1583 
1584 pub const O_ACCMODE: ::c_int = 3;
1585 pub const O_APPEND: ::c_int = 1024;
1586 pub const O_CREAT: ::c_int = 64;
1587 pub const O_EXCL: ::c_int = 128;
1588 pub const O_NOCTTY: ::c_int = 256;
1589 pub const O_NONBLOCK: ::c_int = 2048;
1590 pub const O_SYNC: ::c_int = 0x101000;
1591 pub const O_ASYNC: ::c_int = 0x2000;
1592 pub const O_NDELAY: ::c_int = 0x800;
1593 pub const O_DSYNC: ::c_int = 4096;
1594 pub const O_RSYNC: ::c_int = O_SYNC;
1595 
1596 pub const NI_MAXHOST: ::size_t = 1025;
1597 pub const NI_MAXSERV: ::size_t = 32;
1598 
1599 pub const NI_NOFQDN: ::c_int = 0x00000001;
1600 pub const NI_NUMERICHOST: ::c_int = 0x00000002;
1601 pub const NI_NAMEREQD: ::c_int = 0x00000004;
1602 pub const NI_NUMERICSERV: ::c_int = 0x00000008;
1603 pub const NI_DGRAM: ::c_int = 0x00000010;
1604 
1605 pub const NCCS: usize = 19;
1606 pub const TCSBRKP: ::c_int = 0x5425;
1607 pub const TCSANOW: ::c_int = 0;
1608 pub const TCSADRAIN: ::c_int = 0x1;
1609 pub const TCSAFLUSH: ::c_int = 0x2;
1610 pub const VEOF: usize = 4;
1611 pub const VEOL: usize = 11;
1612 pub const VEOL2: usize = 16;
1613 pub const VMIN: usize = 6;
1614 pub const IEXTEN: ::tcflag_t = 0x00008000;
1615 pub const TOSTOP: ::tcflag_t = 0x00000100;
1616 pub const FLUSHO: ::tcflag_t = 0x00001000;
1617 pub const EXTPROC: ::tcflag_t = 0o200000;
1618 
1619 pub const MAP_HUGETLB: ::c_int = 0x040000;
1620 
1621 pub const PTRACE_TRACEME: ::c_int = 0;
1622 pub const PTRACE_PEEKTEXT: ::c_int = 1;
1623 pub const PTRACE_PEEKDATA: ::c_int = 2;
1624 pub const PTRACE_PEEKUSER: ::c_int = 3;
1625 pub const PTRACE_POKETEXT: ::c_int = 4;
1626 pub const PTRACE_POKEDATA: ::c_int = 5;
1627 pub const PTRACE_POKEUSER: ::c_int = 6;
1628 pub const PTRACE_CONT: ::c_int = 7;
1629 pub const PTRACE_KILL: ::c_int = 8;
1630 pub const PTRACE_SINGLESTEP: ::c_int = 9;
1631 pub const PTRACE_GETREGS: ::c_int = 12;
1632 pub const PTRACE_SETREGS: ::c_int = 13;
1633 pub const PTRACE_ATTACH: ::c_int = 16;
1634 pub const PTRACE_DETACH: ::c_int = 17;
1635 pub const PTRACE_SYSCALL: ::c_int = 24;
1636 pub const PTRACE_SETOPTIONS: ::c_int = 0x4200;
1637 pub const PTRACE_GETEVENTMSG: ::c_int = 0x4201;
1638 pub const PTRACE_GETSIGINFO: ::c_int = 0x4202;
1639 pub const PTRACE_SETSIGINFO: ::c_int = 0x4203;
1640 pub const PTRACE_GETREGSET: ::c_int = 0x4204;
1641 pub const PTRACE_SETREGSET: ::c_int = 0x4205;
1642 pub const PTRACE_SECCOMP_GET_METADATA: ::c_int = 0x420d;
1643 
1644 pub const PTRACE_EVENT_STOP: ::c_int = 128;
1645 
1646 pub const F_GETLK: ::c_int = 5;
1647 pub const F_GETOWN: ::c_int = 9;
1648 pub const F_SETOWN: ::c_int = 8;
1649 pub const F_SETLK: ::c_int = 6;
1650 pub const F_SETLKW: ::c_int = 7;
1651 pub const F_RDLCK: ::c_int = 0;
1652 pub const F_WRLCK: ::c_int = 1;
1653 pub const F_UNLCK: ::c_int = 2;
1654 pub const F_OFD_GETLK: ::c_int = 36;
1655 pub const F_OFD_SETLK: ::c_int = 37;
1656 pub const F_OFD_SETLKW: ::c_int = 38;
1657 
1658 pub const RLIMIT_CPU: ::c_int = 0;
1659 pub const RLIMIT_FSIZE: ::c_int = 1;
1660 pub const RLIMIT_DATA: ::c_int = 2;
1661 pub const RLIMIT_STACK: ::c_int = 3;
1662 pub const RLIMIT_CORE: ::c_int = 4;
1663 pub const RLIMIT_RSS: ::c_int = 5;
1664 pub const RLIMIT_NPROC: ::c_int = 6;
1665 pub const RLIMIT_NOFILE: ::c_int = 7;
1666 pub const RLIMIT_MEMLOCK: ::c_int = 8;
1667 pub const RLIMIT_AS: ::c_int = 9;
1668 pub const RLIMIT_LOCKS: ::c_int = 10;
1669 pub const RLIMIT_SIGPENDING: ::c_int = 11;
1670 pub const RLIMIT_MSGQUEUE: ::c_int = 12;
1671 pub const RLIMIT_NICE: ::c_int = 13;
1672 pub const RLIMIT_RTPRIO: ::c_int = 14;
1673 
1674 #[deprecated(since = "0.2.64", note = "Not stable across OS versions")]
1675 pub const RLIM_NLIMITS: ::c_int = 16;
1676 pub const RLIM_INFINITY: ::rlim_t = !0;
1677 
1678 pub const TCGETS: ::c_int = 0x5401;
1679 pub const TCSETS: ::c_int = 0x5402;
1680 pub const TCSETSW: ::c_int = 0x5403;
1681 pub const TCSETSF: ::c_int = 0x5404;
1682 pub const TCGETS2: ::c_int = 0x802c542a;
1683 pub const TCSETS2: ::c_int = 0x402c542b;
1684 pub const TCSETSW2: ::c_int = 0x402c542c;
1685 pub const TCSETSF2: ::c_int = 0x402c542d;
1686 pub const TCGETA: ::c_int = 0x5405;
1687 pub const TCSETA: ::c_int = 0x5406;
1688 pub const TCSETAW: ::c_int = 0x5407;
1689 pub const TCSETAF: ::c_int = 0x5408;
1690 pub const TCSBRK: ::c_int = 0x5409;
1691 pub const TCXONC: ::c_int = 0x540A;
1692 pub const TCFLSH: ::c_int = 0x540B;
1693 pub const TIOCGSOFTCAR: ::c_int = 0x5419;
1694 pub const TIOCSSOFTCAR: ::c_int = 0x541A;
1695 pub const TIOCINQ: ::c_int = 0x541B;
1696 pub const TIOCLINUX: ::c_int = 0x541C;
1697 pub const TIOCGSERIAL: ::c_int = 0x541E;
1698 pub const TIOCEXCL: ::c_int = 0x540C;
1699 pub const TIOCNXCL: ::c_int = 0x540D;
1700 pub const TIOCSCTTY: ::c_int = 0x540E;
1701 pub const TIOCGPGRP: ::c_int = 0x540F;
1702 pub const TIOCSPGRP: ::c_int = 0x5410;
1703 pub const TIOCOUTQ: ::c_int = 0x5411;
1704 pub const TIOCSTI: ::c_int = 0x5412;
1705 pub const TIOCGWINSZ: ::c_int = 0x5413;
1706 pub const TIOCSWINSZ: ::c_int = 0x5414;
1707 pub const TIOCMGET: ::c_int = 0x5415;
1708 pub const TIOCMBIS: ::c_int = 0x5416;
1709 pub const TIOCMBIC: ::c_int = 0x5417;
1710 pub const TIOCMSET: ::c_int = 0x5418;
1711 pub const FIONREAD: ::c_int = 0x541B;
1712 pub const TIOCCONS: ::c_int = 0x541D;
1713 pub const TIOCSBRK: ::c_int = 0x5427;
1714 pub const TIOCCBRK: ::c_int = 0x5428;
1715 cfg_if! {
1716     if #[cfg(any(target_arch = "x86",
1717                  target_arch = "x86_64",
1718                  target_arch = "arm",
1719                  target_arch = "aarch64",
1720                  target_arch = "riscv64",
1721                  target_arch = "s390x"))] {
1722         pub const FICLONE: ::c_int = 0x40049409;
1723         pub const FICLONERANGE: ::c_int = 0x4020940D;
1724     } else if #[cfg(any(target_arch = "mips",
1725                         target_arch = "mips64",
1726                         target_arch = "powerpc",
1727                         target_arch = "powerpc64"))] {
1728         pub const FICLONE: ::c_int = 0x80049409;
1729         pub const FICLONERANGE: ::c_int = 0x8020940D;
1730     }
1731 }
1732 
1733 pub const ST_RDONLY: ::c_ulong = 1;
1734 pub const ST_NOSUID: ::c_ulong = 2;
1735 pub const ST_NODEV: ::c_ulong = 4;
1736 pub const ST_NOEXEC: ::c_ulong = 8;
1737 pub const ST_SYNCHRONOUS: ::c_ulong = 16;
1738 pub const ST_MANDLOCK: ::c_ulong = 64;
1739 pub const ST_NOATIME: ::c_ulong = 1024;
1740 pub const ST_NODIRATIME: ::c_ulong = 2048;
1741 pub const ST_RELATIME: ::c_ulong = 4096;
1742 
1743 pub const RTLD_NOLOAD: ::c_int = 0x4;
1744 
1745 pub const SEM_FAILED: *mut sem_t = 0 as *mut sem_t;
1746 
1747 pub const AI_PASSIVE: ::c_int = 0x00000001;
1748 pub const AI_CANONNAME: ::c_int = 0x00000002;
1749 pub const AI_NUMERICHOST: ::c_int = 0x00000004;
1750 pub const AI_NUMERICSERV: ::c_int = 0x00000008;
1751 pub const AI_MASK: ::c_int =
1752     AI_PASSIVE | AI_CANONNAME | AI_NUMERICHOST | AI_NUMERICSERV | AI_ADDRCONFIG;
1753 pub const AI_ALL: ::c_int = 0x00000100;
1754 pub const AI_V4MAPPED_CFG: ::c_int = 0x00000200;
1755 pub const AI_ADDRCONFIG: ::c_int = 0x00000400;
1756 pub const AI_V4MAPPED: ::c_int = 0x00000800;
1757 pub const AI_DEFAULT: ::c_int = AI_V4MAPPED_CFG | AI_ADDRCONFIG;
1758 
1759 // linux/kexec.h
1760 pub const KEXEC_ON_CRASH: ::c_int = 0x00000001;
1761 pub const KEXEC_PRESERVE_CONTEXT: ::c_int = 0x00000002;
1762 pub const KEXEC_ARCH_MASK: ::c_int = 0xffff0000;
1763 pub const KEXEC_FILE_UNLOAD: ::c_int = 0x00000001;
1764 pub const KEXEC_FILE_ON_CRASH: ::c_int = 0x00000002;
1765 pub const KEXEC_FILE_NO_INITRAMFS: ::c_int = 0x00000004;
1766 
1767 pub const LINUX_REBOOT_MAGIC1: ::c_int = 0xfee1dead;
1768 pub const LINUX_REBOOT_MAGIC2: ::c_int = 672274793;
1769 pub const LINUX_REBOOT_MAGIC2A: ::c_int = 85072278;
1770 pub const LINUX_REBOOT_MAGIC2B: ::c_int = 369367448;
1771 pub const LINUX_REBOOT_MAGIC2C: ::c_int = 537993216;
1772 
1773 pub const LINUX_REBOOT_CMD_RESTART: ::c_int = 0x01234567;
1774 pub const LINUX_REBOOT_CMD_HALT: ::c_int = 0xCDEF0123;
1775 pub const LINUX_REBOOT_CMD_CAD_ON: ::c_int = 0x89ABCDEF;
1776 pub const LINUX_REBOOT_CMD_CAD_OFF: ::c_int = 0x00000000;
1777 pub const LINUX_REBOOT_CMD_POWER_OFF: ::c_int = 0x4321FEDC;
1778 pub const LINUX_REBOOT_CMD_RESTART2: ::c_int = 0xA1B2C3D4;
1779 pub const LINUX_REBOOT_CMD_SW_SUSPEND: ::c_int = 0xD000FCE2;
1780 pub const LINUX_REBOOT_CMD_KEXEC: ::c_int = 0x45584543;
1781 
1782 pub const REG_BASIC: ::c_int = 0;
1783 pub const REG_EXTENDED: ::c_int = 1;
1784 pub const REG_ICASE: ::c_int = 2;
1785 pub const REG_NOSUB: ::c_int = 4;
1786 pub const REG_NEWLINE: ::c_int = 8;
1787 pub const REG_NOSPEC: ::c_int = 16;
1788 pub const REG_PEND: ::c_int = 32;
1789 pub const REG_DUMP: ::c_int = 128;
1790 
1791 pub const REG_NOMATCH: ::c_int = 1;
1792 pub const REG_BADPAT: ::c_int = 2;
1793 pub const REG_ECOLLATE: ::c_int = 3;
1794 pub const REG_ECTYPE: ::c_int = 4;
1795 pub const REG_EESCAPE: ::c_int = 5;
1796 pub const REG_ESUBREG: ::c_int = 6;
1797 pub const REG_EBRACK: ::c_int = 7;
1798 pub const REG_EPAREN: ::c_int = 8;
1799 pub const REG_EBRACE: ::c_int = 9;
1800 pub const REG_BADBR: ::c_int = 10;
1801 pub const REG_ERANGE: ::c_int = 11;
1802 pub const REG_ESPACE: ::c_int = 12;
1803 pub const REG_BADRPT: ::c_int = 13;
1804 pub const REG_EMPTY: ::c_int = 14;
1805 pub const REG_ASSERT: ::c_int = 15;
1806 pub const REG_INVARG: ::c_int = 16;
1807 pub const REG_ATOI: ::c_int = 255;
1808 pub const REG_ITOA: ::c_int = 256;
1809 
1810 pub const REG_NOTBOL: ::c_int = 1;
1811 pub const REG_NOTEOL: ::c_int = 2;
1812 pub const REG_STARTEND: ::c_int = 4;
1813 pub const REG_TRACE: ::c_int = 256;
1814 pub const REG_LARGE: ::c_int = 512;
1815 pub const REG_BACKR: ::c_int = 1024;
1816 
1817 pub const MCL_CURRENT: ::c_int = 0x0001;
1818 pub const MCL_FUTURE: ::c_int = 0x0002;
1819 pub const MCL_ONFAULT: ::c_int = 0x0004;
1820 
1821 pub const CBAUD: ::tcflag_t = 0o0010017;
1822 pub const TAB1: ::tcflag_t = 0x00000800;
1823 pub const TAB2: ::tcflag_t = 0x00001000;
1824 pub const TAB3: ::tcflag_t = 0x00001800;
1825 pub const CR1: ::tcflag_t = 0x00000200;
1826 pub const CR2: ::tcflag_t = 0x00000400;
1827 pub const CR3: ::tcflag_t = 0x00000600;
1828 pub const FF1: ::tcflag_t = 0x00008000;
1829 pub const BS1: ::tcflag_t = 0x00002000;
1830 pub const VT1: ::tcflag_t = 0x00004000;
1831 pub const VWERASE: usize = 14;
1832 pub const VREPRINT: usize = 12;
1833 pub const VSUSP: usize = 10;
1834 pub const VSTART: usize = 8;
1835 pub const VSTOP: usize = 9;
1836 pub const VDISCARD: usize = 13;
1837 pub const VTIME: usize = 5;
1838 pub const IXON: ::tcflag_t = 0x00000400;
1839 pub const IXOFF: ::tcflag_t = 0x00001000;
1840 pub const ONLCR: ::tcflag_t = 0x4;
1841 pub const CSIZE: ::tcflag_t = 0x00000030;
1842 pub const CS6: ::tcflag_t = 0x00000010;
1843 pub const CS7: ::tcflag_t = 0x00000020;
1844 pub const CS8: ::tcflag_t = 0x00000030;
1845 pub const CSTOPB: ::tcflag_t = 0x00000040;
1846 pub const CREAD: ::tcflag_t = 0x00000080;
1847 pub const PARENB: ::tcflag_t = 0x00000100;
1848 pub const PARODD: ::tcflag_t = 0x00000200;
1849 pub const HUPCL: ::tcflag_t = 0x00000400;
1850 pub const CLOCAL: ::tcflag_t = 0x00000800;
1851 pub const ECHOKE: ::tcflag_t = 0x00000800;
1852 pub const ECHOE: ::tcflag_t = 0x00000010;
1853 pub const ECHOK: ::tcflag_t = 0x00000020;
1854 pub const ECHONL: ::tcflag_t = 0x00000040;
1855 pub const ECHOPRT: ::tcflag_t = 0x00000400;
1856 pub const ECHOCTL: ::tcflag_t = 0x00000200;
1857 pub const ISIG: ::tcflag_t = 0x00000001;
1858 pub const ICANON: ::tcflag_t = 0x00000002;
1859 pub const PENDIN: ::tcflag_t = 0x00004000;
1860 pub const NOFLSH: ::tcflag_t = 0x00000080;
1861 pub const VSWTC: usize = 7;
1862 pub const OLCUC: ::tcflag_t = 0o000002;
1863 pub const NLDLY: ::tcflag_t = 0o000400;
1864 pub const CRDLY: ::tcflag_t = 0o003000;
1865 pub const TABDLY: ::tcflag_t = 0o014000;
1866 pub const BSDLY: ::tcflag_t = 0o020000;
1867 pub const FFDLY: ::tcflag_t = 0o100000;
1868 pub const VTDLY: ::tcflag_t = 0o040000;
1869 pub const XTABS: ::tcflag_t = 0o014000;
1870 
1871 pub const B0: ::speed_t = 0o000000;
1872 pub const B50: ::speed_t = 0o000001;
1873 pub const B75: ::speed_t = 0o000002;
1874 pub const B110: ::speed_t = 0o000003;
1875 pub const B134: ::speed_t = 0o000004;
1876 pub const B150: ::speed_t = 0o000005;
1877 pub const B200: ::speed_t = 0o000006;
1878 pub const B300: ::speed_t = 0o000007;
1879 pub const B600: ::speed_t = 0o000010;
1880 pub const B1200: ::speed_t = 0o000011;
1881 pub const B1800: ::speed_t = 0o000012;
1882 pub const B2400: ::speed_t = 0o000013;
1883 pub const B4800: ::speed_t = 0o000014;
1884 pub const B9600: ::speed_t = 0o000015;
1885 pub const B19200: ::speed_t = 0o000016;
1886 pub const B38400: ::speed_t = 0o000017;
1887 pub const EXTA: ::speed_t = B19200;
1888 pub const EXTB: ::speed_t = B38400;
1889 pub const BOTHER: ::speed_t = 0o010000;
1890 pub const B57600: ::speed_t = 0o010001;
1891 pub const B115200: ::speed_t = 0o010002;
1892 pub const B230400: ::speed_t = 0o010003;
1893 pub const B460800: ::speed_t = 0o010004;
1894 pub const B500000: ::speed_t = 0o010005;
1895 pub const B576000: ::speed_t = 0o010006;
1896 pub const B921600: ::speed_t = 0o010007;
1897 pub const B1000000: ::speed_t = 0o010010;
1898 pub const B1152000: ::speed_t = 0o010011;
1899 pub const B1500000: ::speed_t = 0o010012;
1900 pub const B2000000: ::speed_t = 0o010013;
1901 pub const B2500000: ::speed_t = 0o010014;
1902 pub const B3000000: ::speed_t = 0o010015;
1903 pub const B3500000: ::speed_t = 0o010016;
1904 pub const B4000000: ::speed_t = 0o010017;
1905 pub const IBSHIFT: ::tcflag_t = 16;
1906 
1907 pub const BLKIOMIN: ::c_int = 0x1278;
1908 pub const BLKIOOPT: ::c_int = 0x1279;
1909 pub const BLKSSZGET: ::c_int = 0x1268;
1910 pub const BLKPBSZGET: ::c_int = 0x127B;
1911 
1912 cfg_if! {
1913     // Those type are constructed using the _IOC macro
1914     // DD-SS_SSSS_SSSS_SSSS-TTTT_TTTT-NNNN_NNNN
1915     // where D stands for direction (either None (00), Read (01) or Write (11))
1916     // where S stands for size (int, long, struct...)
1917     // where T stands for type ('f','v','X'...)
1918     // where N stands for NR (NumbeR)
1919     if #[cfg(any(target_arch = "x86", target_arch = "arm"))] {
1920         pub const FS_IOC_GETFLAGS: ::c_int = 0x80046601;
1921         pub const FS_IOC_SETFLAGS: ::c_int = 0x40046602;
1922         pub const FS_IOC_GETVERSION: ::c_int = 0x80047601;
1923         pub const FS_IOC_SETVERSION: ::c_int = 0x40047602;
1924         pub const FS_IOC32_GETFLAGS: ::c_int = 0x80046601;
1925         pub const FS_IOC32_SETFLAGS: ::c_int = 0x40046602;
1926         pub const FS_IOC32_GETVERSION: ::c_int = 0x80047601;
1927         pub const FS_IOC32_SETVERSION: ::c_int = 0x40047602;
1928     } else if #[cfg(any(target_arch = "x86_64", target_arch = "riscv64", target_arch = "aarch64"))] {
1929         pub const FS_IOC_GETFLAGS: ::c_int = 0x80086601;
1930         pub const FS_IOC_SETFLAGS: ::c_int = 0x40086602;
1931         pub const FS_IOC_GETVERSION: ::c_int = 0x80087601;
1932         pub const FS_IOC_SETVERSION: ::c_int = 0x40087602;
1933         pub const FS_IOC32_GETFLAGS: ::c_int = 0x80046601;
1934         pub const FS_IOC32_SETFLAGS: ::c_int = 0x40046602;
1935         pub const FS_IOC32_GETVERSION: ::c_int = 0x80047601;
1936         pub const FS_IOC32_SETVERSION: ::c_int = 0x40047602;
1937     }
1938 }
1939 
1940 pub const EAI_AGAIN: ::c_int = 2;
1941 pub const EAI_BADFLAGS: ::c_int = 3;
1942 pub const EAI_FAIL: ::c_int = 4;
1943 pub const EAI_FAMILY: ::c_int = 5;
1944 pub const EAI_MEMORY: ::c_int = 6;
1945 pub const EAI_NODATA: ::c_int = 7;
1946 pub const EAI_NONAME: ::c_int = 8;
1947 pub const EAI_SERVICE: ::c_int = 9;
1948 pub const EAI_SOCKTYPE: ::c_int = 10;
1949 pub const EAI_SYSTEM: ::c_int = 11;
1950 pub const EAI_OVERFLOW: ::c_int = 14;
1951 
1952 pub const NETLINK_ROUTE: ::c_int = 0;
1953 pub const NETLINK_UNUSED: ::c_int = 1;
1954 pub const NETLINK_USERSOCK: ::c_int = 2;
1955 pub const NETLINK_FIREWALL: ::c_int = 3;
1956 pub const NETLINK_SOCK_DIAG: ::c_int = 4;
1957 pub const NETLINK_NFLOG: ::c_int = 5;
1958 pub const NETLINK_XFRM: ::c_int = 6;
1959 pub const NETLINK_SELINUX: ::c_int = 7;
1960 pub const NETLINK_ISCSI: ::c_int = 8;
1961 pub const NETLINK_AUDIT: ::c_int = 9;
1962 pub const NETLINK_FIB_LOOKUP: ::c_int = 10;
1963 pub const NETLINK_CONNECTOR: ::c_int = 11;
1964 pub const NETLINK_NETFILTER: ::c_int = 12;
1965 pub const NETLINK_IP6_FW: ::c_int = 13;
1966 pub const NETLINK_DNRTMSG: ::c_int = 14;
1967 pub const NETLINK_KOBJECT_UEVENT: ::c_int = 15;
1968 pub const NETLINK_GENERIC: ::c_int = 16;
1969 pub const NETLINK_SCSITRANSPORT: ::c_int = 18;
1970 pub const NETLINK_ECRYPTFS: ::c_int = 19;
1971 pub const NETLINK_RDMA: ::c_int = 20;
1972 pub const NETLINK_CRYPTO: ::c_int = 21;
1973 pub const NETLINK_INET_DIAG: ::c_int = NETLINK_SOCK_DIAG;
1974 
1975 pub const MAX_LINKS: ::c_int = 32;
1976 
1977 pub const NLM_F_REQUEST: ::c_int = 1;
1978 pub const NLM_F_MULTI: ::c_int = 2;
1979 pub const NLM_F_ACK: ::c_int = 4;
1980 pub const NLM_F_ECHO: ::c_int = 8;
1981 pub const NLM_F_DUMP_INTR: ::c_int = 16;
1982 pub const NLM_F_DUMP_FILTERED: ::c_int = 32;
1983 
1984 pub const NLM_F_ROOT: ::c_int = 0x100;
1985 pub const NLM_F_MATCH: ::c_int = 0x200;
1986 pub const NLM_F_ATOMIC: ::c_int = 0x400;
1987 pub const NLM_F_DUMP: ::c_int = NLM_F_ROOT | NLM_F_MATCH;
1988 
1989 pub const NLM_F_REPLACE: ::c_int = 0x100;
1990 pub const NLM_F_EXCL: ::c_int = 0x200;
1991 pub const NLM_F_CREATE: ::c_int = 0x400;
1992 pub const NLM_F_APPEND: ::c_int = 0x800;
1993 
1994 pub const NLMSG_NOOP: ::c_int = 0x1;
1995 pub const NLMSG_ERROR: ::c_int = 0x2;
1996 pub const NLMSG_DONE: ::c_int = 0x3;
1997 pub const NLMSG_OVERRUN: ::c_int = 0x4;
1998 pub const NLMSG_MIN_TYPE: ::c_int = 0x10;
1999 
2000 // linux/netfilter/nfnetlink.h
2001 pub const NFNLGRP_NONE: ::c_int = 0;
2002 pub const NFNLGRP_CONNTRACK_NEW: ::c_int = 1;
2003 pub const NFNLGRP_CONNTRACK_UPDATE: ::c_int = 2;
2004 pub const NFNLGRP_CONNTRACK_DESTROY: ::c_int = 3;
2005 pub const NFNLGRP_CONNTRACK_EXP_NEW: ::c_int = 4;
2006 pub const NFNLGRP_CONNTRACK_EXP_UPDATE: ::c_int = 5;
2007 pub const NFNLGRP_CONNTRACK_EXP_DESTROY: ::c_int = 6;
2008 pub const NFNLGRP_NFTABLES: ::c_int = 7;
2009 pub const NFNLGRP_ACCT_QUOTA: ::c_int = 8;
2010 
2011 pub const NFNETLINK_V0: ::c_int = 0;
2012 
2013 pub const NFNL_SUBSYS_NONE: ::c_int = 0;
2014 pub const NFNL_SUBSYS_CTNETLINK: ::c_int = 1;
2015 pub const NFNL_SUBSYS_CTNETLINK_EXP: ::c_int = 2;
2016 pub const NFNL_SUBSYS_QUEUE: ::c_int = 3;
2017 pub const NFNL_SUBSYS_ULOG: ::c_int = 4;
2018 pub const NFNL_SUBSYS_OSF: ::c_int = 5;
2019 pub const NFNL_SUBSYS_IPSET: ::c_int = 6;
2020 pub const NFNL_SUBSYS_ACCT: ::c_int = 7;
2021 pub const NFNL_SUBSYS_CTNETLINK_TIMEOUT: ::c_int = 8;
2022 pub const NFNL_SUBSYS_CTHELPER: ::c_int = 9;
2023 pub const NFNL_SUBSYS_NFTABLES: ::c_int = 10;
2024 pub const NFNL_SUBSYS_NFT_COMPAT: ::c_int = 11;
2025 pub const NFNL_SUBSYS_COUNT: ::c_int = 12;
2026 
2027 pub const NFNL_MSG_BATCH_BEGIN: ::c_int = NLMSG_MIN_TYPE;
2028 pub const NFNL_MSG_BATCH_END: ::c_int = NLMSG_MIN_TYPE + 1;
2029 
2030 // linux/netfilter/nfnetlink_log.h
2031 pub const NFULNL_MSG_PACKET: ::c_int = 0;
2032 pub const NFULNL_MSG_CONFIG: ::c_int = 1;
2033 
2034 pub const NFULA_UNSPEC: ::c_int = 0;
2035 pub const NFULA_PACKET_HDR: ::c_int = 1;
2036 pub const NFULA_MARK: ::c_int = 2;
2037 pub const NFULA_TIMESTAMP: ::c_int = 3;
2038 pub const NFULA_IFINDEX_INDEV: ::c_int = 4;
2039 pub const NFULA_IFINDEX_OUTDEV: ::c_int = 5;
2040 pub const NFULA_IFINDEX_PHYSINDEV: ::c_int = 6;
2041 pub const NFULA_IFINDEX_PHYSOUTDEV: ::c_int = 7;
2042 pub const NFULA_HWADDR: ::c_int = 8;
2043 pub const NFULA_PAYLOAD: ::c_int = 9;
2044 pub const NFULA_PREFIX: ::c_int = 10;
2045 pub const NFULA_UID: ::c_int = 11;
2046 pub const NFULA_SEQ: ::c_int = 12;
2047 pub const NFULA_SEQ_GLOBAL: ::c_int = 13;
2048 pub const NFULA_GID: ::c_int = 14;
2049 pub const NFULA_HWTYPE: ::c_int = 15;
2050 pub const NFULA_HWHEADER: ::c_int = 16;
2051 pub const NFULA_HWLEN: ::c_int = 17;
2052 pub const NFULA_CT: ::c_int = 18;
2053 pub const NFULA_CT_INFO: ::c_int = 19;
2054 
2055 pub const NFULNL_CFG_CMD_NONE: ::c_int = 0;
2056 pub const NFULNL_CFG_CMD_BIND: ::c_int = 1;
2057 pub const NFULNL_CFG_CMD_UNBIND: ::c_int = 2;
2058 pub const NFULNL_CFG_CMD_PF_BIND: ::c_int = 3;
2059 pub const NFULNL_CFG_CMD_PF_UNBIND: ::c_int = 4;
2060 
2061 pub const NFULA_CFG_UNSPEC: ::c_int = 0;
2062 pub const NFULA_CFG_CMD: ::c_int = 1;
2063 pub const NFULA_CFG_MODE: ::c_int = 2;
2064 pub const NFULA_CFG_NLBUFSIZ: ::c_int = 3;
2065 pub const NFULA_CFG_TIMEOUT: ::c_int = 4;
2066 pub const NFULA_CFG_QTHRESH: ::c_int = 5;
2067 pub const NFULA_CFG_FLAGS: ::c_int = 6;
2068 
2069 pub const NFULNL_COPY_NONE: ::c_int = 0x00;
2070 pub const NFULNL_COPY_META: ::c_int = 0x01;
2071 pub const NFULNL_COPY_PACKET: ::c_int = 0x02;
2072 
2073 pub const NFULNL_CFG_F_SEQ: ::c_int = 0x0001;
2074 pub const NFULNL_CFG_F_SEQ_GLOBAL: ::c_int = 0x0002;
2075 pub const NFULNL_CFG_F_CONNTRACK: ::c_int = 0x0004;
2076 
2077 // linux/netfilter/nfnetlink_log.h
2078 pub const NFQNL_MSG_PACKET: ::c_int = 0;
2079 pub const NFQNL_MSG_VERDICT: ::c_int = 1;
2080 pub const NFQNL_MSG_CONFIG: ::c_int = 2;
2081 pub const NFQNL_MSG_VERDICT_BATCH: ::c_int = 3;
2082 
2083 pub const NFQA_UNSPEC: ::c_int = 0;
2084 pub const NFQA_PACKET_HDR: ::c_int = 1;
2085 pub const NFQA_VERDICT_HDR: ::c_int = 2;
2086 pub const NFQA_MARK: ::c_int = 3;
2087 pub const NFQA_TIMESTAMP: ::c_int = 4;
2088 pub const NFQA_IFINDEX_INDEV: ::c_int = 5;
2089 pub const NFQA_IFINDEX_OUTDEV: ::c_int = 6;
2090 pub const NFQA_IFINDEX_PHYSINDEV: ::c_int = 7;
2091 pub const NFQA_IFINDEX_PHYSOUTDEV: ::c_int = 8;
2092 pub const NFQA_HWADDR: ::c_int = 9;
2093 pub const NFQA_PAYLOAD: ::c_int = 10;
2094 pub const NFQA_CT: ::c_int = 11;
2095 pub const NFQA_CT_INFO: ::c_int = 12;
2096 pub const NFQA_CAP_LEN: ::c_int = 13;
2097 pub const NFQA_SKB_INFO: ::c_int = 14;
2098 pub const NFQA_EXP: ::c_int = 15;
2099 pub const NFQA_UID: ::c_int = 16;
2100 pub const NFQA_GID: ::c_int = 17;
2101 pub const NFQA_SECCTX: ::c_int = 18;
2102 /*
2103  FIXME: These are not yet available in musl sanitized kernel headers and
2104  make the tests fail. Enable them once musl has them.
2105 
2106  See https://github.com/rust-lang/libc/pull/1628 for more details.
2107 pub const NFQA_VLAN: ::c_int = 19;
2108 pub const NFQA_L2HDR: ::c_int = 20;
2109 
2110 pub const NFQA_VLAN_UNSPEC: ::c_int = 0;
2111 pub const NFQA_VLAN_PROTO: ::c_int = 1;
2112 pub const NFQA_VLAN_TCI: ::c_int = 2;
2113 */
2114 
2115 pub const NFQNL_CFG_CMD_NONE: ::c_int = 0;
2116 pub const NFQNL_CFG_CMD_BIND: ::c_int = 1;
2117 pub const NFQNL_CFG_CMD_UNBIND: ::c_int = 2;
2118 pub const NFQNL_CFG_CMD_PF_BIND: ::c_int = 3;
2119 pub const NFQNL_CFG_CMD_PF_UNBIND: ::c_int = 4;
2120 
2121 pub const NFQNL_COPY_NONE: ::c_int = 0;
2122 pub const NFQNL_COPY_META: ::c_int = 1;
2123 pub const NFQNL_COPY_PACKET: ::c_int = 2;
2124 
2125 pub const NFQA_CFG_UNSPEC: ::c_int = 0;
2126 pub const NFQA_CFG_CMD: ::c_int = 1;
2127 pub const NFQA_CFG_PARAMS: ::c_int = 2;
2128 pub const NFQA_CFG_QUEUE_MAXLEN: ::c_int = 3;
2129 pub const NFQA_CFG_MASK: ::c_int = 4;
2130 pub const NFQA_CFG_FLAGS: ::c_int = 5;
2131 
2132 pub const NFQA_CFG_F_FAIL_OPEN: ::c_int = 0x0001;
2133 pub const NFQA_CFG_F_CONNTRACK: ::c_int = 0x0002;
2134 pub const NFQA_CFG_F_GSO: ::c_int = 0x0004;
2135 pub const NFQA_CFG_F_UID_GID: ::c_int = 0x0008;
2136 pub const NFQA_CFG_F_SECCTX: ::c_int = 0x0010;
2137 pub const NFQA_CFG_F_MAX: ::c_int = 0x0020;
2138 
2139 pub const NFQA_SKB_CSUMNOTREADY: ::c_int = 0x0001;
2140 pub const NFQA_SKB_GSO: ::c_int = 0x0002;
2141 pub const NFQA_SKB_CSUM_NOTVERIFIED: ::c_int = 0x0004;
2142 
2143 pub const GENL_NAMSIZ: ::c_int = 16;
2144 
2145 pub const GENL_MIN_ID: ::c_int = NLMSG_MIN_TYPE;
2146 pub const GENL_MAX_ID: ::c_int = 1023;
2147 
2148 pub const GENL_ADMIN_PERM: ::c_int = 0x01;
2149 pub const GENL_CMD_CAP_DO: ::c_int = 0x02;
2150 pub const GENL_CMD_CAP_DUMP: ::c_int = 0x04;
2151 pub const GENL_CMD_CAP_HASPOL: ::c_int = 0x08;
2152 pub const GENL_UNS_ADMIN_PERM: ::c_int = 0x10;
2153 
2154 pub const GENL_ID_CTRL: ::c_int = NLMSG_MIN_TYPE;
2155 pub const GENL_ID_VFS_DQUOT: ::c_int = NLMSG_MIN_TYPE + 1;
2156 pub const GENL_ID_PMCRAID: ::c_int = NLMSG_MIN_TYPE + 2;
2157 
2158 pub const CTRL_CMD_UNSPEC: ::c_int = 0;
2159 pub const CTRL_CMD_NEWFAMILY: ::c_int = 1;
2160 pub const CTRL_CMD_DELFAMILY: ::c_int = 2;
2161 pub const CTRL_CMD_GETFAMILY: ::c_int = 3;
2162 pub const CTRL_CMD_NEWOPS: ::c_int = 4;
2163 pub const CTRL_CMD_DELOPS: ::c_int = 5;
2164 pub const CTRL_CMD_GETOPS: ::c_int = 6;
2165 pub const CTRL_CMD_NEWMCAST_GRP: ::c_int = 7;
2166 pub const CTRL_CMD_DELMCAST_GRP: ::c_int = 8;
2167 pub const CTRL_CMD_GETMCAST_GRP: ::c_int = 9;
2168 
2169 pub const CTRL_ATTR_UNSPEC: ::c_int = 0;
2170 pub const CTRL_ATTR_FAMILY_ID: ::c_int = 1;
2171 pub const CTRL_ATTR_FAMILY_NAME: ::c_int = 2;
2172 pub const CTRL_ATTR_VERSION: ::c_int = 3;
2173 pub const CTRL_ATTR_HDRSIZE: ::c_int = 4;
2174 pub const CTRL_ATTR_MAXATTR: ::c_int = 5;
2175 pub const CTRL_ATTR_OPS: ::c_int = 6;
2176 pub const CTRL_ATTR_MCAST_GROUPS: ::c_int = 7;
2177 
2178 pub const CTRL_ATTR_OP_UNSPEC: ::c_int = 0;
2179 pub const CTRL_ATTR_OP_ID: ::c_int = 1;
2180 pub const CTRL_ATTR_OP_FLAGS: ::c_int = 2;
2181 
2182 pub const CTRL_ATTR_MCAST_GRP_UNSPEC: ::c_int = 0;
2183 pub const CTRL_ATTR_MCAST_GRP_NAME: ::c_int = 1;
2184 pub const CTRL_ATTR_MCAST_GRP_ID: ::c_int = 2;
2185 
2186 pub const NETLINK_ADD_MEMBERSHIP: ::c_int = 1;
2187 pub const NETLINK_DROP_MEMBERSHIP: ::c_int = 2;
2188 pub const NETLINK_PKTINFO: ::c_int = 3;
2189 pub const NETLINK_BROADCAST_ERROR: ::c_int = 4;
2190 pub const NETLINK_NO_ENOBUFS: ::c_int = 5;
2191 pub const NETLINK_RX_RING: ::c_int = 6;
2192 pub const NETLINK_TX_RING: ::c_int = 7;
2193 pub const NETLINK_LISTEN_ALL_NSID: ::c_int = 8;
2194 pub const NETLINK_LIST_MEMBERSHIPS: ::c_int = 9;
2195 pub const NETLINK_CAP_ACK: ::c_int = 10;
2196 pub const NETLINK_EXT_ACK: ::c_int = 11;
2197 pub const NETLINK_GET_STRICT_CHK: ::c_int = 12;
2198 
2199 pub const GRND_NONBLOCK: ::c_uint = 0x0001;
2200 pub const GRND_RANDOM: ::c_uint = 0x0002;
2201 pub const GRND_INSECURE: ::c_uint = 0x0004;
2202 
2203 pub const SECCOMP_MODE_DISABLED: ::c_uint = 0;
2204 pub const SECCOMP_MODE_STRICT: ::c_uint = 1;
2205 pub const SECCOMP_MODE_FILTER: ::c_uint = 2;
2206 
2207 pub const SECCOMP_FILTER_FLAG_TSYNC: ::c_ulong = 1;
2208 pub const SECCOMP_FILTER_FLAG_LOG: ::c_ulong = 2;
2209 pub const SECCOMP_FILTER_FLAG_SPEC_ALLOW: ::c_ulong = 4;
2210 pub const SECCOMP_FILTER_FLAG_NEW_LISTENER: ::c_ulong = 8;
2211 
2212 pub const SECCOMP_RET_ACTION_FULL: ::c_uint = 0xffff0000;
2213 pub const SECCOMP_RET_ACTION: ::c_uint = 0x7fff0000;
2214 pub const SECCOMP_RET_DATA: ::c_uint = 0x0000ffff;
2215 
2216 pub const SECCOMP_RET_KILL_PROCESS: ::c_uint = 0x80000000;
2217 pub const SECCOMP_RET_KILL_THREAD: ::c_uint = 0x00000000;
2218 pub const SECCOMP_RET_KILL: ::c_uint = SECCOMP_RET_KILL_THREAD;
2219 pub const SECCOMP_RET_TRAP: ::c_uint = 0x00030000;
2220 pub const SECCOMP_RET_ERRNO: ::c_uint = 0x00050000;
2221 pub const SECCOMP_RET_USER_NOTIF: ::c_uint = 0x7fc00000;
2222 pub const SECCOMP_RET_TRACE: ::c_uint = 0x7ff00000;
2223 pub const SECCOMP_RET_LOG: ::c_uint = 0x7ffc0000;
2224 pub const SECCOMP_RET_ALLOW: ::c_uint = 0x7fff0000;
2225 
2226 pub const NLA_F_NESTED: ::c_int = 1 << 15;
2227 pub const NLA_F_NET_BYTEORDER: ::c_int = 1 << 14;
2228 pub const NLA_TYPE_MASK: ::c_int = !(NLA_F_NESTED | NLA_F_NET_BYTEORDER);
2229 
2230 pub const NLA_ALIGNTO: ::c_int = 4;
2231 
2232 pub const SIGEV_THREAD_ID: ::c_int = 4;
2233 
2234 pub const CIBAUD: ::tcflag_t = 0o02003600000;
2235 pub const CBAUDEX: ::tcflag_t = 0o010000;
2236 
2237 pub const TIOCM_LE: ::c_int = 0x001;
2238 pub const TIOCM_DTR: ::c_int = 0x002;
2239 pub const TIOCM_RTS: ::c_int = 0x004;
2240 pub const TIOCM_ST: ::c_int = 0x008;
2241 pub const TIOCM_SR: ::c_int = 0x010;
2242 pub const TIOCM_CTS: ::c_int = 0x020;
2243 pub const TIOCM_CAR: ::c_int = 0x040;
2244 pub const TIOCM_RNG: ::c_int = 0x080;
2245 pub const TIOCM_DSR: ::c_int = 0x100;
2246 pub const TIOCM_CD: ::c_int = TIOCM_CAR;
2247 pub const TIOCM_RI: ::c_int = TIOCM_RNG;
2248 
2249 pub const POLLWRNORM: ::c_short = 0x100;
2250 pub const POLLWRBAND: ::c_short = 0x200;
2251 
2252 pub const SFD_CLOEXEC: ::c_int = O_CLOEXEC;
2253 pub const SFD_NONBLOCK: ::c_int = O_NONBLOCK;
2254 
2255 pub const SOCK_NONBLOCK: ::c_int = O_NONBLOCK;
2256 
2257 pub const SO_ORIGINAL_DST: ::c_int = 80;
2258 
2259 pub const IP_RECVFRAGSIZE: ::c_int = 25;
2260 
2261 pub const IPV6_FLOWINFO: ::c_int = 11;
2262 pub const IPV6_MULTICAST_ALL: ::c_int = 29;
2263 pub const IPV6_ROUTER_ALERT_ISOLATE: ::c_int = 30;
2264 pub const IPV6_FLOWLABEL_MGR: ::c_int = 32;
2265 pub const IPV6_FLOWINFO_SEND: ::c_int = 33;
2266 pub const IPV6_RECVFRAGSIZE: ::c_int = 77;
2267 pub const IPV6_FREEBIND: ::c_int = 78;
2268 pub const IPV6_FLOWINFO_FLOWLABEL: ::c_int = 0x000fffff;
2269 pub const IPV6_FLOWINFO_PRIORITY: ::c_int = 0x0ff00000;
2270 
2271 pub const IUTF8: ::tcflag_t = 0x00004000;
2272 pub const CMSPAR: ::tcflag_t = 0o10000000000;
2273 pub const O_TMPFILE: ::c_int = 0o20000000 | O_DIRECTORY;
2274 
2275 pub const MFD_CLOEXEC: ::c_uint = 0x0001;
2276 pub const MFD_ALLOW_SEALING: ::c_uint = 0x0002;
2277 pub const MFD_HUGETLB: ::c_uint = 0x0004;
2278 pub const MFD_NOEXEC_SEAL: ::c_uint = 0x0008;
2279 pub const MFD_EXEC: ::c_uint = 0x0010;
2280 pub const MFD_HUGE_64KB: ::c_uint = 0x40000000;
2281 pub const MFD_HUGE_512KB: ::c_uint = 0x4c000000;
2282 pub const MFD_HUGE_1MB: ::c_uint = 0x50000000;
2283 pub const MFD_HUGE_2MB: ::c_uint = 0x54000000;
2284 pub const MFD_HUGE_8MB: ::c_uint = 0x5c000000;
2285 pub const MFD_HUGE_16MB: ::c_uint = 0x60000000;
2286 pub const MFD_HUGE_32MB: ::c_uint = 0x64000000;
2287 pub const MFD_HUGE_256MB: ::c_uint = 0x70000000;
2288 pub const MFD_HUGE_512MB: ::c_uint = 0x74000000;
2289 pub const MFD_HUGE_1GB: ::c_uint = 0x78000000;
2290 pub const MFD_HUGE_2GB: ::c_uint = 0x7c000000;
2291 pub const MFD_HUGE_16GB: ::c_uint = 0x88000000;
2292 pub const MFD_HUGE_MASK: ::c_uint = 63;
2293 pub const MFD_HUGE_SHIFT: ::c_uint = 26;
2294 
2295 // these are used in the p_type field of Elf32_Phdr and Elf64_Phdr, which has
2296 // the type Elf32Word and Elf64Word respectively. Luckily, both of those are u32
2297 // so we can use that type here to avoid having to cast.
2298 pub const PT_NULL: u32 = 0;
2299 pub const PT_LOAD: u32 = 1;
2300 pub const PT_DYNAMIC: u32 = 2;
2301 pub const PT_INTERP: u32 = 3;
2302 pub const PT_NOTE: u32 = 4;
2303 pub const PT_SHLIB: u32 = 5;
2304 pub const PT_PHDR: u32 = 6;
2305 pub const PT_TLS: u32 = 7;
2306 pub const PT_LOOS: u32 = 0x60000000;
2307 pub const PT_GNU_EH_FRAME: u32 = 0x6474e550;
2308 pub const PT_GNU_STACK: u32 = 0x6474e551;
2309 pub const PT_GNU_RELRO: u32 = 0x6474e552;
2310 pub const PT_HIOS: u32 = 0x6fffffff;
2311 pub const PT_LOPROC: u32 = 0x70000000;
2312 pub const PT_HIPROC: u32 = 0x7fffffff;
2313 
2314 // uapi/linux/mount.h
2315 pub const OPEN_TREE_CLONE: ::c_uint = 0x01;
2316 pub const OPEN_TREE_CLOEXEC: ::c_uint = O_CLOEXEC as ::c_uint;
2317 
2318 // linux/netfilter.h
2319 pub const NF_DROP: ::c_int = 0;
2320 pub const NF_ACCEPT: ::c_int = 1;
2321 pub const NF_STOLEN: ::c_int = 2;
2322 pub const NF_QUEUE: ::c_int = 3;
2323 pub const NF_REPEAT: ::c_int = 4;
2324 pub const NF_STOP: ::c_int = 5;
2325 pub const NF_MAX_VERDICT: ::c_int = NF_STOP;
2326 
2327 pub const NF_VERDICT_MASK: ::c_int = 0x000000ff;
2328 pub const NF_VERDICT_FLAG_QUEUE_BYPASS: ::c_int = 0x00008000;
2329 
2330 pub const NF_VERDICT_QMASK: ::c_int = 0xffff0000;
2331 pub const NF_VERDICT_QBITS: ::c_int = 16;
2332 
2333 pub const NF_VERDICT_BITS: ::c_int = 16;
2334 
2335 pub const NF_INET_PRE_ROUTING: ::c_int = 0;
2336 pub const NF_INET_LOCAL_IN: ::c_int = 1;
2337 pub const NF_INET_FORWARD: ::c_int = 2;
2338 pub const NF_INET_LOCAL_OUT: ::c_int = 3;
2339 pub const NF_INET_POST_ROUTING: ::c_int = 4;
2340 pub const NF_INET_NUMHOOKS: ::c_int = 5;
2341 
2342 pub const NF_NETDEV_INGRESS: ::c_int = 0;
2343 pub const NF_NETDEV_NUMHOOKS: ::c_int = 1;
2344 
2345 pub const NFPROTO_UNSPEC: ::c_int = 0;
2346 pub const NFPROTO_INET: ::c_int = 1;
2347 pub const NFPROTO_IPV4: ::c_int = 2;
2348 pub const NFPROTO_ARP: ::c_int = 3;
2349 pub const NFPROTO_NETDEV: ::c_int = 5;
2350 pub const NFPROTO_BRIDGE: ::c_int = 7;
2351 pub const NFPROTO_IPV6: ::c_int = 10;
2352 pub const NFPROTO_DECNET: ::c_int = 12;
2353 pub const NFPROTO_NUMPROTO: ::c_int = 13;
2354 
2355 // linux/netfilter_ipv4.h
2356 pub const NF_IP_PRE_ROUTING: ::c_int = 0;
2357 pub const NF_IP_LOCAL_IN: ::c_int = 1;
2358 pub const NF_IP_FORWARD: ::c_int = 2;
2359 pub const NF_IP_LOCAL_OUT: ::c_int = 3;
2360 pub const NF_IP_POST_ROUTING: ::c_int = 4;
2361 pub const NF_IP_NUMHOOKS: ::c_int = 5;
2362 
2363 pub const NF_IP_PRI_FIRST: ::c_int = ::INT_MIN;
2364 pub const NF_IP_PRI_CONNTRACK_DEFRAG: ::c_int = -400;
2365 pub const NF_IP_PRI_RAW: ::c_int = -300;
2366 pub const NF_IP_PRI_SELINUX_FIRST: ::c_int = -225;
2367 pub const NF_IP_PRI_CONNTRACK: ::c_int = -200;
2368 pub const NF_IP_PRI_MANGLE: ::c_int = -150;
2369 pub const NF_IP_PRI_NAT_DST: ::c_int = -100;
2370 pub const NF_IP_PRI_FILTER: ::c_int = 0;
2371 pub const NF_IP_PRI_SECURITY: ::c_int = 50;
2372 pub const NF_IP_PRI_NAT_SRC: ::c_int = 100;
2373 pub const NF_IP_PRI_SELINUX_LAST: ::c_int = 225;
2374 pub const NF_IP_PRI_CONNTRACK_HELPER: ::c_int = 300;
2375 pub const NF_IP_PRI_CONNTRACK_CONFIRM: ::c_int = ::INT_MAX;
2376 pub const NF_IP_PRI_LAST: ::c_int = ::INT_MAX;
2377 
2378 // linux/netfilter_ipv6.h
2379 pub const NF_IP6_PRE_ROUTING: ::c_int = 0;
2380 pub const NF_IP6_LOCAL_IN: ::c_int = 1;
2381 pub const NF_IP6_FORWARD: ::c_int = 2;
2382 pub const NF_IP6_LOCAL_OUT: ::c_int = 3;
2383 pub const NF_IP6_POST_ROUTING: ::c_int = 4;
2384 pub const NF_IP6_NUMHOOKS: ::c_int = 5;
2385 
2386 pub const NF_IP6_PRI_FIRST: ::c_int = ::INT_MIN;
2387 pub const NF_IP6_PRI_CONNTRACK_DEFRAG: ::c_int = -400;
2388 pub const NF_IP6_PRI_RAW: ::c_int = -300;
2389 pub const NF_IP6_PRI_SELINUX_FIRST: ::c_int = -225;
2390 pub const NF_IP6_PRI_CONNTRACK: ::c_int = -200;
2391 pub const NF_IP6_PRI_MANGLE: ::c_int = -150;
2392 pub const NF_IP6_PRI_NAT_DST: ::c_int = -100;
2393 pub const NF_IP6_PRI_FILTER: ::c_int = 0;
2394 pub const NF_IP6_PRI_SECURITY: ::c_int = 50;
2395 pub const NF_IP6_PRI_NAT_SRC: ::c_int = 100;
2396 pub const NF_IP6_PRI_SELINUX_LAST: ::c_int = 225;
2397 pub const NF_IP6_PRI_CONNTRACK_HELPER: ::c_int = 300;
2398 pub const NF_IP6_PRI_LAST: ::c_int = ::INT_MAX;
2399 
2400 // linux/netfilter_ipv6/ip6_tables.h
2401 pub const IP6T_SO_ORIGINAL_DST: ::c_int = 80;
2402 
2403 // linux/netfilter/nf_tables.h
2404 pub const NFT_TABLE_MAXNAMELEN: ::c_int = 256;
2405 pub const NFT_CHAIN_MAXNAMELEN: ::c_int = 256;
2406 pub const NFT_SET_MAXNAMELEN: ::c_int = 256;
2407 pub const NFT_OBJ_MAXNAMELEN: ::c_int = 256;
2408 pub const NFT_USERDATA_MAXLEN: ::c_int = 256;
2409 
2410 pub const NFT_REG_VERDICT: ::c_int = 0;
2411 pub const NFT_REG_1: ::c_int = 1;
2412 pub const NFT_REG_2: ::c_int = 2;
2413 pub const NFT_REG_3: ::c_int = 3;
2414 pub const NFT_REG_4: ::c_int = 4;
2415 pub const __NFT_REG_MAX: ::c_int = 5;
2416 pub const NFT_REG32_00: ::c_int = 8;
2417 pub const NFT_REG32_01: ::c_int = 9;
2418 pub const NFT_REG32_02: ::c_int = 10;
2419 pub const NFT_REG32_03: ::c_int = 11;
2420 pub const NFT_REG32_04: ::c_int = 12;
2421 pub const NFT_REG32_05: ::c_int = 13;
2422 pub const NFT_REG32_06: ::c_int = 14;
2423 pub const NFT_REG32_07: ::c_int = 15;
2424 pub const NFT_REG32_08: ::c_int = 16;
2425 pub const NFT_REG32_09: ::c_int = 17;
2426 pub const NFT_REG32_10: ::c_int = 18;
2427 pub const NFT_REG32_11: ::c_int = 19;
2428 pub const NFT_REG32_12: ::c_int = 20;
2429 pub const NFT_REG32_13: ::c_int = 21;
2430 pub const NFT_REG32_14: ::c_int = 22;
2431 pub const NFT_REG32_15: ::c_int = 23;
2432 
2433 pub const NFT_REG_SIZE: ::c_int = 16;
2434 pub const NFT_REG32_SIZE: ::c_int = 4;
2435 
2436 pub const NFT_CONTINUE: ::c_int = -1;
2437 pub const NFT_BREAK: ::c_int = -2;
2438 pub const NFT_JUMP: ::c_int = -3;
2439 pub const NFT_GOTO: ::c_int = -4;
2440 pub const NFT_RETURN: ::c_int = -5;
2441 
2442 pub const NFT_MSG_NEWTABLE: ::c_int = 0;
2443 pub const NFT_MSG_GETTABLE: ::c_int = 1;
2444 pub const NFT_MSG_DELTABLE: ::c_int = 2;
2445 pub const NFT_MSG_NEWCHAIN: ::c_int = 3;
2446 pub const NFT_MSG_GETCHAIN: ::c_int = 4;
2447 pub const NFT_MSG_DELCHAIN: ::c_int = 5;
2448 pub const NFT_MSG_NEWRULE: ::c_int = 6;
2449 pub const NFT_MSG_GETRULE: ::c_int = 7;
2450 pub const NFT_MSG_DELRULE: ::c_int = 8;
2451 pub const NFT_MSG_NEWSET: ::c_int = 9;
2452 pub const NFT_MSG_GETSET: ::c_int = 10;
2453 pub const NFT_MSG_DELSET: ::c_int = 11;
2454 pub const NFT_MSG_NEWSETELEM: ::c_int = 12;
2455 pub const NFT_MSG_GETSETELEM: ::c_int = 13;
2456 pub const NFT_MSG_DELSETELEM: ::c_int = 14;
2457 pub const NFT_MSG_NEWGEN: ::c_int = 15;
2458 pub const NFT_MSG_GETGEN: ::c_int = 16;
2459 pub const NFT_MSG_TRACE: ::c_int = 17;
2460 pub const NFT_MSG_NEWOBJ: ::c_int = 18;
2461 pub const NFT_MSG_GETOBJ: ::c_int = 19;
2462 pub const NFT_MSG_DELOBJ: ::c_int = 20;
2463 pub const NFT_MSG_GETOBJ_RESET: ::c_int = 21;
2464 pub const NFT_MSG_MAX: ::c_int = 25;
2465 
2466 pub const NFT_SET_ANONYMOUS: ::c_int = 0x1;
2467 pub const NFT_SET_CONSTANT: ::c_int = 0x2;
2468 pub const NFT_SET_INTERVAL: ::c_int = 0x4;
2469 pub const NFT_SET_MAP: ::c_int = 0x8;
2470 pub const NFT_SET_TIMEOUT: ::c_int = 0x10;
2471 pub const NFT_SET_EVAL: ::c_int = 0x20;
2472 
2473 pub const NFT_SET_POL_PERFORMANCE: ::c_int = 0;
2474 pub const NFT_SET_POL_MEMORY: ::c_int = 1;
2475 
2476 pub const NFT_SET_ELEM_INTERVAL_END: ::c_int = 0x1;
2477 
2478 pub const NFT_DATA_VALUE: ::c_uint = 0;
2479 pub const NFT_DATA_VERDICT: ::c_uint = 0xffffff00;
2480 
2481 pub const NFT_DATA_RESERVED_MASK: ::c_uint = 0xffffff00;
2482 
2483 pub const NFT_DATA_VALUE_MAXLEN: ::c_int = 64;
2484 
2485 pub const NFT_BYTEORDER_NTOH: ::c_int = 0;
2486 pub const NFT_BYTEORDER_HTON: ::c_int = 1;
2487 
2488 pub const NFT_CMP_EQ: ::c_int = 0;
2489 pub const NFT_CMP_NEQ: ::c_int = 1;
2490 pub const NFT_CMP_LT: ::c_int = 2;
2491 pub const NFT_CMP_LTE: ::c_int = 3;
2492 pub const NFT_CMP_GT: ::c_int = 4;
2493 pub const NFT_CMP_GTE: ::c_int = 5;
2494 
2495 pub const NFT_RANGE_EQ: ::c_int = 0;
2496 pub const NFT_RANGE_NEQ: ::c_int = 1;
2497 
2498 pub const NFT_LOOKUP_F_INV: ::c_int = 1 << 0;
2499 
2500 pub const NFT_DYNSET_OP_ADD: ::c_int = 0;
2501 pub const NFT_DYNSET_OP_UPDATE: ::c_int = 1;
2502 
2503 pub const NFT_DYNSET_F_INV: ::c_int = 1 << 0;
2504 
2505 pub const NFT_PAYLOAD_LL_HEADER: ::c_int = 0;
2506 pub const NFT_PAYLOAD_NETWORK_HEADER: ::c_int = 1;
2507 pub const NFT_PAYLOAD_TRANSPORT_HEADER: ::c_int = 2;
2508 
2509 pub const NFT_PAYLOAD_CSUM_NONE: ::c_int = 0;
2510 pub const NFT_PAYLOAD_CSUM_INET: ::c_int = 1;
2511 
2512 pub const NFT_META_LEN: ::c_int = 0;
2513 pub const NFT_META_PROTOCOL: ::c_int = 1;
2514 pub const NFT_META_PRIORITY: ::c_int = 2;
2515 pub const NFT_META_MARK: ::c_int = 3;
2516 pub const NFT_META_IIF: ::c_int = 4;
2517 pub const NFT_META_OIF: ::c_int = 5;
2518 pub const NFT_META_IIFNAME: ::c_int = 6;
2519 pub const NFT_META_OIFNAME: ::c_int = 7;
2520 pub const NFT_META_IIFTYPE: ::c_int = 8;
2521 pub const NFT_META_OIFTYPE: ::c_int = 9;
2522 pub const NFT_META_SKUID: ::c_int = 10;
2523 pub const NFT_META_SKGID: ::c_int = 11;
2524 pub const NFT_META_NFTRACE: ::c_int = 12;
2525 pub const NFT_META_RTCLASSID: ::c_int = 13;
2526 pub const NFT_META_SECMARK: ::c_int = 14;
2527 pub const NFT_META_NFPROTO: ::c_int = 15;
2528 pub const NFT_META_L4PROTO: ::c_int = 16;
2529 pub const NFT_META_BRI_IIFNAME: ::c_int = 17;
2530 pub const NFT_META_BRI_OIFNAME: ::c_int = 18;
2531 pub const NFT_META_PKTTYPE: ::c_int = 19;
2532 pub const NFT_META_CPU: ::c_int = 20;
2533 pub const NFT_META_IIFGROUP: ::c_int = 21;
2534 pub const NFT_META_OIFGROUP: ::c_int = 22;
2535 pub const NFT_META_CGROUP: ::c_int = 23;
2536 pub const NFT_META_PRANDOM: ::c_int = 24;
2537 
2538 pub const NFT_CT_STATE: ::c_int = 0;
2539 pub const NFT_CT_DIRECTION: ::c_int = 1;
2540 pub const NFT_CT_STATUS: ::c_int = 2;
2541 pub const NFT_CT_MARK: ::c_int = 3;
2542 pub const NFT_CT_SECMARK: ::c_int = 4;
2543 pub const NFT_CT_EXPIRATION: ::c_int = 5;
2544 pub const NFT_CT_HELPER: ::c_int = 6;
2545 pub const NFT_CT_L3PROTOCOL: ::c_int = 7;
2546 pub const NFT_CT_SRC: ::c_int = 8;
2547 pub const NFT_CT_DST: ::c_int = 9;
2548 pub const NFT_CT_PROTOCOL: ::c_int = 10;
2549 pub const NFT_CT_PROTO_SRC: ::c_int = 11;
2550 pub const NFT_CT_PROTO_DST: ::c_int = 12;
2551 pub const NFT_CT_LABELS: ::c_int = 13;
2552 pub const NFT_CT_PKTS: ::c_int = 14;
2553 pub const NFT_CT_BYTES: ::c_int = 15;
2554 
2555 pub const NFT_LIMIT_PKTS: ::c_int = 0;
2556 pub const NFT_LIMIT_PKT_BYTES: ::c_int = 1;
2557 
2558 pub const NFT_LIMIT_F_INV: ::c_int = 1 << 0;
2559 
2560 pub const NFT_QUEUE_FLAG_BYPASS: ::c_int = 0x01;
2561 pub const NFT_QUEUE_FLAG_CPU_FANOUT: ::c_int = 0x02;
2562 pub const NFT_QUEUE_FLAG_MASK: ::c_int = 0x03;
2563 
2564 pub const NFT_QUOTA_F_INV: ::c_int = 1 << 0;
2565 
2566 pub const NFT_REJECT_ICMP_UNREACH: ::c_int = 0;
2567 pub const NFT_REJECT_TCP_RST: ::c_int = 1;
2568 pub const NFT_REJECT_ICMPX_UNREACH: ::c_int = 2;
2569 
2570 pub const NFT_REJECT_ICMPX_NO_ROUTE: ::c_int = 0;
2571 pub const NFT_REJECT_ICMPX_PORT_UNREACH: ::c_int = 1;
2572 pub const NFT_REJECT_ICMPX_HOST_UNREACH: ::c_int = 2;
2573 pub const NFT_REJECT_ICMPX_ADMIN_PROHIBITED: ::c_int = 3;
2574 
2575 pub const NFT_NAT_SNAT: ::c_int = 0;
2576 pub const NFT_NAT_DNAT: ::c_int = 1;
2577 
2578 pub const NFT_TRACETYPE_UNSPEC: ::c_int = 0;
2579 pub const NFT_TRACETYPE_POLICY: ::c_int = 1;
2580 pub const NFT_TRACETYPE_RETURN: ::c_int = 2;
2581 pub const NFT_TRACETYPE_RULE: ::c_int = 3;
2582 
2583 pub const NFT_NG_INCREMENTAL: ::c_int = 0;
2584 pub const NFT_NG_RANDOM: ::c_int = 1;
2585 
2586 // linux/input.h
2587 pub const FF_MAX: ::__u16 = 0x7f;
2588 pub const FF_CNT: usize = FF_MAX as usize + 1;
2589 
2590 // linux/input-event-codes.h
2591 pub const INPUT_PROP_MAX: ::__u16 = 0x1f;
2592 pub const INPUT_PROP_CNT: usize = INPUT_PROP_MAX as usize + 1;
2593 pub const EV_MAX: ::__u16 = 0x1f;
2594 pub const EV_CNT: usize = EV_MAX as usize + 1;
2595 pub const SYN_MAX: ::__u16 = 0xf;
2596 pub const SYN_CNT: usize = SYN_MAX as usize + 1;
2597 pub const KEY_MAX: ::__u16 = 0x2ff;
2598 pub const KEY_CNT: usize = KEY_MAX as usize + 1;
2599 pub const REL_MAX: ::__u16 = 0x0f;
2600 pub const REL_CNT: usize = REL_MAX as usize + 1;
2601 pub const ABS_MAX: ::__u16 = 0x3f;
2602 pub const ABS_CNT: usize = ABS_MAX as usize + 1;
2603 pub const SW_MAX: ::__u16 = 0x0f;
2604 pub const SW_CNT: usize = SW_MAX as usize + 1;
2605 pub const MSC_MAX: ::__u16 = 0x07;
2606 pub const MSC_CNT: usize = MSC_MAX as usize + 1;
2607 pub const LED_MAX: ::__u16 = 0x0f;
2608 pub const LED_CNT: usize = LED_MAX as usize + 1;
2609 pub const REP_MAX: ::__u16 = 0x01;
2610 pub const REP_CNT: usize = REP_MAX as usize + 1;
2611 pub const SND_MAX: ::__u16 = 0x07;
2612 pub const SND_CNT: usize = SND_MAX as usize + 1;
2613 
2614 // linux/uinput.h
2615 pub const UINPUT_VERSION: ::c_uint = 5;
2616 pub const UINPUT_MAX_NAME_SIZE: usize = 80;
2617 
2618 // bionic/libc/kernel/uapi/linux/if_tun.h
2619 pub const IFF_TUN: ::c_int = 0x0001;
2620 pub const IFF_TAP: ::c_int = 0x0002;
2621 pub const IFF_NAPI: ::c_int = 0x0010;
2622 pub const IFF_NAPI_FRAGS: ::c_int = 0x0020;
2623 pub const IFF_NO_CARRIER: ::c_int = 0x0040;
2624 pub const IFF_NO_PI: ::c_int = 0x1000;
2625 pub const IFF_ONE_QUEUE: ::c_int = 0x2000;
2626 pub const IFF_VNET_HDR: ::c_int = 0x4000;
2627 pub const IFF_TUN_EXCL: ::c_int = 0x8000;
2628 pub const IFF_MULTI_QUEUE: ::c_int = 0x0100;
2629 pub const IFF_ATTACH_QUEUE: ::c_int = 0x0200;
2630 pub const IFF_DETACH_QUEUE: ::c_int = 0x0400;
2631 pub const IFF_PERSIST: ::c_int = 0x0800;
2632 pub const IFF_NOFILTER: ::c_int = 0x1000;
2633 // Features for GSO (TUNSETOFFLOAD)
2634 pub const TUN_F_CSUM: ::c_uint = 0x01;
2635 pub const TUN_F_TSO4: ::c_uint = 0x02;
2636 pub const TUN_F_TSO6: ::c_uint = 0x04;
2637 pub const TUN_F_TSO_ECN: ::c_uint = 0x08;
2638 pub const TUN_F_UFO: ::c_uint = 0x10;
2639 pub const TUN_F_USO4: ::c_uint = 0x20;
2640 pub const TUN_F_USO6: ::c_uint = 0x40;
2641 
2642 // start android/platform/bionic/libc/kernel/uapi/linux/if_ether.h
2643 // from https://android.googlesource.com/platform/bionic/+/HEAD/libc/kernel/uapi/linux/if_ether.h
2644 pub const ETH_ALEN: ::c_int = 6;
2645 pub const ETH_HLEN: ::c_int = 14;
2646 pub const ETH_ZLEN: ::c_int = 60;
2647 pub const ETH_DATA_LEN: ::c_int = 1500;
2648 pub const ETH_FRAME_LEN: ::c_int = 1514;
2649 pub const ETH_FCS_LEN: ::c_int = 4;
2650 pub const ETH_MIN_MTU: ::c_int = 68;
2651 pub const ETH_MAX_MTU: ::c_int = 0xFFFF;
2652 pub const ETH_P_LOOP: ::c_int = 0x0060;
2653 pub const ETH_P_PUP: ::c_int = 0x0200;
2654 pub const ETH_P_PUPAT: ::c_int = 0x0201;
2655 pub const ETH_P_TSN: ::c_int = 0x22F0;
2656 pub const ETH_P_IP: ::c_int = 0x0800;
2657 pub const ETH_P_X25: ::c_int = 0x0805;
2658 pub const ETH_P_ARP: ::c_int = 0x0806;
2659 pub const ETH_P_BPQ: ::c_int = 0x08FF;
2660 pub const ETH_P_IEEEPUP: ::c_int = 0x0a00;
2661 pub const ETH_P_IEEEPUPAT: ::c_int = 0x0a01;
2662 pub const ETH_P_BATMAN: ::c_int = 0x4305;
2663 pub const ETH_P_DEC: ::c_int = 0x6000;
2664 pub const ETH_P_DNA_DL: ::c_int = 0x6001;
2665 pub const ETH_P_DNA_RC: ::c_int = 0x6002;
2666 pub const ETH_P_DNA_RT: ::c_int = 0x6003;
2667 pub const ETH_P_LAT: ::c_int = 0x6004;
2668 pub const ETH_P_DIAG: ::c_int = 0x6005;
2669 pub const ETH_P_CUST: ::c_int = 0x6006;
2670 pub const ETH_P_SCA: ::c_int = 0x6007;
2671 pub const ETH_P_TEB: ::c_int = 0x6558;
2672 pub const ETH_P_RARP: ::c_int = 0x8035;
2673 pub const ETH_P_ATALK: ::c_int = 0x809B;
2674 pub const ETH_P_AARP: ::c_int = 0x80F3;
2675 pub const ETH_P_8021Q: ::c_int = 0x8100;
2676 /* see rust-lang/libc#924 pub const ETH_P_ERSPAN: ::c_int = 0x88BE;*/
2677 pub const ETH_P_IPX: ::c_int = 0x8137;
2678 pub const ETH_P_IPV6: ::c_int = 0x86DD;
2679 pub const ETH_P_PAUSE: ::c_int = 0x8808;
2680 pub const ETH_P_SLOW: ::c_int = 0x8809;
2681 pub const ETH_P_WCCP: ::c_int = 0x883E;
2682 pub const ETH_P_MPLS_UC: ::c_int = 0x8847;
2683 pub const ETH_P_MPLS_MC: ::c_int = 0x8848;
2684 pub const ETH_P_ATMMPOA: ::c_int = 0x884c;
2685 pub const ETH_P_PPP_DISC: ::c_int = 0x8863;
2686 pub const ETH_P_PPP_SES: ::c_int = 0x8864;
2687 pub const ETH_P_LINK_CTL: ::c_int = 0x886c;
2688 pub const ETH_P_ATMFATE: ::c_int = 0x8884;
2689 pub const ETH_P_PAE: ::c_int = 0x888E;
2690 pub const ETH_P_AOE: ::c_int = 0x88A2;
2691 pub const ETH_P_8021AD: ::c_int = 0x88A8;
2692 pub const ETH_P_802_EX1: ::c_int = 0x88B5;
2693 pub const ETH_P_TIPC: ::c_int = 0x88CA;
2694 pub const ETH_P_MACSEC: ::c_int = 0x88E5;
2695 pub const ETH_P_8021AH: ::c_int = 0x88E7;
2696 pub const ETH_P_MVRP: ::c_int = 0x88F5;
2697 pub const ETH_P_1588: ::c_int = 0x88F7;
2698 pub const ETH_P_NCSI: ::c_int = 0x88F8;
2699 pub const ETH_P_PRP: ::c_int = 0x88FB;
2700 pub const ETH_P_FCOE: ::c_int = 0x8906;
2701 /* see rust-lang/libc#924 pub const ETH_P_IBOE: ::c_int = 0x8915;*/
2702 pub const ETH_P_TDLS: ::c_int = 0x890D;
2703 pub const ETH_P_FIP: ::c_int = 0x8914;
2704 pub const ETH_P_80221: ::c_int = 0x8917;
2705 pub const ETH_P_HSR: ::c_int = 0x892F;
2706 /* see rust-lang/libc#924 pub const ETH_P_NSH: ::c_int = 0x894F;*/
2707 pub const ETH_P_LOOPBACK: ::c_int = 0x9000;
2708 pub const ETH_P_QINQ1: ::c_int = 0x9100;
2709 pub const ETH_P_QINQ2: ::c_int = 0x9200;
2710 pub const ETH_P_QINQ3: ::c_int = 0x9300;
2711 pub const ETH_P_EDSA: ::c_int = 0xDADA;
2712 /* see rust-lang/libc#924 pub const ETH_P_IFE: ::c_int = 0xED3E;*/
2713 pub const ETH_P_AF_IUCV: ::c_int = 0xFBFB;
2714 pub const ETH_P_802_3_MIN: ::c_int = 0x0600;
2715 pub const ETH_P_802_3: ::c_int = 0x0001;
2716 pub const ETH_P_AX25: ::c_int = 0x0002;
2717 pub const ETH_P_ALL: ::c_int = 0x0003;
2718 pub const ETH_P_802_2: ::c_int = 0x0004;
2719 pub const ETH_P_SNAP: ::c_int = 0x0005;
2720 pub const ETH_P_DDCMP: ::c_int = 0x0006;
2721 pub const ETH_P_WAN_PPP: ::c_int = 0x0007;
2722 pub const ETH_P_PPP_MP: ::c_int = 0x0008;
2723 pub const ETH_P_LOCALTALK: ::c_int = 0x0009;
2724 pub const ETH_P_CAN: ::c_int = 0x000C;
2725 pub const ETH_P_CANFD: ::c_int = 0x000D;
2726 pub const ETH_P_PPPTALK: ::c_int = 0x0010;
2727 pub const ETH_P_TR_802_2: ::c_int = 0x0011;
2728 pub const ETH_P_MOBITEX: ::c_int = 0x0015;
2729 pub const ETH_P_CONTROL: ::c_int = 0x0016;
2730 pub const ETH_P_IRDA: ::c_int = 0x0017;
2731 pub const ETH_P_ECONET: ::c_int = 0x0018;
2732 pub const ETH_P_HDLC: ::c_int = 0x0019;
2733 pub const ETH_P_ARCNET: ::c_int = 0x001A;
2734 pub const ETH_P_DSA: ::c_int = 0x001B;
2735 pub const ETH_P_TRAILER: ::c_int = 0x001C;
2736 pub const ETH_P_PHONET: ::c_int = 0x00F5;
2737 pub const ETH_P_IEEE802154: ::c_int = 0x00F6;
2738 pub const ETH_P_CAIF: ::c_int = 0x00F7;
2739 pub const ETH_P_XDSA: ::c_int = 0x00F8;
2740 /* see rust-lang/libc#924 pub const ETH_P_MAP: ::c_int = 0x00F9;*/
2741 // end android/platform/bionic/libc/kernel/uapi/linux/if_ether.h
2742 
2743 // start android/platform/bionic/libc/kernel/uapi/linux/neighbour.h
2744 pub const NDA_UNSPEC: ::c_ushort = 0;
2745 pub const NDA_DST: ::c_ushort = 1;
2746 pub const NDA_LLADDR: ::c_ushort = 2;
2747 pub const NDA_CACHEINFO: ::c_ushort = 3;
2748 pub const NDA_PROBES: ::c_ushort = 4;
2749 pub const NDA_VLAN: ::c_ushort = 5;
2750 pub const NDA_PORT: ::c_ushort = 6;
2751 pub const NDA_VNI: ::c_ushort = 7;
2752 pub const NDA_IFINDEX: ::c_ushort = 8;
2753 pub const NDA_MASTER: ::c_ushort = 9;
2754 pub const NDA_LINK_NETNSID: ::c_ushort = 10;
2755 pub const NDA_SRC_VNI: ::c_ushort = 11;
2756 pub const NDA_PROTOCOL: ::c_ushort = 12;
2757 pub const NDA_NH_ID: ::c_ushort = 13;
2758 pub const NDA_FDB_EXT_ATTRS: ::c_ushort = 14;
2759 pub const NDA_FLAGS_EXT: ::c_ushort = 15;
2760 pub const NDA_NDM_STATE_MASK: ::c_ushort = 16;
2761 pub const NDA_NDM_FLAGS_MASK: ::c_ushort = 17;
2762 
2763 pub const NTF_USE: u8 = 0x01;
2764 pub const NTF_SELF: u8 = 0x02;
2765 pub const NTF_MASTER: u8 = 0x04;
2766 pub const NTF_PROXY: u8 = 0x08;
2767 pub const NTF_EXT_LEARNED: u8 = 0x10;
2768 pub const NTF_OFFLOADED: u8 = 0x20;
2769 pub const NTF_STICKY: u8 = 0x40;
2770 pub const NTF_ROUTER: u8 = 0x80;
2771 
2772 pub const NTF_EXT_MANAGED: u8 = 0x01;
2773 pub const NTF_EXT_LOCKED: u8 = 0x02;
2774 
2775 pub const NUD_NONE: u16 = 0x00;
2776 pub const NUD_INCOMPLETE: u16 = 0x01;
2777 pub const NUD_REACHABLE: u16 = 0x02;
2778 pub const NUD_STALE: u16 = 0x04;
2779 pub const NUD_DELAY: u16 = 0x08;
2780 pub const NUD_PROBE: u16 = 0x10;
2781 pub const NUD_FAILED: u16 = 0x20;
2782 pub const NUD_NOARP: u16 = 0x40;
2783 pub const NUD_PERMANENT: u16 = 0x80;
2784 
2785 pub const NDTPA_UNSPEC: ::c_ushort = 0;
2786 pub const NDTPA_IFINDEX: ::c_ushort = 1;
2787 pub const NDTPA_REFCNT: ::c_ushort = 2;
2788 pub const NDTPA_REACHABLE_TIME: ::c_ushort = 3;
2789 pub const NDTPA_BASE_REACHABLE_TIME: ::c_ushort = 4;
2790 pub const NDTPA_RETRANS_TIME: ::c_ushort = 5;
2791 pub const NDTPA_GC_STALETIME: ::c_ushort = 6;
2792 pub const NDTPA_DELAY_PROBE_TIME: ::c_ushort = 7;
2793 pub const NDTPA_QUEUE_LEN: ::c_ushort = 8;
2794 pub const NDTPA_APP_PROBES: ::c_ushort = 9;
2795 pub const NDTPA_UCAST_PROBES: ::c_ushort = 10;
2796 pub const NDTPA_MCAST_PROBES: ::c_ushort = 11;
2797 pub const NDTPA_ANYCAST_DELAY: ::c_ushort = 12;
2798 pub const NDTPA_PROXY_DELAY: ::c_ushort = 13;
2799 pub const NDTPA_PROXY_QLEN: ::c_ushort = 14;
2800 pub const NDTPA_LOCKTIME: ::c_ushort = 15;
2801 pub const NDTPA_QUEUE_LENBYTES: ::c_ushort = 16;
2802 pub const NDTPA_MCAST_REPROBES: ::c_ushort = 17;
2803 pub const NDTPA_PAD: ::c_ushort = 18;
2804 pub const NDTPA_INTERVAL_PROBE_TIME_MS: ::c_ushort = 19;
2805 
2806 pub const NDTA_UNSPEC: ::c_ushort = 0;
2807 pub const NDTA_NAME: ::c_ushort = 1;
2808 pub const NDTA_THRESH1: ::c_ushort = 2;
2809 pub const NDTA_THRESH2: ::c_ushort = 3;
2810 pub const NDTA_THRESH3: ::c_ushort = 4;
2811 pub const NDTA_CONFIG: ::c_ushort = 5;
2812 pub const NDTA_PARMS: ::c_ushort = 6;
2813 pub const NDTA_STATS: ::c_ushort = 7;
2814 pub const NDTA_GC_INTERVAL: ::c_ushort = 8;
2815 pub const NDTA_PAD: ::c_ushort = 9;
2816 
2817 pub const FDB_NOTIFY_BIT: u16 = 0x01;
2818 pub const FDB_NOTIFY_INACTIVE_BIT: u16 = 0x02;
2819 
2820 pub const NFEA_UNSPEC: ::c_ushort = 0;
2821 pub const NFEA_ACTIVITY_NOTIFY: ::c_ushort = 1;
2822 pub const NFEA_DONT_REFRESH: ::c_ushort = 2;
2823 // end android/platform/bionic/libc/kernel/uapi/linux/neighbour.h
2824 
2825 pub const SIOCADDRT: ::c_ulong = 0x0000890B;
2826 pub const SIOCDELRT: ::c_ulong = 0x0000890C;
2827 pub const SIOCRTMSG: ::c_ulong = 0x0000890D;
2828 pub const SIOCGIFNAME: ::c_ulong = 0x00008910;
2829 pub const SIOCSIFLINK: ::c_ulong = 0x00008911;
2830 pub const SIOCGIFCONF: ::c_ulong = 0x00008912;
2831 pub const SIOCGIFFLAGS: ::c_ulong = 0x00008913;
2832 pub const SIOCSIFFLAGS: ::c_ulong = 0x00008914;
2833 pub const SIOCGIFADDR: ::c_ulong = 0x00008915;
2834 pub const SIOCSIFADDR: ::c_ulong = 0x00008916;
2835 pub const SIOCGIFDSTADDR: ::c_ulong = 0x00008917;
2836 pub const SIOCSIFDSTADDR: ::c_ulong = 0x00008918;
2837 pub const SIOCGIFBRDADDR: ::c_ulong = 0x00008919;
2838 pub const SIOCSIFBRDADDR: ::c_ulong = 0x0000891A;
2839 pub const SIOCGIFNETMASK: ::c_ulong = 0x0000891B;
2840 pub const SIOCSIFNETMASK: ::c_ulong = 0x0000891C;
2841 pub const SIOCGIFMETRIC: ::c_ulong = 0x0000891D;
2842 pub const SIOCSIFMETRIC: ::c_ulong = 0x0000891E;
2843 pub const SIOCGIFMEM: ::c_ulong = 0x0000891F;
2844 pub const SIOCSIFMEM: ::c_ulong = 0x00008920;
2845 pub const SIOCGIFMTU: ::c_ulong = 0x00008921;
2846 pub const SIOCSIFMTU: ::c_ulong = 0x00008922;
2847 pub const SIOCSIFNAME: ::c_ulong = 0x00008923;
2848 pub const SIOCSIFHWADDR: ::c_ulong = 0x00008924;
2849 pub const SIOCGIFENCAP: ::c_ulong = 0x00008925;
2850 pub const SIOCSIFENCAP: ::c_ulong = 0x00008926;
2851 pub const SIOCGIFHWADDR: ::c_ulong = 0x00008927;
2852 pub const SIOCGIFSLAVE: ::c_ulong = 0x00008929;
2853 pub const SIOCSIFSLAVE: ::c_ulong = 0x00008930;
2854 pub const SIOCADDMULTI: ::c_ulong = 0x00008931;
2855 pub const SIOCDELMULTI: ::c_ulong = 0x00008932;
2856 pub const SIOCGIFINDEX: ::c_ulong = 0x00008933;
2857 pub const SIOGIFINDEX: ::c_ulong = SIOCGIFINDEX;
2858 pub const SIOCSIFPFLAGS: ::c_ulong = 0x00008934;
2859 pub const SIOCGIFPFLAGS: ::c_ulong = 0x00008935;
2860 pub const SIOCDIFADDR: ::c_ulong = 0x00008936;
2861 pub const SIOCSIFHWBROADCAST: ::c_ulong = 0x00008937;
2862 pub const SIOCGIFCOUNT: ::c_ulong = 0x00008938;
2863 pub const SIOCGIFBR: ::c_ulong = 0x00008940;
2864 pub const SIOCSIFBR: ::c_ulong = 0x00008941;
2865 pub const SIOCGIFTXQLEN: ::c_ulong = 0x00008942;
2866 pub const SIOCSIFTXQLEN: ::c_ulong = 0x00008943;
2867 pub const SIOCETHTOOL: ::c_ulong = 0x00008946;
2868 pub const SIOCGMIIPHY: ::c_ulong = 0x00008947;
2869 pub const SIOCGMIIREG: ::c_ulong = 0x00008948;
2870 pub const SIOCSMIIREG: ::c_ulong = 0x00008949;
2871 pub const SIOCWANDEV: ::c_ulong = 0x0000894A;
2872 pub const SIOCOUTQNSD: ::c_ulong = 0x0000894B;
2873 pub const SIOCGSKNS: ::c_ulong = 0x0000894C;
2874 pub const SIOCDARP: ::c_ulong = 0x00008953;
2875 pub const SIOCGARP: ::c_ulong = 0x00008954;
2876 pub const SIOCSARP: ::c_ulong = 0x00008955;
2877 pub const SIOCDRARP: ::c_ulong = 0x00008960;
2878 pub const SIOCGRARP: ::c_ulong = 0x00008961;
2879 pub const SIOCSRARP: ::c_ulong = 0x00008962;
2880 pub const SIOCGIFMAP: ::c_ulong = 0x00008970;
2881 pub const SIOCSIFMAP: ::c_ulong = 0x00008971;
2882 pub const SIOCADDDLCI: ::c_ulong = 0x00008980;
2883 pub const SIOCDELDLCI: ::c_ulong = 0x00008981;
2884 pub const SIOCGIFVLAN: ::c_ulong = 0x00008982;
2885 pub const SIOCSIFVLAN: ::c_ulong = 0x00008983;
2886 pub const SIOCBONDENSLAVE: ::c_ulong = 0x00008990;
2887 pub const SIOCBONDRELEASE: ::c_ulong = 0x00008991;
2888 pub const SIOCBONDSETHWADDR: ::c_ulong = 0x00008992;
2889 pub const SIOCBONDSLAVEINFOQUERY: ::c_ulong = 0x00008993;
2890 pub const SIOCBONDINFOQUERY: ::c_ulong = 0x00008994;
2891 pub const SIOCBONDCHANGEACTIVE: ::c_ulong = 0x00008995;
2892 pub const SIOCBRADDBR: ::c_ulong = 0x000089a0;
2893 pub const SIOCBRDELBR: ::c_ulong = 0x000089a1;
2894 pub const SIOCBRADDIF: ::c_ulong = 0x000089a2;
2895 pub const SIOCBRDELIF: ::c_ulong = 0x000089a3;
2896 pub const SIOCSHWTSTAMP: ::c_ulong = 0x000089b0;
2897 pub const SIOCGHWTSTAMP: ::c_ulong = 0x000089b1;
2898 pub const SIOCDEVPRIVATE: ::c_ulong = 0x000089F0;
2899 pub const SIOCPROTOPRIVATE: ::c_ulong = 0x000089E0;
2900 
2901 // linux/module.h
2902 pub const MODULE_INIT_IGNORE_MODVERSIONS: ::c_uint = 0x0001;
2903 pub const MODULE_INIT_IGNORE_VERMAGIC: ::c_uint = 0x0002;
2904 
2905 // linux/net_tstamp.h
2906 pub const SOF_TIMESTAMPING_TX_HARDWARE: ::c_uint = 1 << 0;
2907 pub const SOF_TIMESTAMPING_TX_SOFTWARE: ::c_uint = 1 << 1;
2908 pub const SOF_TIMESTAMPING_RX_HARDWARE: ::c_uint = 1 << 2;
2909 pub const SOF_TIMESTAMPING_RX_SOFTWARE: ::c_uint = 1 << 3;
2910 pub const SOF_TIMESTAMPING_SOFTWARE: ::c_uint = 1 << 4;
2911 pub const SOF_TIMESTAMPING_SYS_HARDWARE: ::c_uint = 1 << 5;
2912 pub const SOF_TIMESTAMPING_RAW_HARDWARE: ::c_uint = 1 << 6;
2913 pub const SOF_TIMESTAMPING_OPT_ID: ::c_uint = 1 << 7;
2914 pub const SOF_TIMESTAMPING_TX_SCHED: ::c_uint = 1 << 8;
2915 pub const SOF_TIMESTAMPING_TX_ACK: ::c_uint = 1 << 9;
2916 pub const SOF_TIMESTAMPING_OPT_CMSG: ::c_uint = 1 << 10;
2917 pub const SOF_TIMESTAMPING_OPT_TSONLY: ::c_uint = 1 << 11;
2918 pub const SOF_TIMESTAMPING_OPT_STATS: ::c_uint = 1 << 12;
2919 pub const SOF_TIMESTAMPING_OPT_PKTINFO: ::c_uint = 1 << 13;
2920 pub const SOF_TIMESTAMPING_OPT_TX_SWHW: ::c_uint = 1 << 14;
2921 
2922 #[deprecated(
2923     since = "0.2.55",
2924     note = "ENOATTR is not available on Android; use ENODATA instead"
2925 )]
2926 pub const ENOATTR: ::c_int = ::ENODATA;
2927 
2928 // linux/if_alg.h
2929 pub const ALG_SET_KEY: ::c_int = 1;
2930 pub const ALG_SET_IV: ::c_int = 2;
2931 pub const ALG_SET_OP: ::c_int = 3;
2932 pub const ALG_SET_AEAD_ASSOCLEN: ::c_int = 4;
2933 pub const ALG_SET_AEAD_AUTHSIZE: ::c_int = 5;
2934 pub const ALG_SET_DRBG_ENTROPY: ::c_int = 6;
2935 
2936 pub const ALG_OP_DECRYPT: ::c_int = 0;
2937 pub const ALG_OP_ENCRYPT: ::c_int = 1;
2938 
2939 // sys/mman.h
2940 pub const MLOCK_ONFAULT: ::c_int = 0x01;
2941 
2942 // uapi/linux/vm_sockets.h
2943 pub const VMADDR_CID_ANY: ::c_uint = 0xFFFFFFFF;
2944 pub const VMADDR_CID_HYPERVISOR: ::c_uint = 0;
2945 pub const VMADDR_CID_LOCAL: ::c_uint = 1;
2946 pub const VMADDR_CID_HOST: ::c_uint = 2;
2947 pub const VMADDR_PORT_ANY: ::c_uint = 0xFFFFFFFF;
2948 
2949 // uapi/linux/inotify.h
2950 pub const IN_ACCESS: u32 = 0x0000_0001;
2951 pub const IN_MODIFY: u32 = 0x0000_0002;
2952 pub const IN_ATTRIB: u32 = 0x0000_0004;
2953 pub const IN_CLOSE_WRITE: u32 = 0x0000_0008;
2954 pub const IN_CLOSE_NOWRITE: u32 = 0x0000_0010;
2955 pub const IN_CLOSE: u32 = IN_CLOSE_WRITE | IN_CLOSE_NOWRITE;
2956 pub const IN_OPEN: u32 = 0x0000_0020;
2957 pub const IN_MOVED_FROM: u32 = 0x0000_0040;
2958 pub const IN_MOVED_TO: u32 = 0x0000_0080;
2959 pub const IN_MOVE: u32 = IN_MOVED_FROM | IN_MOVED_TO;
2960 pub const IN_CREATE: u32 = 0x0000_0100;
2961 pub const IN_DELETE: u32 = 0x0000_0200;
2962 pub const IN_DELETE_SELF: u32 = 0x0000_0400;
2963 pub const IN_MOVE_SELF: u32 = 0x0000_0800;
2964 pub const IN_UNMOUNT: u32 = 0x0000_2000;
2965 pub const IN_Q_OVERFLOW: u32 = 0x0000_4000;
2966 pub const IN_IGNORED: u32 = 0x0000_8000;
2967 pub const IN_ONLYDIR: u32 = 0x0100_0000;
2968 pub const IN_DONT_FOLLOW: u32 = 0x0200_0000;
2969 pub const IN_EXCL_UNLINK: u32 = 0x0400_0000;
2970 
2971 pub const IN_MASK_CREATE: u32 = 0x1000_0000;
2972 pub const IN_MASK_ADD: u32 = 0x2000_0000;
2973 pub const IN_ISDIR: u32 = 0x4000_0000;
2974 pub const IN_ONESHOT: u32 = 0x8000_0000;
2975 
2976 pub const IN_ALL_EVENTS: u32 = IN_ACCESS
2977     | IN_MODIFY
2978     | IN_ATTRIB
2979     | IN_CLOSE_WRITE
2980     | IN_CLOSE_NOWRITE
2981     | IN_OPEN
2982     | IN_MOVED_FROM
2983     | IN_MOVED_TO
2984     | IN_DELETE
2985     | IN_CREATE
2986     | IN_DELETE_SELF
2987     | IN_MOVE_SELF;
2988 
2989 pub const IN_CLOEXEC: ::c_int = O_CLOEXEC;
2990 pub const IN_NONBLOCK: ::c_int = O_NONBLOCK;
2991 
2992 pub const FUTEX_WAIT: ::c_int = 0;
2993 pub const FUTEX_WAKE: ::c_int = 1;
2994 pub const FUTEX_FD: ::c_int = 2;
2995 pub const FUTEX_REQUEUE: ::c_int = 3;
2996 pub const FUTEX_CMP_REQUEUE: ::c_int = 4;
2997 pub const FUTEX_WAKE_OP: ::c_int = 5;
2998 pub const FUTEX_LOCK_PI: ::c_int = 6;
2999 pub const FUTEX_UNLOCK_PI: ::c_int = 7;
3000 pub const FUTEX_TRYLOCK_PI: ::c_int = 8;
3001 pub const FUTEX_WAIT_BITSET: ::c_int = 9;
3002 pub const FUTEX_WAKE_BITSET: ::c_int = 10;
3003 pub const FUTEX_WAIT_REQUEUE_PI: ::c_int = 11;
3004 pub const FUTEX_CMP_REQUEUE_PI: ::c_int = 12;
3005 
3006 pub const FUTEX_PRIVATE_FLAG: ::c_int = 128;
3007 pub const FUTEX_CLOCK_REALTIME: ::c_int = 256;
3008 pub const FUTEX_CMD_MASK: ::c_int = !(FUTEX_PRIVATE_FLAG | FUTEX_CLOCK_REALTIME);
3009 
3010 // linux/errqueue.h
3011 pub const SO_EE_ORIGIN_NONE: u8 = 0;
3012 pub const SO_EE_ORIGIN_LOCAL: u8 = 1;
3013 pub const SO_EE_ORIGIN_ICMP: u8 = 2;
3014 pub const SO_EE_ORIGIN_ICMP6: u8 = 3;
3015 pub const SO_EE_ORIGIN_TXSTATUS: u8 = 4;
3016 pub const SO_EE_ORIGIN_TIMESTAMPING: u8 = SO_EE_ORIGIN_TXSTATUS;
3017 
3018 // errno.h
3019 pub const EPERM: ::c_int = 1;
3020 pub const ENOENT: ::c_int = 2;
3021 pub const ESRCH: ::c_int = 3;
3022 pub const EINTR: ::c_int = 4;
3023 pub const EIO: ::c_int = 5;
3024 pub const ENXIO: ::c_int = 6;
3025 pub const E2BIG: ::c_int = 7;
3026 pub const ENOEXEC: ::c_int = 8;
3027 pub const EBADF: ::c_int = 9;
3028 pub const ECHILD: ::c_int = 10;
3029 pub const EAGAIN: ::c_int = 11;
3030 pub const ENOMEM: ::c_int = 12;
3031 pub const EACCES: ::c_int = 13;
3032 pub const EFAULT: ::c_int = 14;
3033 pub const ENOTBLK: ::c_int = 15;
3034 pub const EBUSY: ::c_int = 16;
3035 pub const EEXIST: ::c_int = 17;
3036 pub const EXDEV: ::c_int = 18;
3037 pub const ENODEV: ::c_int = 19;
3038 pub const ENOTDIR: ::c_int = 20;
3039 pub const EISDIR: ::c_int = 21;
3040 pub const EINVAL: ::c_int = 22;
3041 pub const ENFILE: ::c_int = 23;
3042 pub const EMFILE: ::c_int = 24;
3043 pub const ENOTTY: ::c_int = 25;
3044 pub const ETXTBSY: ::c_int = 26;
3045 pub const EFBIG: ::c_int = 27;
3046 pub const ENOSPC: ::c_int = 28;
3047 pub const ESPIPE: ::c_int = 29;
3048 pub const EROFS: ::c_int = 30;
3049 pub const EMLINK: ::c_int = 31;
3050 pub const EPIPE: ::c_int = 32;
3051 pub const EDOM: ::c_int = 33;
3052 pub const ERANGE: ::c_int = 34;
3053 pub const EWOULDBLOCK: ::c_int = EAGAIN;
3054 
3055 pub const PRIO_PROCESS: ::c_int = 0;
3056 pub const PRIO_PGRP: ::c_int = 1;
3057 pub const PRIO_USER: ::c_int = 2;
3058 
3059 // linux/sched.h
3060 pub const SCHED_NORMAL: ::c_int = 0;
3061 pub const SCHED_FIFO: ::c_int = 1;
3062 pub const SCHED_RR: ::c_int = 2;
3063 pub const SCHED_BATCH: ::c_int = 3;
3064 pub const SCHED_IDLE: ::c_int = 5;
3065 pub const SCHED_DEADLINE: ::c_int = 6;
3066 
3067 pub const SCHED_RESET_ON_FORK: ::c_int = 0x40000000;
3068 
3069 pub const CLONE_PIDFD: ::c_int = 0x1000;
3070 
3071 // linux/membarrier.h
3072 pub const MEMBARRIER_CMD_QUERY: ::c_int = 0;
3073 pub const MEMBARRIER_CMD_GLOBAL: ::c_int = 1 << 0;
3074 pub const MEMBARRIER_CMD_GLOBAL_EXPEDITED: ::c_int = 1 << 1;
3075 pub const MEMBARRIER_CMD_REGISTER_GLOBAL_EXPEDITED: ::c_int = 1 << 2;
3076 pub const MEMBARRIER_CMD_PRIVATE_EXPEDITED: ::c_int = 1 << 3;
3077 pub const MEMBARRIER_CMD_REGISTER_PRIVATE_EXPEDITED: ::c_int = 1 << 4;
3078 pub const MEMBARRIER_CMD_PRIVATE_EXPEDITED_SYNC_CORE: ::c_int = 1 << 5;
3079 pub const MEMBARRIER_CMD_REGISTER_PRIVATE_EXPEDITED_SYNC_CORE: ::c_int = 1 << 6;
3080 pub const MEMBARRIER_CMD_PRIVATE_EXPEDITED_RSEQ: ::c_int = 1 << 7;
3081 pub const MEMBARRIER_CMD_REGISTER_PRIVATE_EXPEDITED_RSEQ: ::c_int = 1 << 8;
3082 
3083 // linux/mempolicy.h
3084 pub const MPOL_DEFAULT: ::c_int = 0;
3085 pub const MPOL_PREFERRED: ::c_int = 1;
3086 pub const MPOL_BIND: ::c_int = 2;
3087 pub const MPOL_INTERLEAVE: ::c_int = 3;
3088 pub const MPOL_LOCAL: ::c_int = 4;
3089 pub const MPOL_F_NUMA_BALANCING: ::c_int = 1 << 13;
3090 pub const MPOL_F_RELATIVE_NODES: ::c_int = 1 << 14;
3091 pub const MPOL_F_STATIC_NODES: ::c_int = 1 << 15;
3092 
3093 // bits/seek_constants.h
3094 pub const SEEK_DATA: ::c_int = 3;
3095 pub const SEEK_HOLE: ::c_int = 4;
3096 
3097 // sys/socket.h
3098 pub const AF_NFC: ::c_int = 39;
3099 pub const AF_VSOCK: ::c_int = 40;
3100 pub const PF_NFC: ::c_int = AF_NFC;
3101 pub const PF_VSOCK: ::c_int = AF_VSOCK;
3102 
3103 pub const SOMAXCONN: ::c_int = 128;
3104 
3105 // sys/prctl.h
3106 pub const PR_SET_PDEATHSIG: ::c_int = 1;
3107 pub const PR_GET_PDEATHSIG: ::c_int = 2;
3108 pub const PR_GET_SECUREBITS: ::c_int = 27;
3109 pub const PR_SET_SECUREBITS: ::c_int = 28;
3110 
3111 // sys/system_properties.h
3112 pub const PROP_VALUE_MAX: ::c_int = 92;
3113 pub const PROP_NAME_MAX: ::c_int = 32;
3114 
3115 // sys/prctl.h
3116 pub const PR_SET_VMA: ::c_int = 0x53564d41;
3117 pub const PR_SET_VMA_ANON_NAME: ::c_int = 0;
3118 pub const PR_SET_NO_NEW_PRIVS: ::c_int = 38;
3119 pub const PR_GET_NO_NEW_PRIVS: ::c_int = 39;
3120 pub const PR_GET_SECCOMP: ::c_int = 21;
3121 pub const PR_SET_SECCOMP: ::c_int = 22;
3122 pub const PR_GET_TIMING: ::c_int = 13;
3123 pub const PR_SET_TIMING: ::c_int = 14;
3124 pub const PR_TIMING_STATISTICAL: ::c_int = 0;
3125 pub const PR_TIMING_TIMESTAMP: ::c_int = 1;
3126 
3127 // linux/if_addr.h
3128 pub const IFA_UNSPEC: ::c_ushort = 0;
3129 pub const IFA_ADDRESS: ::c_ushort = 1;
3130 pub const IFA_LOCAL: ::c_ushort = 2;
3131 pub const IFA_LABEL: ::c_ushort = 3;
3132 pub const IFA_BROADCAST: ::c_ushort = 4;
3133 pub const IFA_ANYCAST: ::c_ushort = 5;
3134 pub const IFA_CACHEINFO: ::c_ushort = 6;
3135 pub const IFA_MULTICAST: ::c_ushort = 7;
3136 
3137 pub const IFA_F_SECONDARY: u32 = 0x01;
3138 pub const IFA_F_TEMPORARY: u32 = 0x01;
3139 pub const IFA_F_NODAD: u32 = 0x02;
3140 pub const IFA_F_OPTIMISTIC: u32 = 0x04;
3141 pub const IFA_F_DADFAILED: u32 = 0x08;
3142 pub const IFA_F_HOMEADDRESS: u32 = 0x10;
3143 pub const IFA_F_DEPRECATED: u32 = 0x20;
3144 pub const IFA_F_TENTATIVE: u32 = 0x40;
3145 pub const IFA_F_PERMANENT: u32 = 0x80;
3146 
3147 // linux/if_link.h
3148 pub const IFLA_UNSPEC: ::c_ushort = 0;
3149 pub const IFLA_ADDRESS: ::c_ushort = 1;
3150 pub const IFLA_BROADCAST: ::c_ushort = 2;
3151 pub const IFLA_IFNAME: ::c_ushort = 3;
3152 pub const IFLA_MTU: ::c_ushort = 4;
3153 pub const IFLA_LINK: ::c_ushort = 5;
3154 pub const IFLA_QDISC: ::c_ushort = 6;
3155 pub const IFLA_STATS: ::c_ushort = 7;
3156 pub const IFLA_COST: ::c_ushort = 8;
3157 pub const IFLA_PRIORITY: ::c_ushort = 9;
3158 pub const IFLA_MASTER: ::c_ushort = 10;
3159 pub const IFLA_WIRELESS: ::c_ushort = 11;
3160 pub const IFLA_PROTINFO: ::c_ushort = 12;
3161 pub const IFLA_TXQLEN: ::c_ushort = 13;
3162 pub const IFLA_MAP: ::c_ushort = 14;
3163 pub const IFLA_WEIGHT: ::c_ushort = 15;
3164 pub const IFLA_OPERSTATE: ::c_ushort = 16;
3165 pub const IFLA_LINKMODE: ::c_ushort = 17;
3166 pub const IFLA_LINKINFO: ::c_ushort = 18;
3167 pub const IFLA_NET_NS_PID: ::c_ushort = 19;
3168 pub const IFLA_IFALIAS: ::c_ushort = 20;
3169 pub const IFLA_NUM_VF: ::c_ushort = 21;
3170 pub const IFLA_VFINFO_LIST: ::c_ushort = 22;
3171 pub const IFLA_STATS64: ::c_ushort = 23;
3172 pub const IFLA_VF_PORTS: ::c_ushort = 24;
3173 pub const IFLA_PORT_SELF: ::c_ushort = 25;
3174 pub const IFLA_AF_SPEC: ::c_ushort = 26;
3175 pub const IFLA_GROUP: ::c_ushort = 27;
3176 pub const IFLA_NET_NS_FD: ::c_ushort = 28;
3177 pub const IFLA_EXT_MASK: ::c_ushort = 29;
3178 pub const IFLA_PROMISCUITY: ::c_ushort = 30;
3179 pub const IFLA_NUM_TX_QUEUES: ::c_ushort = 31;
3180 pub const IFLA_NUM_RX_QUEUES: ::c_ushort = 32;
3181 pub const IFLA_CARRIER: ::c_ushort = 33;
3182 pub const IFLA_PHYS_PORT_ID: ::c_ushort = 34;
3183 pub const IFLA_CARRIER_CHANGES: ::c_ushort = 35;
3184 pub const IFLA_PHYS_SWITCH_ID: ::c_ushort = 36;
3185 pub const IFLA_LINK_NETNSID: ::c_ushort = 37;
3186 pub const IFLA_PHYS_PORT_NAME: ::c_ushort = 38;
3187 pub const IFLA_PROTO_DOWN: ::c_ushort = 39;
3188 pub const IFLA_GSO_MAX_SEGS: ::c_ushort = 40;
3189 pub const IFLA_GSO_MAX_SIZE: ::c_ushort = 41;
3190 pub const IFLA_PAD: ::c_ushort = 42;
3191 pub const IFLA_XDP: ::c_ushort = 43;
3192 pub const IFLA_EVENT: ::c_ushort = 44;
3193 pub const IFLA_NEW_NETNSID: ::c_ushort = 45;
3194 pub const IFLA_IF_NETNSID: ::c_ushort = 46;
3195 pub const IFLA_TARGET_NETNSID: ::c_ushort = IFLA_IF_NETNSID;
3196 pub const IFLA_CARRIER_UP_COUNT: ::c_ushort = 47;
3197 pub const IFLA_CARRIER_DOWN_COUNT: ::c_ushort = 48;
3198 pub const IFLA_NEW_IFINDEX: ::c_ushort = 49;
3199 pub const IFLA_MIN_MTU: ::c_ushort = 50;
3200 pub const IFLA_MAX_MTU: ::c_ushort = 51;
3201 pub const IFLA_PROP_LIST: ::c_ushort = 52;
3202 pub const IFLA_ALT_IFNAME: ::c_ushort = 53;
3203 pub const IFLA_PERM_ADDRESS: ::c_ushort = 54;
3204 pub const IFLA_PROTO_DOWN_REASON: ::c_ushort = 55;
3205 pub const IFLA_PARENT_DEV_NAME: ::c_ushort = 56;
3206 pub const IFLA_PARENT_DEV_BUS_NAME: ::c_ushort = 57;
3207 pub const IFLA_GRO_MAX_SIZE: ::c_ushort = 58;
3208 pub const IFLA_TSO_MAX_SIZE: ::c_ushort = 59;
3209 pub const IFLA_TSO_MAX_SEGS: ::c_ushort = 60;
3210 pub const IFLA_ALLMULTI: ::c_ushort = 61;
3211 pub const IFLA_DEVLINK_PORT: ::c_ushort = 62;
3212 pub const IFLA_GSO_IPV4_MAX_SIZE: ::c_ushort = 63;
3213 pub const IFLA_GRO_IPV4_MAX_SIZE: ::c_ushort = 64;
3214 
3215 pub const IFLA_INFO_UNSPEC: ::c_ushort = 0;
3216 pub const IFLA_INFO_KIND: ::c_ushort = 1;
3217 pub const IFLA_INFO_DATA: ::c_ushort = 2;
3218 pub const IFLA_INFO_XSTATS: ::c_ushort = 3;
3219 pub const IFLA_INFO_SLAVE_KIND: ::c_ushort = 4;
3220 pub const IFLA_INFO_SLAVE_DATA: ::c_ushort = 5;
3221 
3222 // linux/rtnetlink.h
3223 pub const TCA_UNSPEC: ::c_ushort = 0;
3224 pub const TCA_KIND: ::c_ushort = 1;
3225 pub const TCA_OPTIONS: ::c_ushort = 2;
3226 pub const TCA_STATS: ::c_ushort = 3;
3227 pub const TCA_XSTATS: ::c_ushort = 4;
3228 pub const TCA_RATE: ::c_ushort = 5;
3229 pub const TCA_FCNT: ::c_ushort = 6;
3230 pub const TCA_STATS2: ::c_ushort = 7;
3231 pub const TCA_STAB: ::c_ushort = 8;
3232 
3233 pub const RTM_NEWLINK: u16 = 16;
3234 pub const RTM_DELLINK: u16 = 17;
3235 pub const RTM_GETLINK: u16 = 18;
3236 pub const RTM_SETLINK: u16 = 19;
3237 pub const RTM_NEWADDR: u16 = 20;
3238 pub const RTM_DELADDR: u16 = 21;
3239 pub const RTM_GETADDR: u16 = 22;
3240 pub const RTM_NEWROUTE: u16 = 24;
3241 pub const RTM_DELROUTE: u16 = 25;
3242 pub const RTM_GETROUTE: u16 = 26;
3243 pub const RTM_NEWNEIGH: u16 = 28;
3244 pub const RTM_DELNEIGH: u16 = 29;
3245 pub const RTM_GETNEIGH: u16 = 30;
3246 pub const RTM_NEWRULE: u16 = 32;
3247 pub const RTM_DELRULE: u16 = 33;
3248 pub const RTM_GETRULE: u16 = 34;
3249 pub const RTM_NEWQDISC: u16 = 36;
3250 pub const RTM_DELQDISC: u16 = 37;
3251 pub const RTM_GETQDISC: u16 = 38;
3252 pub const RTM_NEWTCLASS: u16 = 40;
3253 pub const RTM_DELTCLASS: u16 = 41;
3254 pub const RTM_GETTCLASS: u16 = 42;
3255 pub const RTM_NEWTFILTER: u16 = 44;
3256 pub const RTM_DELTFILTER: u16 = 45;
3257 pub const RTM_GETTFILTER: u16 = 46;
3258 pub const RTM_NEWACTION: u16 = 48;
3259 pub const RTM_DELACTION: u16 = 49;
3260 pub const RTM_GETACTION: u16 = 50;
3261 pub const RTM_NEWPREFIX: u16 = 52;
3262 pub const RTM_GETMULTICAST: u16 = 58;
3263 pub const RTM_GETANYCAST: u16 = 62;
3264 pub const RTM_NEWNEIGHTBL: u16 = 64;
3265 pub const RTM_GETNEIGHTBL: u16 = 66;
3266 pub const RTM_SETNEIGHTBL: u16 = 67;
3267 pub const RTM_NEWNDUSEROPT: u16 = 68;
3268 pub const RTM_NEWADDRLABEL: u16 = 72;
3269 pub const RTM_DELADDRLABEL: u16 = 73;
3270 pub const RTM_GETADDRLABEL: u16 = 74;
3271 pub const RTM_GETDCB: u16 = 78;
3272 pub const RTM_SETDCB: u16 = 79;
3273 pub const RTM_NEWNETCONF: u16 = 80;
3274 pub const RTM_GETNETCONF: u16 = 82;
3275 pub const RTM_NEWMDB: u16 = 84;
3276 pub const RTM_DELMDB: u16 = 85;
3277 pub const RTM_GETMDB: u16 = 86;
3278 pub const RTM_NEWNSID: u16 = 88;
3279 pub const RTM_DELNSID: u16 = 89;
3280 pub const RTM_GETNSID: u16 = 90;
3281 
3282 pub const RTM_F_NOTIFY: ::c_uint = 0x100;
3283 pub const RTM_F_CLONED: ::c_uint = 0x200;
3284 pub const RTM_F_EQUALIZE: ::c_uint = 0x400;
3285 pub const RTM_F_PREFIX: ::c_uint = 0x800;
3286 
3287 pub const RTA_UNSPEC: ::c_ushort = 0;
3288 pub const RTA_DST: ::c_ushort = 1;
3289 pub const RTA_SRC: ::c_ushort = 2;
3290 pub const RTA_IIF: ::c_ushort = 3;
3291 pub const RTA_OIF: ::c_ushort = 4;
3292 pub const RTA_GATEWAY: ::c_ushort = 5;
3293 pub const RTA_PRIORITY: ::c_ushort = 6;
3294 pub const RTA_PREFSRC: ::c_ushort = 7;
3295 pub const RTA_METRICS: ::c_ushort = 8;
3296 pub const RTA_MULTIPATH: ::c_ushort = 9;
3297 pub const RTA_PROTOINFO: ::c_ushort = 10; // No longer used
3298 pub const RTA_FLOW: ::c_ushort = 11;
3299 pub const RTA_CACHEINFO: ::c_ushort = 12;
3300 pub const RTA_SESSION: ::c_ushort = 13; // No longer used
3301 pub const RTA_MP_ALGO: ::c_ushort = 14; // No longer used
3302 pub const RTA_TABLE: ::c_ushort = 15;
3303 pub const RTA_MARK: ::c_ushort = 16;
3304 pub const RTA_MFC_STATS: ::c_ushort = 17;
3305 
3306 pub const RTN_UNSPEC: ::c_uchar = 0;
3307 pub const RTN_UNICAST: ::c_uchar = 1;
3308 pub const RTN_LOCAL: ::c_uchar = 2;
3309 pub const RTN_BROADCAST: ::c_uchar = 3;
3310 pub const RTN_ANYCAST: ::c_uchar = 4;
3311 pub const RTN_MULTICAST: ::c_uchar = 5;
3312 pub const RTN_BLACKHOLE: ::c_uchar = 6;
3313 pub const RTN_UNREACHABLE: ::c_uchar = 7;
3314 pub const RTN_PROHIBIT: ::c_uchar = 8;
3315 pub const RTN_THROW: ::c_uchar = 9;
3316 pub const RTN_NAT: ::c_uchar = 10;
3317 pub const RTN_XRESOLVE: ::c_uchar = 11;
3318 
3319 pub const RTPROT_UNSPEC: ::c_uchar = 0;
3320 pub const RTPROT_REDIRECT: ::c_uchar = 1;
3321 pub const RTPROT_KERNEL: ::c_uchar = 2;
3322 pub const RTPROT_BOOT: ::c_uchar = 3;
3323 pub const RTPROT_STATIC: ::c_uchar = 4;
3324 
3325 pub const RT_SCOPE_UNIVERSE: ::c_uchar = 0;
3326 pub const RT_SCOPE_SITE: ::c_uchar = 200;
3327 pub const RT_SCOPE_LINK: ::c_uchar = 253;
3328 pub const RT_SCOPE_HOST: ::c_uchar = 254;
3329 pub const RT_SCOPE_NOWHERE: ::c_uchar = 255;
3330 
3331 pub const RT_TABLE_UNSPEC: ::c_uchar = 0;
3332 pub const RT_TABLE_COMPAT: ::c_uchar = 252;
3333 pub const RT_TABLE_DEFAULT: ::c_uchar = 253;
3334 pub const RT_TABLE_MAIN: ::c_uchar = 254;
3335 pub const RT_TABLE_LOCAL: ::c_uchar = 255;
3336 
3337 pub const RTMSG_NEWDEVICE: u32 = 0x11;
3338 pub const RTMSG_DELDEVICE: u32 = 0x12;
3339 pub const RTMSG_NEWROUTE: u32 = 0x21;
3340 pub const RTMSG_DELROUTE: u32 = 0x22;
3341 
3342 pub const CTL_KERN: ::c_int = 1;
3343 pub const CTL_VM: ::c_int = 2;
3344 pub const CTL_NET: ::c_int = 3;
3345 pub const CTL_FS: ::c_int = 5;
3346 pub const CTL_DEBUG: ::c_int = 6;
3347 pub const CTL_DEV: ::c_int = 7;
3348 pub const CTL_BUS: ::c_int = 8;
3349 pub const CTL_ABI: ::c_int = 9;
3350 pub const CTL_CPU: ::c_int = 10;
3351 
3352 pub const CTL_BUS_ISA: ::c_int = 1;
3353 
3354 pub const INOTIFY_MAX_USER_INSTANCES: ::c_int = 1;
3355 pub const INOTIFY_MAX_USER_WATCHES: ::c_int = 2;
3356 pub const INOTIFY_MAX_QUEUED_EVENTS: ::c_int = 3;
3357 
3358 pub const KERN_OSTYPE: ::c_int = 1;
3359 pub const KERN_OSRELEASE: ::c_int = 2;
3360 pub const KERN_OSREV: ::c_int = 3;
3361 pub const KERN_VERSION: ::c_int = 4;
3362 pub const KERN_SECUREMASK: ::c_int = 5;
3363 pub const KERN_PROF: ::c_int = 6;
3364 pub const KERN_NODENAME: ::c_int = 7;
3365 pub const KERN_DOMAINNAME: ::c_int = 8;
3366 pub const KERN_PANIC: ::c_int = 15;
3367 pub const KERN_REALROOTDEV: ::c_int = 16;
3368 pub const KERN_SPARC_REBOOT: ::c_int = 21;
3369 pub const KERN_CTLALTDEL: ::c_int = 22;
3370 pub const KERN_PRINTK: ::c_int = 23;
3371 pub const KERN_NAMETRANS: ::c_int = 24;
3372 pub const KERN_PPC_HTABRECLAIM: ::c_int = 25;
3373 pub const KERN_PPC_ZEROPAGED: ::c_int = 26;
3374 pub const KERN_PPC_POWERSAVE_NAP: ::c_int = 27;
3375 pub const KERN_MODPROBE: ::c_int = 28;
3376 pub const KERN_SG_BIG_BUFF: ::c_int = 29;
3377 pub const KERN_ACCT: ::c_int = 30;
3378 pub const KERN_PPC_L2CR: ::c_int = 31;
3379 pub const KERN_RTSIGNR: ::c_int = 32;
3380 pub const KERN_RTSIGMAX: ::c_int = 33;
3381 pub const KERN_SHMMAX: ::c_int = 34;
3382 pub const KERN_MSGMAX: ::c_int = 35;
3383 pub const KERN_MSGMNB: ::c_int = 36;
3384 pub const KERN_MSGPOOL: ::c_int = 37;
3385 pub const KERN_SYSRQ: ::c_int = 38;
3386 pub const KERN_MAX_THREADS: ::c_int = 39;
3387 pub const KERN_RANDOM: ::c_int = 40;
3388 pub const KERN_SHMALL: ::c_int = 41;
3389 pub const KERN_MSGMNI: ::c_int = 42;
3390 pub const KERN_SEM: ::c_int = 43;
3391 pub const KERN_SPARC_STOP_A: ::c_int = 44;
3392 pub const KERN_SHMMNI: ::c_int = 45;
3393 pub const KERN_OVERFLOWUID: ::c_int = 46;
3394 pub const KERN_OVERFLOWGID: ::c_int = 47;
3395 pub const KERN_SHMPATH: ::c_int = 48;
3396 pub const KERN_HOTPLUG: ::c_int = 49;
3397 pub const KERN_IEEE_EMULATION_WARNINGS: ::c_int = 50;
3398 pub const KERN_S390_USER_DEBUG_LOGGING: ::c_int = 51;
3399 pub const KERN_CORE_USES_PID: ::c_int = 52;
3400 pub const KERN_TAINTED: ::c_int = 53;
3401 pub const KERN_CADPID: ::c_int = 54;
3402 pub const KERN_PIDMAX: ::c_int = 55;
3403 pub const KERN_CORE_PATTERN: ::c_int = 56;
3404 pub const KERN_PANIC_ON_OOPS: ::c_int = 57;
3405 pub const KERN_HPPA_PWRSW: ::c_int = 58;
3406 pub const KERN_HPPA_UNALIGNED: ::c_int = 59;
3407 pub const KERN_PRINTK_RATELIMIT: ::c_int = 60;
3408 pub const KERN_PRINTK_RATELIMIT_BURST: ::c_int = 61;
3409 pub const KERN_PTY: ::c_int = 62;
3410 pub const KERN_NGROUPS_MAX: ::c_int = 63;
3411 pub const KERN_SPARC_SCONS_PWROFF: ::c_int = 64;
3412 pub const KERN_HZ_TIMER: ::c_int = 65;
3413 pub const KERN_UNKNOWN_NMI_PANIC: ::c_int = 66;
3414 pub const KERN_BOOTLOADER_TYPE: ::c_int = 67;
3415 pub const KERN_RANDOMIZE: ::c_int = 68;
3416 pub const KERN_SETUID_DUMPABLE: ::c_int = 69;
3417 pub const KERN_SPIN_RETRY: ::c_int = 70;
3418 pub const KERN_ACPI_VIDEO_FLAGS: ::c_int = 71;
3419 pub const KERN_IA64_UNALIGNED: ::c_int = 72;
3420 pub const KERN_COMPAT_LOG: ::c_int = 73;
3421 pub const KERN_MAX_LOCK_DEPTH: ::c_int = 74;
3422 
3423 pub const VM_OVERCOMMIT_MEMORY: ::c_int = 5;
3424 pub const VM_PAGE_CLUSTER: ::c_int = 10;
3425 pub const VM_DIRTY_BACKGROUND: ::c_int = 11;
3426 pub const VM_DIRTY_RATIO: ::c_int = 12;
3427 pub const VM_DIRTY_WB_CS: ::c_int = 13;
3428 pub const VM_DIRTY_EXPIRE_CS: ::c_int = 14;
3429 pub const VM_NR_PDFLUSH_THREADS: ::c_int = 15;
3430 pub const VM_OVERCOMMIT_RATIO: ::c_int = 16;
3431 pub const VM_PAGEBUF: ::c_int = 17;
3432 pub const VM_HUGETLB_PAGES: ::c_int = 18;
3433 pub const VM_SWAPPINESS: ::c_int = 19;
3434 pub const VM_LOWMEM_RESERVE_RATIO: ::c_int = 20;
3435 pub const VM_MIN_FREE_KBYTES: ::c_int = 21;
3436 pub const VM_MAX_MAP_COUNT: ::c_int = 22;
3437 pub const VM_LAPTOP_MODE: ::c_int = 23;
3438 pub const VM_BLOCK_DUMP: ::c_int = 24;
3439 pub const VM_HUGETLB_GROUP: ::c_int = 25;
3440 pub const VM_VFS_CACHE_PRESSURE: ::c_int = 26;
3441 pub const VM_LEGACY_VA_LAYOUT: ::c_int = 27;
3442 pub const VM_SWAP_TOKEN_TIMEOUT: ::c_int = 28;
3443 pub const VM_DROP_PAGECACHE: ::c_int = 29;
3444 pub const VM_PERCPU_PAGELIST_FRACTION: ::c_int = 30;
3445 pub const VM_ZONE_RECLAIM_MODE: ::c_int = 31;
3446 pub const VM_MIN_UNMAPPED: ::c_int = 32;
3447 pub const VM_PANIC_ON_OOM: ::c_int = 33;
3448 pub const VM_VDSO_ENABLED: ::c_int = 34;
3449 
3450 pub const NET_CORE: ::c_int = 1;
3451 pub const NET_ETHER: ::c_int = 2;
3452 pub const NET_802: ::c_int = 3;
3453 pub const NET_UNIX: ::c_int = 4;
3454 pub const NET_IPV4: ::c_int = 5;
3455 pub const NET_IPX: ::c_int = 6;
3456 pub const NET_ATALK: ::c_int = 7;
3457 pub const NET_NETROM: ::c_int = 8;
3458 pub const NET_AX25: ::c_int = 9;
3459 pub const NET_BRIDGE: ::c_int = 10;
3460 pub const NET_ROSE: ::c_int = 11;
3461 pub const NET_IPV6: ::c_int = 12;
3462 pub const NET_X25: ::c_int = 13;
3463 pub const NET_TR: ::c_int = 14;
3464 pub const NET_DECNET: ::c_int = 15;
3465 pub const NET_ECONET: ::c_int = 16;
3466 pub const NET_SCTP: ::c_int = 17;
3467 pub const NET_LLC: ::c_int = 18;
3468 pub const NET_NETFILTER: ::c_int = 19;
3469 pub const NET_DCCP: ::c_int = 20;
3470 pub const HUGETLB_FLAG_ENCODE_SHIFT: ::c_int = 26;
3471 pub const MAP_HUGE_SHIFT: ::c_int = HUGETLB_FLAG_ENCODE_SHIFT;
3472 
3473 // include/linux/sched.h
3474 pub const PF_VCPU: ::c_int = 0x00000001;
3475 pub const PF_IDLE: ::c_int = 0x00000002;
3476 pub const PF_EXITING: ::c_int = 0x00000004;
3477 pub const PF_POSTCOREDUMP: ::c_int = 0x00000008;
3478 pub const PF_IO_WORKER: ::c_int = 0x00000010;
3479 pub const PF_WQ_WORKER: ::c_int = 0x00000020;
3480 pub const PF_FORKNOEXEC: ::c_int = 0x00000040;
3481 pub const PF_MCE_PROCESS: ::c_int = 0x00000080;
3482 pub const PF_SUPERPRIV: ::c_int = 0x00000100;
3483 pub const PF_DUMPCORE: ::c_int = 0x00000200;
3484 pub const PF_SIGNALED: ::c_int = 0x00000400;
3485 pub const PF_MEMALLOC: ::c_int = 0x00000800;
3486 pub const PF_NPROC_EXCEEDED: ::c_int = 0x00001000;
3487 pub const PF_USED_MATH: ::c_int = 0x00002000;
3488 pub const PF_USER_WORKER: ::c_int = 0x00004000;
3489 pub const PF_NOFREEZE: ::c_int = 0x00008000;
3490 
3491 pub const PF_KSWAPD: ::c_int = 0x00020000;
3492 pub const PF_MEMALLOC_NOFS: ::c_int = 0x00040000;
3493 pub const PF_MEMALLOC_NOIO: ::c_int = 0x00080000;
3494 pub const PF_LOCAL_THROTTLE: ::c_int = 0x00100000;
3495 pub const PF_KTHREAD: ::c_int = 0x00200000;
3496 pub const PF_RANDOMIZE: ::c_int = 0x00400000;
3497 
3498 pub const PF_NO_SETAFFINITY: ::c_int = 0x04000000;
3499 pub const PF_MCE_EARLY: ::c_int = 0x08000000;
3500 pub const PF_MEMALLOC_PIN: ::c_int = 0x10000000;
3501 
3502 pub const PF_SUSPEND_TASK: ::c_int = 0x80000000;
3503 
3504 // Most `*_SUPER_MAGIC` constants are defined at the `linux_like` level; the
3505 // following are only available on newer Linux versions than the versions
3506 // currently used in CI in some configurations, so we define them here.
3507 cfg_if! {
3508     if #[cfg(not(target_arch = "s390x"))] {
3509         pub const XFS_SUPER_MAGIC: ::c_long = 0x58465342;
3510     } else if #[cfg(target_arch = "s390x")] {
3511         pub const XFS_SUPER_MAGIC: ::c_uint = 0x58465342;
3512     }
3513 }
3514 
3515 f! {
3516     pub fn CMSG_NXTHDR(mhdr: *const msghdr,
3517                        cmsg: *const cmsghdr) -> *mut cmsghdr {
3518         let next = (cmsg as usize
3519                     + super::CMSG_ALIGN((*cmsg).cmsg_len as usize))
3520             as *mut cmsghdr;
3521         let max = (*mhdr).msg_control as usize
3522             + (*mhdr).msg_controllen as usize;
3523         if (next.offset(1)) as usize > max {
3524             0 as *mut cmsghdr
3525         } else {
3526             next as *mut cmsghdr
3527         }
3528     }
3529 
3530     pub fn CPU_ALLOC_SIZE(count: ::c_int) -> ::size_t {
3531         let _dummy: cpu_set_t = ::mem::zeroed();
3532         let size_in_bits = 8 * ::mem::size_of_val(&_dummy.__bits[0]);
3533         ((count as ::size_t + size_in_bits - 1) / 8) as ::size_t
3534     }
3535 
3536     pub fn CPU_ZERO(cpuset: &mut cpu_set_t) -> () {
3537         for slot in cpuset.__bits.iter_mut() {
3538             *slot = 0;
3539         }
3540     }
3541 
3542     pub fn CPU_SET(cpu: usize, cpuset: &mut cpu_set_t) -> () {
3543         let size_in_bits
3544             = 8 * ::mem::size_of_val(&cpuset.__bits[0]); // 32, 64 etc
3545         let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);
3546         cpuset.__bits[idx] |= 1 << offset;
3547         ()
3548     }
3549 
3550     pub fn CPU_CLR(cpu: usize, cpuset: &mut cpu_set_t) -> () {
3551         let size_in_bits
3552             = 8 * ::mem::size_of_val(&cpuset.__bits[0]); // 32, 64 etc
3553         let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);
3554         cpuset.__bits[idx] &= !(1 << offset);
3555         ()
3556     }
3557 
3558     pub fn CPU_ISSET(cpu: usize, cpuset: &cpu_set_t) -> bool {
3559         let size_in_bits = 8 * ::mem::size_of_val(&cpuset.__bits[0]);
3560         let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);
3561         0 != (cpuset.__bits[idx] & (1 << offset))
3562     }
3563 
3564     pub fn CPU_COUNT_S(size: usize, cpuset: &cpu_set_t) -> ::c_int {
3565         let mut s: u32 = 0;
3566         let size_of_mask = ::mem::size_of_val(&cpuset.__bits[0]);
3567         for i in cpuset.__bits[..(size / size_of_mask)].iter() {
3568             s += i.count_ones();
3569         };
3570         s as ::c_int
3571     }
3572 
3573     pub fn CPU_COUNT(cpuset: &cpu_set_t) -> ::c_int {
3574         CPU_COUNT_S(::mem::size_of::<cpu_set_t>(), cpuset)
3575     }
3576 
3577     pub fn CPU_EQUAL(set1: &cpu_set_t, set2: &cpu_set_t) -> bool {
3578         set1.__bits == set2.__bits
3579     }
3580 
3581     pub fn major(dev: ::dev_t) -> ::c_int {
3582         ((dev >> 8) & 0xfff) as ::c_int
3583     }
3584     pub fn minor(dev: ::dev_t) -> ::c_int {
3585         ((dev & 0xff) | ((dev >> 12) & 0xfff00)) as ::c_int
3586     }
3587     pub fn NLA_ALIGN(len: ::c_int) -> ::c_int {
3588         return ((len) + NLA_ALIGNTO - 1) & !(NLA_ALIGNTO - 1)
3589     }
3590 
3591     pub fn SO_EE_OFFENDER(ee: *const ::sock_extended_err) -> *mut ::sockaddr {
3592         ee.offset(1) as *mut ::sockaddr
3593     }
3594 }
3595 
3596 safe_f! {
3597     pub {const} fn makedev(ma: ::c_uint, mi: ::c_uint) -> ::dev_t {
3598         let ma = ma as ::dev_t;
3599         let mi = mi as ::dev_t;
3600         ((ma & 0xfff) << 8) | (mi & 0xff) | ((mi & 0xfff00) << 12)
3601     }
3602 
3603 }
3604 
3605 extern "C" {
getrlimit64(resource: ::c_int, rlim: *mut rlimit64) -> ::c_int3606     pub fn getrlimit64(resource: ::c_int, rlim: *mut rlimit64) -> ::c_int;
setrlimit64(resource: ::c_int, rlim: *const rlimit64) -> ::c_int3607     pub fn setrlimit64(resource: ::c_int, rlim: *const rlimit64) -> ::c_int;
getrlimit(resource: ::c_int, rlim: *mut ::rlimit) -> ::c_int3608     pub fn getrlimit(resource: ::c_int, rlim: *mut ::rlimit) -> ::c_int;
setrlimit(resource: ::c_int, rlim: *const ::rlimit) -> ::c_int3609     pub fn setrlimit(resource: ::c_int, rlim: *const ::rlimit) -> ::c_int;
prlimit( pid: ::pid_t, resource: ::c_int, new_limit: *const ::rlimit, old_limit: *mut ::rlimit, ) -> ::c_int3610     pub fn prlimit(
3611         pid: ::pid_t,
3612         resource: ::c_int,
3613         new_limit: *const ::rlimit,
3614         old_limit: *mut ::rlimit,
3615     ) -> ::c_int;
prlimit64( pid: ::pid_t, resource: ::c_int, new_limit: *const ::rlimit64, old_limit: *mut ::rlimit64, ) -> ::c_int3616     pub fn prlimit64(
3617         pid: ::pid_t,
3618         resource: ::c_int,
3619         new_limit: *const ::rlimit64,
3620         old_limit: *mut ::rlimit64,
3621     ) -> ::c_int;
strerror_r(errnum: ::c_int, buf: *mut c_char, buflen: ::size_t) -> ::c_int3622     pub fn strerror_r(errnum: ::c_int, buf: *mut c_char, buflen: ::size_t) -> ::c_int;
3623 
gettimeofday(tp: *mut ::timeval, tz: *mut ::timezone) -> ::c_int3624     pub fn gettimeofday(tp: *mut ::timeval, tz: *mut ::timezone) -> ::c_int;
mlock2(addr: *const ::c_void, len: ::size_t, flags: ::c_int) -> ::c_int3625     pub fn mlock2(addr: *const ::c_void, len: ::size_t, flags: ::c_int) -> ::c_int;
madvise(addr: *mut ::c_void, len: ::size_t, advice: ::c_int) -> ::c_int3626     pub fn madvise(addr: *mut ::c_void, len: ::size_t, advice: ::c_int) -> ::c_int;
ioctl(fd: ::c_int, request: ::c_int, ...) -> ::c_int3627     pub fn ioctl(fd: ::c_int, request: ::c_int, ...) -> ::c_int;
msync(addr: *mut ::c_void, len: ::size_t, flags: ::c_int) -> ::c_int3628     pub fn msync(addr: *mut ::c_void, len: ::size_t, flags: ::c_int) -> ::c_int;
mprotect(addr: *mut ::c_void, len: ::size_t, prot: ::c_int) -> ::c_int3629     pub fn mprotect(addr: *mut ::c_void, len: ::size_t, prot: ::c_int) -> ::c_int;
recvfrom( socket: ::c_int, buf: *mut ::c_void, len: ::size_t, flags: ::c_int, addr: *mut ::sockaddr, addrlen: *mut ::socklen_t, ) -> ::ssize_t3630     pub fn recvfrom(
3631         socket: ::c_int,
3632         buf: *mut ::c_void,
3633         len: ::size_t,
3634         flags: ::c_int,
3635         addr: *mut ::sockaddr,
3636         addrlen: *mut ::socklen_t,
3637     ) -> ::ssize_t;
getnameinfo( sa: *const ::sockaddr, salen: ::socklen_t, host: *mut ::c_char, hostlen: ::size_t, serv: *mut ::c_char, servlen: ::size_t, flags: ::c_int, ) -> ::c_int3638     pub fn getnameinfo(
3639         sa: *const ::sockaddr,
3640         salen: ::socklen_t,
3641         host: *mut ::c_char,
3642         hostlen: ::size_t,
3643         serv: *mut ::c_char,
3644         servlen: ::size_t,
3645         flags: ::c_int,
3646     ) -> ::c_int;
preadv(fd: ::c_int, iov: *const ::iovec, count: ::c_int, offset: ::off_t) -> ::ssize_t3647     pub fn preadv(fd: ::c_int, iov: *const ::iovec, count: ::c_int, offset: ::off_t) -> ::ssize_t;
pwritev(fd: ::c_int, iov: *const ::iovec, count: ::c_int, offset: ::off_t) -> ::ssize_t3648     pub fn pwritev(fd: ::c_int, iov: *const ::iovec, count: ::c_int, offset: ::off_t) -> ::ssize_t;
process_vm_readv( pid: ::pid_t, local_iov: *const ::iovec, local_iov_count: ::c_ulong, remote_iov: *const ::iovec, remote_iov_count: ::c_ulong, flags: ::c_ulong, ) -> ::ssize_t3649     pub fn process_vm_readv(
3650         pid: ::pid_t,
3651         local_iov: *const ::iovec,
3652         local_iov_count: ::c_ulong,
3653         remote_iov: *const ::iovec,
3654         remote_iov_count: ::c_ulong,
3655         flags: ::c_ulong,
3656     ) -> ::ssize_t;
process_vm_writev( pid: ::pid_t, local_iov: *const ::iovec, local_iov_count: ::c_ulong, remote_iov: *const ::iovec, remote_iov_count: ::c_ulong, flags: ::c_ulong, ) -> ::ssize_t3657     pub fn process_vm_writev(
3658         pid: ::pid_t,
3659         local_iov: *const ::iovec,
3660         local_iov_count: ::c_ulong,
3661         remote_iov: *const ::iovec,
3662         remote_iov_count: ::c_ulong,
3663         flags: ::c_ulong,
3664     ) -> ::ssize_t;
ptrace(request: ::c_int, ...) -> ::c_long3665     pub fn ptrace(request: ::c_int, ...) -> ::c_long;
getpriority(which: ::c_int, who: ::id_t) -> ::c_int3666     pub fn getpriority(which: ::c_int, who: ::id_t) -> ::c_int;
setpriority(which: ::c_int, who: ::id_t, prio: ::c_int) -> ::c_int3667     pub fn setpriority(which: ::c_int, who: ::id_t, prio: ::c_int) -> ::c_int;
__sched_cpualloc(count: ::size_t) -> *mut ::cpu_set_t3668     pub fn __sched_cpualloc(count: ::size_t) -> *mut ::cpu_set_t;
__sched_cpufree(set: *mut ::cpu_set_t)3669     pub fn __sched_cpufree(set: *mut ::cpu_set_t);
__sched_cpucount(setsize: ::size_t, set: *const cpu_set_t) -> ::c_int3670     pub fn __sched_cpucount(setsize: ::size_t, set: *const cpu_set_t) -> ::c_int;
sched_getcpu() -> ::c_int3671     pub fn sched_getcpu() -> ::c_int;
mallinfo() -> ::mallinfo3672     pub fn mallinfo() -> ::mallinfo;
3673     // available from API 23
malloc_info(options: ::c_int, stream: *mut ::FILE) -> ::c_int3674     pub fn malloc_info(options: ::c_int, stream: *mut ::FILE) -> ::c_int;
3675 
malloc_usable_size(ptr: *const ::c_void) -> ::size_t3676     pub fn malloc_usable_size(ptr: *const ::c_void) -> ::size_t;
3677 
utmpname(name: *const ::c_char) -> ::c_int3678     pub fn utmpname(name: *const ::c_char) -> ::c_int;
setutent()3679     pub fn setutent();
getutent() -> *mut utmp3680     pub fn getutent() -> *mut utmp;
3681 
seekdir(dirp: *mut ::DIR, loc: ::c_long)3682     pub fn seekdir(dirp: *mut ::DIR, loc: ::c_long);
telldir(dirp: *mut ::DIR) -> ::c_long3683     pub fn telldir(dirp: *mut ::DIR) -> ::c_long;
fallocate(fd: ::c_int, mode: ::c_int, offset: ::off_t, len: ::off_t) -> ::c_int3684     pub fn fallocate(fd: ::c_int, mode: ::c_int, offset: ::off_t, len: ::off_t) -> ::c_int;
fallocate64(fd: ::c_int, mode: ::c_int, offset: ::off64_t, len: ::off64_t) -> ::c_int3685     pub fn fallocate64(fd: ::c_int, mode: ::c_int, offset: ::off64_t, len: ::off64_t) -> ::c_int;
posix_fallocate(fd: ::c_int, offset: ::off_t, len: ::off_t) -> ::c_int3686     pub fn posix_fallocate(fd: ::c_int, offset: ::off_t, len: ::off_t) -> ::c_int;
posix_fallocate64(fd: ::c_int, offset: ::off64_t, len: ::off64_t) -> ::c_int3687     pub fn posix_fallocate64(fd: ::c_int, offset: ::off64_t, len: ::off64_t) -> ::c_int;
getxattr( path: *const c_char, name: *const c_char, value: *mut ::c_void, size: ::size_t, ) -> ::ssize_t3688     pub fn getxattr(
3689         path: *const c_char,
3690         name: *const c_char,
3691         value: *mut ::c_void,
3692         size: ::size_t,
3693     ) -> ::ssize_t;
lgetxattr( path: *const c_char, name: *const c_char, value: *mut ::c_void, size: ::size_t, ) -> ::ssize_t3694     pub fn lgetxattr(
3695         path: *const c_char,
3696         name: *const c_char,
3697         value: *mut ::c_void,
3698         size: ::size_t,
3699     ) -> ::ssize_t;
fgetxattr( filedes: ::c_int, name: *const c_char, value: *mut ::c_void, size: ::size_t, ) -> ::ssize_t3700     pub fn fgetxattr(
3701         filedes: ::c_int,
3702         name: *const c_char,
3703         value: *mut ::c_void,
3704         size: ::size_t,
3705     ) -> ::ssize_t;
setxattr( path: *const c_char, name: *const c_char, value: *const ::c_void, size: ::size_t, flags: ::c_int, ) -> ::c_int3706     pub fn setxattr(
3707         path: *const c_char,
3708         name: *const c_char,
3709         value: *const ::c_void,
3710         size: ::size_t,
3711         flags: ::c_int,
3712     ) -> ::c_int;
lsetxattr( path: *const c_char, name: *const c_char, value: *const ::c_void, size: ::size_t, flags: ::c_int, ) -> ::c_int3713     pub fn lsetxattr(
3714         path: *const c_char,
3715         name: *const c_char,
3716         value: *const ::c_void,
3717         size: ::size_t,
3718         flags: ::c_int,
3719     ) -> ::c_int;
fsetxattr( filedes: ::c_int, name: *const c_char, value: *const ::c_void, size: ::size_t, flags: ::c_int, ) -> ::c_int3720     pub fn fsetxattr(
3721         filedes: ::c_int,
3722         name: *const c_char,
3723         value: *const ::c_void,
3724         size: ::size_t,
3725         flags: ::c_int,
3726     ) -> ::c_int;
listxattr(path: *const c_char, list: *mut c_char, size: ::size_t) -> ::ssize_t3727     pub fn listxattr(path: *const c_char, list: *mut c_char, size: ::size_t) -> ::ssize_t;
llistxattr(path: *const c_char, list: *mut c_char, size: ::size_t) -> ::ssize_t3728     pub fn llistxattr(path: *const c_char, list: *mut c_char, size: ::size_t) -> ::ssize_t;
flistxattr(filedes: ::c_int, list: *mut c_char, size: ::size_t) -> ::ssize_t3729     pub fn flistxattr(filedes: ::c_int, list: *mut c_char, size: ::size_t) -> ::ssize_t;
removexattr(path: *const c_char, name: *const c_char) -> ::c_int3730     pub fn removexattr(path: *const c_char, name: *const c_char) -> ::c_int;
lremovexattr(path: *const c_char, name: *const c_char) -> ::c_int3731     pub fn lremovexattr(path: *const c_char, name: *const c_char) -> ::c_int;
fremovexattr(filedes: ::c_int, name: *const c_char) -> ::c_int3732     pub fn fremovexattr(filedes: ::c_int, name: *const c_char) -> ::c_int;
signalfd(fd: ::c_int, mask: *const ::sigset_t, flags: ::c_int) -> ::c_int3733     pub fn signalfd(fd: ::c_int, mask: *const ::sigset_t, flags: ::c_int) -> ::c_int;
timerfd_create(clock: ::clockid_t, flags: ::c_int) -> ::c_int3734     pub fn timerfd_create(clock: ::clockid_t, flags: ::c_int) -> ::c_int;
timerfd_gettime(fd: ::c_int, current_value: *mut itimerspec) -> ::c_int3735     pub fn timerfd_gettime(fd: ::c_int, current_value: *mut itimerspec) -> ::c_int;
timerfd_settime( fd: ::c_int, flags: ::c_int, new_value: *const itimerspec, old_value: *mut itimerspec, ) -> ::c_int3736     pub fn timerfd_settime(
3737         fd: ::c_int,
3738         flags: ::c_int,
3739         new_value: *const itimerspec,
3740         old_value: *mut itimerspec,
3741     ) -> ::c_int;
syscall(num: ::c_long, ...) -> ::c_long3742     pub fn syscall(num: ::c_long, ...) -> ::c_long;
sched_getaffinity(pid: ::pid_t, cpusetsize: ::size_t, cpuset: *mut cpu_set_t) -> ::c_int3743     pub fn sched_getaffinity(pid: ::pid_t, cpusetsize: ::size_t, cpuset: *mut cpu_set_t)
3744         -> ::c_int;
sched_setaffinity( pid: ::pid_t, cpusetsize: ::size_t, cpuset: *const cpu_set_t, ) -> ::c_int3745     pub fn sched_setaffinity(
3746         pid: ::pid_t,
3747         cpusetsize: ::size_t,
3748         cpuset: *const cpu_set_t,
3749     ) -> ::c_int;
epoll_create(size: ::c_int) -> ::c_int3750     pub fn epoll_create(size: ::c_int) -> ::c_int;
epoll_create1(flags: ::c_int) -> ::c_int3751     pub fn epoll_create1(flags: ::c_int) -> ::c_int;
epoll_wait( epfd: ::c_int, events: *mut ::epoll_event, maxevents: ::c_int, timeout: ::c_int, ) -> ::c_int3752     pub fn epoll_wait(
3753         epfd: ::c_int,
3754         events: *mut ::epoll_event,
3755         maxevents: ::c_int,
3756         timeout: ::c_int,
3757     ) -> ::c_int;
epoll_ctl(epfd: ::c_int, op: ::c_int, fd: ::c_int, event: *mut ::epoll_event) -> ::c_int3758     pub fn epoll_ctl(epfd: ::c_int, op: ::c_int, fd: ::c_int, event: *mut ::epoll_event)
3759         -> ::c_int;
pthread_getschedparam( native: ::pthread_t, policy: *mut ::c_int, param: *mut ::sched_param, ) -> ::c_int3760     pub fn pthread_getschedparam(
3761         native: ::pthread_t,
3762         policy: *mut ::c_int,
3763         param: *mut ::sched_param,
3764     ) -> ::c_int;
unshare(flags: ::c_int) -> ::c_int3765     pub fn unshare(flags: ::c_int) -> ::c_int;
umount(target: *const ::c_char) -> ::c_int3766     pub fn umount(target: *const ::c_char) -> ::c_int;
sched_get_priority_max(policy: ::c_int) -> ::c_int3767     pub fn sched_get_priority_max(policy: ::c_int) -> ::c_int;
tee(fd_in: ::c_int, fd_out: ::c_int, len: ::size_t, flags: ::c_uint) -> ::ssize_t3768     pub fn tee(fd_in: ::c_int, fd_out: ::c_int, len: ::size_t, flags: ::c_uint) -> ::ssize_t;
settimeofday(tv: *const ::timeval, tz: *const ::timezone) -> ::c_int3769     pub fn settimeofday(tv: *const ::timeval, tz: *const ::timezone) -> ::c_int;
splice( fd_in: ::c_int, off_in: *mut ::loff_t, fd_out: ::c_int, off_out: *mut ::loff_t, len: ::size_t, flags: ::c_uint, ) -> ::ssize_t3770     pub fn splice(
3771         fd_in: ::c_int,
3772         off_in: *mut ::loff_t,
3773         fd_out: ::c_int,
3774         off_out: *mut ::loff_t,
3775         len: ::size_t,
3776         flags: ::c_uint,
3777     ) -> ::ssize_t;
eventfd(init: ::c_uint, flags: ::c_int) -> ::c_int3778     pub fn eventfd(init: ::c_uint, flags: ::c_int) -> ::c_int;
eventfd_read(fd: ::c_int, value: *mut eventfd_t) -> ::c_int3779     pub fn eventfd_read(fd: ::c_int, value: *mut eventfd_t) -> ::c_int;
eventfd_write(fd: ::c_int, value: eventfd_t) -> ::c_int3780     pub fn eventfd_write(fd: ::c_int, value: eventfd_t) -> ::c_int;
sched_rr_get_interval(pid: ::pid_t, tp: *mut ::timespec) -> ::c_int3781     pub fn sched_rr_get_interval(pid: ::pid_t, tp: *mut ::timespec) -> ::c_int;
sem_timedwait(sem: *mut sem_t, abstime: *const ::timespec) -> ::c_int3782     pub fn sem_timedwait(sem: *mut sem_t, abstime: *const ::timespec) -> ::c_int;
sem_getvalue(sem: *mut sem_t, sval: *mut ::c_int) -> ::c_int3783     pub fn sem_getvalue(sem: *mut sem_t, sval: *mut ::c_int) -> ::c_int;
sched_setparam(pid: ::pid_t, param: *const ::sched_param) -> ::c_int3784     pub fn sched_setparam(pid: ::pid_t, param: *const ::sched_param) -> ::c_int;
setns(fd: ::c_int, nstype: ::c_int) -> ::c_int3785     pub fn setns(fd: ::c_int, nstype: ::c_int) -> ::c_int;
swapoff(puath: *const ::c_char) -> ::c_int3786     pub fn swapoff(puath: *const ::c_char) -> ::c_int;
vmsplice( fd: ::c_int, iov: *const ::iovec, nr_segs: ::size_t, flags: ::c_uint, ) -> ::ssize_t3787     pub fn vmsplice(
3788         fd: ::c_int,
3789         iov: *const ::iovec,
3790         nr_segs: ::size_t,
3791         flags: ::c_uint,
3792     ) -> ::ssize_t;
mount( src: *const ::c_char, target: *const ::c_char, fstype: *const ::c_char, flags: ::c_ulong, data: *const ::c_void, ) -> ::c_int3793     pub fn mount(
3794         src: *const ::c_char,
3795         target: *const ::c_char,
3796         fstype: *const ::c_char,
3797         flags: ::c_ulong,
3798         data: *const ::c_void,
3799     ) -> ::c_int;
personality(persona: ::c_uint) -> ::c_int3800     pub fn personality(persona: ::c_uint) -> ::c_int;
prctl(option: ::c_int, ...) -> ::c_int3801     pub fn prctl(option: ::c_int, ...) -> ::c_int;
sched_getparam(pid: ::pid_t, param: *mut ::sched_param) -> ::c_int3802     pub fn sched_getparam(pid: ::pid_t, param: *mut ::sched_param) -> ::c_int;
ppoll( fds: *mut ::pollfd, nfds: nfds_t, timeout: *const ::timespec, sigmask: *const sigset_t, ) -> ::c_int3803     pub fn ppoll(
3804         fds: *mut ::pollfd,
3805         nfds: nfds_t,
3806         timeout: *const ::timespec,
3807         sigmask: *const sigset_t,
3808     ) -> ::c_int;
pthread_mutex_timedlock( lock: *mut pthread_mutex_t, abstime: *const ::timespec, ) -> ::c_int3809     pub fn pthread_mutex_timedlock(
3810         lock: *mut pthread_mutex_t,
3811         abstime: *const ::timespec,
3812     ) -> ::c_int;
pthread_barrierattr_init(attr: *mut ::pthread_barrierattr_t) -> ::c_int3813     pub fn pthread_barrierattr_init(attr: *mut ::pthread_barrierattr_t) -> ::c_int;
pthread_barrierattr_destroy(attr: *mut ::pthread_barrierattr_t) -> ::c_int3814     pub fn pthread_barrierattr_destroy(attr: *mut ::pthread_barrierattr_t) -> ::c_int;
pthread_barrierattr_getpshared( attr: *const ::pthread_barrierattr_t, shared: *mut ::c_int, ) -> ::c_int3815     pub fn pthread_barrierattr_getpshared(
3816         attr: *const ::pthread_barrierattr_t,
3817         shared: *mut ::c_int,
3818     ) -> ::c_int;
pthread_barrierattr_setpshared( attr: *mut ::pthread_barrierattr_t, shared: ::c_int, ) -> ::c_int3819     pub fn pthread_barrierattr_setpshared(
3820         attr: *mut ::pthread_barrierattr_t,
3821         shared: ::c_int,
3822     ) -> ::c_int;
pthread_barrier_init( barrier: *mut pthread_barrier_t, attr: *const ::pthread_barrierattr_t, count: ::c_uint, ) -> ::c_int3823     pub fn pthread_barrier_init(
3824         barrier: *mut pthread_barrier_t,
3825         attr: *const ::pthread_barrierattr_t,
3826         count: ::c_uint,
3827     ) -> ::c_int;
pthread_barrier_destroy(barrier: *mut pthread_barrier_t) -> ::c_int3828     pub fn pthread_barrier_destroy(barrier: *mut pthread_barrier_t) -> ::c_int;
pthread_barrier_wait(barrier: *mut pthread_barrier_t) -> ::c_int3829     pub fn pthread_barrier_wait(barrier: *mut pthread_barrier_t) -> ::c_int;
pthread_spin_init(lock: *mut ::pthread_spinlock_t, pshared: ::c_int) -> ::c_int3830     pub fn pthread_spin_init(lock: *mut ::pthread_spinlock_t, pshared: ::c_int) -> ::c_int;
pthread_spin_destroy(lock: *mut ::pthread_spinlock_t) -> ::c_int3831     pub fn pthread_spin_destroy(lock: *mut ::pthread_spinlock_t) -> ::c_int;
pthread_spin_lock(lock: *mut ::pthread_spinlock_t) -> ::c_int3832     pub fn pthread_spin_lock(lock: *mut ::pthread_spinlock_t) -> ::c_int;
pthread_spin_trylock(lock: *mut ::pthread_spinlock_t) -> ::c_int3833     pub fn pthread_spin_trylock(lock: *mut ::pthread_spinlock_t) -> ::c_int;
pthread_spin_unlock(lock: *mut ::pthread_spinlock_t) -> ::c_int3834     pub fn pthread_spin_unlock(lock: *mut ::pthread_spinlock_t) -> ::c_int;
clone( cb: extern "C" fn(*mut ::c_void) -> ::c_int, child_stack: *mut ::c_void, flags: ::c_int, arg: *mut ::c_void, ... ) -> ::c_int3835     pub fn clone(
3836         cb: extern "C" fn(*mut ::c_void) -> ::c_int,
3837         child_stack: *mut ::c_void,
3838         flags: ::c_int,
3839         arg: *mut ::c_void,
3840         ...
3841     ) -> ::c_int;
sched_getscheduler(pid: ::pid_t) -> ::c_int3842     pub fn sched_getscheduler(pid: ::pid_t) -> ::c_int;
clock_nanosleep( clk_id: ::clockid_t, flags: ::c_int, rqtp: *const ::timespec, rmtp: *mut ::timespec, ) -> ::c_int3843     pub fn clock_nanosleep(
3844         clk_id: ::clockid_t,
3845         flags: ::c_int,
3846         rqtp: *const ::timespec,
3847         rmtp: *mut ::timespec,
3848     ) -> ::c_int;
pthread_attr_getguardsize( attr: *const ::pthread_attr_t, guardsize: *mut ::size_t, ) -> ::c_int3849     pub fn pthread_attr_getguardsize(
3850         attr: *const ::pthread_attr_t,
3851         guardsize: *mut ::size_t,
3852     ) -> ::c_int;
pthread_attr_setguardsize(attr: *mut ::pthread_attr_t, guardsize: ::size_t) -> ::c_int3853     pub fn pthread_attr_setguardsize(attr: *mut ::pthread_attr_t, guardsize: ::size_t) -> ::c_int;
pthread_attr_getinheritsched( attr: *const ::pthread_attr_t, flag: *mut ::c_int, ) -> ::c_int3854     pub fn pthread_attr_getinheritsched(
3855         attr: *const ::pthread_attr_t,
3856         flag: *mut ::c_int,
3857     ) -> ::c_int;
pthread_attr_setinheritsched(attr: *mut ::pthread_attr_t, flag: ::c_int) -> ::c_int3858     pub fn pthread_attr_setinheritsched(attr: *mut ::pthread_attr_t, flag: ::c_int) -> ::c_int;
sethostname(name: *const ::c_char, len: ::size_t) -> ::c_int3859     pub fn sethostname(name: *const ::c_char, len: ::size_t) -> ::c_int;
sched_get_priority_min(policy: ::c_int) -> ::c_int3860     pub fn sched_get_priority_min(policy: ::c_int) -> ::c_int;
pthread_condattr_getpshared( attr: *const pthread_condattr_t, pshared: *mut ::c_int, ) -> ::c_int3861     pub fn pthread_condattr_getpshared(
3862         attr: *const pthread_condattr_t,
3863         pshared: *mut ::c_int,
3864     ) -> ::c_int;
sysinfo(info: *mut ::sysinfo) -> ::c_int3865     pub fn sysinfo(info: *mut ::sysinfo) -> ::c_int;
umount2(target: *const ::c_char, flags: ::c_int) -> ::c_int3866     pub fn umount2(target: *const ::c_char, flags: ::c_int) -> ::c_int;
pthread_setschedparam( native: ::pthread_t, policy: ::c_int, param: *const ::sched_param, ) -> ::c_int3867     pub fn pthread_setschedparam(
3868         native: ::pthread_t,
3869         policy: ::c_int,
3870         param: *const ::sched_param,
3871     ) -> ::c_int;
swapon(path: *const ::c_char, swapflags: ::c_int) -> ::c_int3872     pub fn swapon(path: *const ::c_char, swapflags: ::c_int) -> ::c_int;
sched_setscheduler( pid: ::pid_t, policy: ::c_int, param: *const ::sched_param, ) -> ::c_int3873     pub fn sched_setscheduler(
3874         pid: ::pid_t,
3875         policy: ::c_int,
3876         param: *const ::sched_param,
3877     ) -> ::c_int;
sendfile( out_fd: ::c_int, in_fd: ::c_int, offset: *mut ::off_t, count: ::size_t, ) -> ::ssize_t3878     pub fn sendfile(
3879         out_fd: ::c_int,
3880         in_fd: ::c_int,
3881         offset: *mut ::off_t,
3882         count: ::size_t,
3883     ) -> ::ssize_t;
sendfile64( out_fd: ::c_int, in_fd: ::c_int, offset: *mut ::off64_t, count: ::size_t, ) -> ::ssize_t3884     pub fn sendfile64(
3885         out_fd: ::c_int,
3886         in_fd: ::c_int,
3887         offset: *mut ::off64_t,
3888         count: ::size_t,
3889     ) -> ::ssize_t;
setfsgid(gid: ::gid_t) -> ::c_int3890     pub fn setfsgid(gid: ::gid_t) -> ::c_int;
setfsuid(uid: ::uid_t) -> ::c_int3891     pub fn setfsuid(uid: ::uid_t) -> ::c_int;
sigsuspend(mask: *const ::sigset_t) -> ::c_int3892     pub fn sigsuspend(mask: *const ::sigset_t) -> ::c_int;
getgrgid_r( gid: ::gid_t, grp: *mut ::group, buf: *mut ::c_char, buflen: ::size_t, result: *mut *mut ::group, ) -> ::c_int3893     pub fn getgrgid_r(
3894         gid: ::gid_t,
3895         grp: *mut ::group,
3896         buf: *mut ::c_char,
3897         buflen: ::size_t,
3898         result: *mut *mut ::group,
3899     ) -> ::c_int;
sigaltstack(ss: *const stack_t, oss: *mut stack_t) -> ::c_int3900     pub fn sigaltstack(ss: *const stack_t, oss: *mut stack_t) -> ::c_int;
sem_close(sem: *mut sem_t) -> ::c_int3901     pub fn sem_close(sem: *mut sem_t) -> ::c_int;
getgrnam_r( name: *const ::c_char, grp: *mut ::group, buf: *mut ::c_char, buflen: ::size_t, result: *mut *mut ::group, ) -> ::c_int3902     pub fn getgrnam_r(
3903         name: *const ::c_char,
3904         grp: *mut ::group,
3905         buf: *mut ::c_char,
3906         buflen: ::size_t,
3907         result: *mut *mut ::group,
3908     ) -> ::c_int;
pthread_sigmask(how: ::c_int, set: *const sigset_t, oldset: *mut sigset_t) -> ::c_int3909     pub fn pthread_sigmask(how: ::c_int, set: *const sigset_t, oldset: *mut sigset_t) -> ::c_int;
sem_open(name: *const ::c_char, oflag: ::c_int, ...) -> *mut sem_t3910     pub fn sem_open(name: *const ::c_char, oflag: ::c_int, ...) -> *mut sem_t;
getgrnam(name: *const ::c_char) -> *mut ::group3911     pub fn getgrnam(name: *const ::c_char) -> *mut ::group;
pthread_kill(thread: ::pthread_t, sig: ::c_int) -> ::c_int3912     pub fn pthread_kill(thread: ::pthread_t, sig: ::c_int) -> ::c_int;
sem_unlink(name: *const ::c_char) -> ::c_int3913     pub fn sem_unlink(name: *const ::c_char) -> ::c_int;
daemon(nochdir: ::c_int, noclose: ::c_int) -> ::c_int3914     pub fn daemon(nochdir: ::c_int, noclose: ::c_int) -> ::c_int;
getpwnam_r( name: *const ::c_char, pwd: *mut passwd, buf: *mut ::c_char, buflen: ::size_t, result: *mut *mut passwd, ) -> ::c_int3915     pub fn getpwnam_r(
3916         name: *const ::c_char,
3917         pwd: *mut passwd,
3918         buf: *mut ::c_char,
3919         buflen: ::size_t,
3920         result: *mut *mut passwd,
3921     ) -> ::c_int;
getpwuid_r( uid: ::uid_t, pwd: *mut passwd, buf: *mut ::c_char, buflen: ::size_t, result: *mut *mut passwd, ) -> ::c_int3922     pub fn getpwuid_r(
3923         uid: ::uid_t,
3924         pwd: *mut passwd,
3925         buf: *mut ::c_char,
3926         buflen: ::size_t,
3927         result: *mut *mut passwd,
3928     ) -> ::c_int;
sigtimedwait( set: *const sigset_t, info: *mut siginfo_t, timeout: *const ::timespec, ) -> ::c_int3929     pub fn sigtimedwait(
3930         set: *const sigset_t,
3931         info: *mut siginfo_t,
3932         timeout: *const ::timespec,
3933     ) -> ::c_int;
sigwait(set: *const sigset_t, sig: *mut ::c_int) -> ::c_int3934     pub fn sigwait(set: *const sigset_t, sig: *mut ::c_int) -> ::c_int;
pthread_atfork( prepare: ::Option<unsafe extern "C" fn()>, parent: ::Option<unsafe extern "C" fn()>, child: ::Option<unsafe extern "C" fn()>, ) -> ::c_int3935     pub fn pthread_atfork(
3936         prepare: ::Option<unsafe extern "C" fn()>,
3937         parent: ::Option<unsafe extern "C" fn()>,
3938         child: ::Option<unsafe extern "C" fn()>,
3939     ) -> ::c_int;
getgrgid(gid: ::gid_t) -> *mut ::group3940     pub fn getgrgid(gid: ::gid_t) -> *mut ::group;
getgrouplist( user: *const ::c_char, group: ::gid_t, groups: *mut ::gid_t, ngroups: *mut ::c_int, ) -> ::c_int3941     pub fn getgrouplist(
3942         user: *const ::c_char,
3943         group: ::gid_t,
3944         groups: *mut ::gid_t,
3945         ngroups: *mut ::c_int,
3946     ) -> ::c_int;
initgroups(user: *const ::c_char, group: ::gid_t) -> ::c_int3947     pub fn initgroups(user: *const ::c_char, group: ::gid_t) -> ::c_int;
pthread_mutexattr_getpshared( attr: *const pthread_mutexattr_t, pshared: *mut ::c_int, ) -> ::c_int3948     pub fn pthread_mutexattr_getpshared(
3949         attr: *const pthread_mutexattr_t,
3950         pshared: *mut ::c_int,
3951     ) -> ::c_int;
popen(command: *const c_char, mode: *const c_char) -> *mut ::FILE3952     pub fn popen(command: *const c_char, mode: *const c_char) -> *mut ::FILE;
faccessat( dirfd: ::c_int, pathname: *const ::c_char, mode: ::c_int, flags: ::c_int, ) -> ::c_int3953     pub fn faccessat(
3954         dirfd: ::c_int,
3955         pathname: *const ::c_char,
3956         mode: ::c_int,
3957         flags: ::c_int,
3958     ) -> ::c_int;
pthread_create( native: *mut ::pthread_t, attr: *const ::pthread_attr_t, f: extern "C" fn(*mut ::c_void) -> *mut ::c_void, value: *mut ::c_void, ) -> ::c_int3959     pub fn pthread_create(
3960         native: *mut ::pthread_t,
3961         attr: *const ::pthread_attr_t,
3962         f: extern "C" fn(*mut ::c_void) -> *mut ::c_void,
3963         value: *mut ::c_void,
3964     ) -> ::c_int;
__errno() -> *mut ::c_int3965     pub fn __errno() -> *mut ::c_int;
inotify_rm_watch(fd: ::c_int, wd: u32) -> ::c_int3966     pub fn inotify_rm_watch(fd: ::c_int, wd: u32) -> ::c_int;
sendmmsg( sockfd: ::c_int, msgvec: *const ::mmsghdr, vlen: ::c_uint, flags: ::c_int, ) -> ::c_int3967     pub fn sendmmsg(
3968         sockfd: ::c_int,
3969         msgvec: *const ::mmsghdr,
3970         vlen: ::c_uint,
3971         flags: ::c_int,
3972     ) -> ::c_int;
recvmmsg( sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::c_uint, flags: ::c_int, timeout: *const ::timespec, ) -> ::c_int3973     pub fn recvmmsg(
3974         sockfd: ::c_int,
3975         msgvec: *mut ::mmsghdr,
3976         vlen: ::c_uint,
3977         flags: ::c_int,
3978         timeout: *const ::timespec,
3979     ) -> ::c_int;
inotify_init() -> ::c_int3980     pub fn inotify_init() -> ::c_int;
inotify_init1(flags: ::c_int) -> ::c_int3981     pub fn inotify_init1(flags: ::c_int) -> ::c_int;
inotify_add_watch(fd: ::c_int, path: *const ::c_char, mask: u32) -> ::c_int3982     pub fn inotify_add_watch(fd: ::c_int, path: *const ::c_char, mask: u32) -> ::c_int;
3983 
regcomp(preg: *mut ::regex_t, pattern: *const ::c_char, cflags: ::c_int) -> ::c_int3984     pub fn regcomp(preg: *mut ::regex_t, pattern: *const ::c_char, cflags: ::c_int) -> ::c_int;
3985 
regexec( preg: *const ::regex_t, input: *const ::c_char, nmatch: ::size_t, pmatch: *mut regmatch_t, eflags: ::c_int, ) -> ::c_int3986     pub fn regexec(
3987         preg: *const ::regex_t,
3988         input: *const ::c_char,
3989         nmatch: ::size_t,
3990         pmatch: *mut regmatch_t,
3991         eflags: ::c_int,
3992     ) -> ::c_int;
3993 
regerror( errcode: ::c_int, preg: *const ::regex_t, errbuf: *mut ::c_char, errbuf_size: ::size_t, ) -> ::size_t3994     pub fn regerror(
3995         errcode: ::c_int,
3996         preg: *const ::regex_t,
3997         errbuf: *mut ::c_char,
3998         errbuf_size: ::size_t,
3999     ) -> ::size_t;
4000 
regfree(preg: *mut ::regex_t)4001     pub fn regfree(preg: *mut ::regex_t);
4002 
android_set_abort_message(msg: *const ::c_char)4003     pub fn android_set_abort_message(msg: *const ::c_char);
4004 
gettid() -> ::pid_t4005     pub fn gettid() -> ::pid_t;
4006 
4007     /// Only available in API Version 28+
getrandom(buf: *mut ::c_void, buflen: ::size_t, flags: ::c_uint) -> ::ssize_t4008     pub fn getrandom(buf: *mut ::c_void, buflen: ::size_t, flags: ::c_uint) -> ::ssize_t;
getentropy(buf: *mut ::c_void, buflen: ::size_t) -> ::c_int4009     pub fn getentropy(buf: *mut ::c_void, buflen: ::size_t) -> ::c_int;
4010 
pthread_setname_np(thread: ::pthread_t, name: *const ::c_char) -> ::c_int4011     pub fn pthread_setname_np(thread: ::pthread_t, name: *const ::c_char) -> ::c_int;
4012 
__system_property_set(__name: *const ::c_char, __value: *const ::c_char) -> ::c_int4013     pub fn __system_property_set(__name: *const ::c_char, __value: *const ::c_char) -> ::c_int;
__system_property_get(__name: *const ::c_char, __value: *mut ::c_char) -> ::c_int4014     pub fn __system_property_get(__name: *const ::c_char, __value: *mut ::c_char) -> ::c_int;
__system_property_find(__name: *const ::c_char) -> *const prop_info4015     pub fn __system_property_find(__name: *const ::c_char) -> *const prop_info;
__system_property_find_nth(__n: ::c_uint) -> *const prop_info4016     pub fn __system_property_find_nth(__n: ::c_uint) -> *const prop_info;
__system_property_foreach( __callback: unsafe extern "C" fn(__pi: *const prop_info, __cookie: *mut ::c_void), __cookie: *mut ::c_void, ) -> ::c_int4017     pub fn __system_property_foreach(
4018         __callback: unsafe extern "C" fn(__pi: *const prop_info, __cookie: *mut ::c_void),
4019         __cookie: *mut ::c_void,
4020     ) -> ::c_int;
4021 
4022     // #include <link.h>
4023     /// Only available in API Version 21+
dl_iterate_phdr( callback: ::Option< unsafe extern "C" fn( info: *mut dl_phdr_info, size: usize, data: *mut ::c_void, ) -> ::c_int, >, data: *mut ::c_void, ) -> ::c_int4024     pub fn dl_iterate_phdr(
4025         callback: ::Option<
4026             unsafe extern "C" fn(
4027                 info: *mut dl_phdr_info,
4028                 size: usize,
4029                 data: *mut ::c_void,
4030             ) -> ::c_int,
4031         >,
4032         data: *mut ::c_void,
4033     ) -> ::c_int;
4034 
arc4random() -> u324035     pub fn arc4random() -> u32;
arc4random_uniform(__upper_bound: u32) -> u324036     pub fn arc4random_uniform(__upper_bound: u32) -> u32;
arc4random_buf(__buf: *mut ::c_void, __n: ::size_t)4037     pub fn arc4random_buf(__buf: *mut ::c_void, __n: ::size_t);
4038 
reallocarray(ptr: *mut ::c_void, nmemb: ::size_t, size: ::size_t) -> *mut ::c_void4039     pub fn reallocarray(ptr: *mut ::c_void, nmemb: ::size_t, size: ::size_t) -> *mut ::c_void;
4040 
pthread_getcpuclockid(thread: ::pthread_t, clk_id: *mut ::clockid_t) -> ::c_int4041     pub fn pthread_getcpuclockid(thread: ::pthread_t, clk_id: *mut ::clockid_t) -> ::c_int;
4042 
dirname(path: *const ::c_char) -> *mut ::c_char4043     pub fn dirname(path: *const ::c_char) -> *mut ::c_char;
basename(path: *const ::c_char) -> *mut ::c_char4044     pub fn basename(path: *const ::c_char) -> *mut ::c_char;
getopt_long( argc: ::c_int, argv: *const *mut c_char, optstring: *const c_char, longopts: *const option, longindex: *mut ::c_int, ) -> ::c_int4045     pub fn getopt_long(
4046         argc: ::c_int,
4047         argv: *const *mut c_char,
4048         optstring: *const c_char,
4049         longopts: *const option,
4050         longindex: *mut ::c_int,
4051     ) -> ::c_int;
4052 
sync()4053     pub fn sync();
syncfs(fd: ::c_int) -> ::c_int4054     pub fn syncfs(fd: ::c_int) -> ::c_int;
4055 
memmem( haystack: *const ::c_void, haystacklen: ::size_t, needle: *const ::c_void, needlelen: ::size_t, ) -> *mut ::c_void4056     pub fn memmem(
4057         haystack: *const ::c_void,
4058         haystacklen: ::size_t,
4059         needle: *const ::c_void,
4060         needlelen: ::size_t,
4061     ) -> *mut ::c_void;
fread_unlocked( buf: *mut ::c_void, size: ::size_t, nobj: ::size_t, stream: *mut ::FILE, ) -> ::size_t4062     pub fn fread_unlocked(
4063         buf: *mut ::c_void,
4064         size: ::size_t,
4065         nobj: ::size_t,
4066         stream: *mut ::FILE,
4067     ) -> ::size_t;
fwrite_unlocked( buf: *const ::c_void, size: ::size_t, nobj: ::size_t, stream: *mut ::FILE, ) -> ::size_t4068     pub fn fwrite_unlocked(
4069         buf: *const ::c_void,
4070         size: ::size_t,
4071         nobj: ::size_t,
4072         stream: *mut ::FILE,
4073     ) -> ::size_t;
fflush_unlocked(stream: *mut ::FILE) -> ::c_int4074     pub fn fflush_unlocked(stream: *mut ::FILE) -> ::c_int;
fgets_unlocked(buf: *mut ::c_char, size: ::c_int, stream: *mut ::FILE) -> *mut ::c_char4075     pub fn fgets_unlocked(buf: *mut ::c_char, size: ::c_int, stream: *mut ::FILE) -> *mut ::c_char;
4076 }
4077 
4078 cfg_if! {
4079     if #[cfg(target_pointer_width = "32")] {
4080         mod b32;
4081         pub use self::b32::*;
4082     } else if #[cfg(target_pointer_width = "64")] {
4083         mod b64;
4084         pub use self::b64::*;
4085     } else {
4086         // Unknown target_pointer_width
4087     }
4088 }
4089 
4090 impl siginfo_t {
si_addr(&self) -> *mut ::c_void4091     pub unsafe fn si_addr(&self) -> *mut ::c_void {
4092         #[repr(C)]
4093         struct siginfo_sigfault {
4094             _si_signo: ::c_int,
4095             _si_errno: ::c_int,
4096             _si_code: ::c_int,
4097             si_addr: *mut ::c_void,
4098         }
4099         (*(self as *const siginfo_t as *const siginfo_sigfault)).si_addr
4100     }
4101 
si_value(&self) -> ::sigval4102     pub unsafe fn si_value(&self) -> ::sigval {
4103         #[repr(C)]
4104         struct siginfo_timer {
4105             _si_signo: ::c_int,
4106             _si_errno: ::c_int,
4107             _si_code: ::c_int,
4108             _si_tid: ::c_int,
4109             _si_overrun: ::c_int,
4110             si_sigval: ::sigval,
4111         }
4112         (*(self as *const siginfo_t as *const siginfo_timer)).si_sigval
4113     }
4114 }
4115 
4116 cfg_if! {
4117     if #[cfg(libc_union)] {
4118         // Internal, for casts to access union fields
4119         #[repr(C)]
4120         struct sifields_sigchld {
4121             si_pid: ::pid_t,
4122             si_uid: ::uid_t,
4123             si_status: ::c_int,
4124             si_utime: ::c_long,
4125             si_stime: ::c_long,
4126         }
4127         impl ::Copy for sifields_sigchld {}
4128         impl ::Clone for sifields_sigchld {
4129             fn clone(&self) -> sifields_sigchld {
4130                 *self
4131             }
4132         }
4133 
4134         // Internal, for casts to access union fields
4135         #[repr(C)]
4136         union sifields {
4137             _align_pointer: *mut ::c_void,
4138             sigchld: sifields_sigchld,
4139         }
4140 
4141         // Internal, for casts to access union fields. Note that some variants
4142         // of sifields start with a pointer, which makes the alignment of
4143         // sifields vary on 32-bit and 64-bit architectures.
4144         #[repr(C)]
4145         struct siginfo_f {
4146             _siginfo_base: [::c_int; 3],
4147             sifields: sifields,
4148         }
4149 
4150         impl siginfo_t {
4151             unsafe fn sifields(&self) -> &sifields {
4152                 &(*(self as *const siginfo_t as *const siginfo_f)).sifields
4153             }
4154 
4155             pub unsafe fn si_pid(&self) -> ::pid_t {
4156                 self.sifields().sigchld.si_pid
4157             }
4158 
4159             pub unsafe fn si_uid(&self) -> ::uid_t {
4160                 self.sifields().sigchld.si_uid
4161             }
4162 
4163             pub unsafe fn si_status(&self) -> ::c_int {
4164                 self.sifields().sigchld.si_status
4165             }
4166 
4167             pub unsafe fn si_utime(&self) -> ::c_long {
4168                 self.sifields().sigchld.si_utime
4169             }
4170 
4171             pub unsafe fn si_stime(&self) -> ::c_long {
4172                 self.sifields().sigchld.si_stime
4173             }
4174         }
4175     }
4176 }
4177