xref: /rust-libc-0.2.174/src/fuchsia/mod.rs (revision a64612fc)
1 //! Definitions found commonly among almost all Unix derivatives
2 //!
3 //! More functions and definitions can be found in the more specific modules
4 //! according to the platform in question.
5 
6 use crate::prelude::*;
7 
8 // PUB_TYPE
9 
10 pub type intmax_t = i64;
11 pub type uintmax_t = u64;
12 
13 pub type locale_t = *mut c_void;
14 
15 pub type size_t = usize;
16 pub type ptrdiff_t = isize;
17 pub type intptr_t = isize;
18 pub type uintptr_t = usize;
19 pub type ssize_t = isize;
20 
21 pub type pid_t = i32;
22 pub type uid_t = u32;
23 pub type gid_t = u32;
24 pub type in_addr_t = u32;
25 pub type in_port_t = u16;
26 pub type sighandler_t = size_t;
27 pub type cc_t = c_uchar;
28 pub type sa_family_t = u16;
29 pub type pthread_key_t = c_uint;
30 pub type speed_t = c_uint;
31 pub type tcflag_t = c_uint;
32 pub type clockid_t = c_int;
33 pub type key_t = c_int;
34 pub type id_t = c_uint;
35 pub type useconds_t = u32;
36 pub type dev_t = u64;
37 pub type socklen_t = u32;
38 pub type pthread_t = c_ulong;
39 pub type mode_t = u32;
40 pub type ino64_t = u64;
41 pub type off64_t = i64;
42 pub type blkcnt64_t = i64;
43 pub type rlim64_t = u64;
44 pub type mqd_t = c_int;
45 pub type nfds_t = c_ulong;
46 pub type nl_item = c_int;
47 pub type idtype_t = c_uint;
48 pub type loff_t = c_longlong;
49 
50 pub type __u8 = c_uchar;
51 pub type __u16 = c_ushort;
52 pub type __s16 = c_short;
53 pub type __u32 = c_uint;
54 pub type __s32 = c_int;
55 
56 pub type Elf32_Half = u16;
57 pub type Elf32_Word = u32;
58 pub type Elf32_Off = u32;
59 pub type Elf32_Addr = u32;
60 
61 pub type Elf64_Half = u16;
62 pub type Elf64_Word = u32;
63 pub type Elf64_Off = u64;
64 pub type Elf64_Addr = u64;
65 pub type Elf64_Xword = u64;
66 
67 pub type clock_t = c_long;
68 pub type time_t = c_long;
69 pub type suseconds_t = c_long;
70 pub type ino_t = u64;
71 pub type off_t = i64;
72 pub type blkcnt_t = i64;
73 
74 pub type shmatt_t = c_ulong;
75 pub type msgqnum_t = c_ulong;
76 pub type msglen_t = c_ulong;
77 pub type fsblkcnt_t = c_ulonglong;
78 pub type fsfilcnt_t = c_ulonglong;
79 pub type rlim_t = c_ulonglong;
80 
81 // FIXME(fuchsia): why are these uninhabited types? that seems... wrong?
82 // Presumably these should be `()` or an `extern type` (when that stabilizes).
83 #[cfg_attr(feature = "extra_traits", derive(Debug))]
84 pub enum timezone {}
85 impl Copy for timezone {}
86 impl Clone for timezone {
87     fn clone(&self) -> timezone {
88         *self
89     }
90 }
91 #[cfg_attr(feature = "extra_traits", derive(Debug))]
92 pub enum DIR {}
93 impl Copy for DIR {}
94 impl Clone for DIR {
95     fn clone(&self) -> DIR {
96         *self
97     }
98 }
99 
100 #[cfg_attr(feature = "extra_traits", derive(Debug))]
101 pub enum fpos64_t {} // FIXME(fuchsia): fill this out with a struct
102 impl Copy for fpos64_t {}
103 impl Clone for fpos64_t {
104     fn clone(&self) -> fpos64_t {
105         *self
106     }
107 }
108 
109 // PUB_STRUCT
110 
111 s! {
112     pub struct group {
113         pub gr_name: *mut c_char,
114         pub gr_passwd: *mut c_char,
115         pub gr_gid: crate::gid_t,
116         pub gr_mem: *mut *mut c_char,
117     }
118 
119     pub struct utimbuf {
120         pub actime: time_t,
121         pub modtime: time_t,
122     }
123 
124     pub struct timeval {
125         pub tv_sec: time_t,
126         pub tv_usec: suseconds_t,
127     }
128 
129     pub struct timespec {
130         pub tv_sec: time_t,
131         pub tv_nsec: c_long,
132     }
133 
134     // FIXME(fuchsia): the rlimit and rusage related functions and types don't exist
135     // within zircon. Are there reasons for keeping them around?
136     pub struct rlimit {
137         pub rlim_cur: rlim_t,
138         pub rlim_max: rlim_t,
139     }
140 
141     pub struct rusage {
142         pub ru_utime: timeval,
143         pub ru_stime: timeval,
144         pub ru_maxrss: c_long,
145         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
146         __pad1: u32,
147         pub ru_ixrss: c_long,
148         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
149         __pad2: u32,
150         pub ru_idrss: c_long,
151         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
152         __pad3: u32,
153         pub ru_isrss: c_long,
154         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
155         __pad4: u32,
156         pub ru_minflt: c_long,
157         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
158         __pad5: u32,
159         pub ru_majflt: c_long,
160         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
161         __pad6: u32,
162         pub ru_nswap: c_long,
163         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
164         __pad7: u32,
165         pub ru_inblock: c_long,
166         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
167         __pad8: u32,
168         pub ru_oublock: c_long,
169         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
170         __pad9: u32,
171         pub ru_msgsnd: c_long,
172         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
173         __pad10: u32,
174         pub ru_msgrcv: c_long,
175         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
176         __pad11: u32,
177         pub ru_nsignals: c_long,
178         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
179         __pad12: u32,
180         pub ru_nvcsw: c_long,
181         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
182         __pad13: u32,
183         pub ru_nivcsw: c_long,
184         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
185         __pad14: u32,
186     }
187 
188     pub struct in_addr {
189         pub s_addr: in_addr_t,
190     }
191 
192     pub struct in6_addr {
193         pub s6_addr: [u8; 16],
194     }
195 
196     pub struct ip_mreq {
197         pub imr_multiaddr: in_addr,
198         pub imr_interface: in_addr,
199     }
200 
201     pub struct ip_mreqn {
202         pub imr_multiaddr: in_addr,
203         pub imr_address: in_addr,
204         pub imr_ifindex: c_int,
205     }
206 
207     pub struct ipv6_mreq {
208         pub ipv6mr_multiaddr: in6_addr,
209         pub ipv6mr_interface: c_uint,
210     }
211 
212     pub struct hostent {
213         pub h_name: *mut c_char,
214         pub h_aliases: *mut *mut c_char,
215         pub h_addrtype: c_int,
216         pub h_length: c_int,
217         pub h_addr_list: *mut *mut c_char,
218     }
219 
220     pub struct iovec {
221         pub iov_base: *mut c_void,
222         pub iov_len: size_t,
223     }
224 
225     pub struct pollfd {
226         pub fd: c_int,
227         pub events: c_short,
228         pub revents: c_short,
229     }
230 
231     pub struct winsize {
232         pub ws_row: c_ushort,
233         pub ws_col: c_ushort,
234         pub ws_xpixel: c_ushort,
235         pub ws_ypixel: c_ushort,
236     }
237 
238     pub struct linger {
239         pub l_onoff: c_int,
240         pub l_linger: c_int,
241     }
242 
243     pub struct sigval {
244         // Actually a union of an int and a void*
245         pub sival_ptr: *mut c_void,
246     }
247 
248     // <sys/time.h>
249     pub struct itimerval {
250         pub it_interval: crate::timeval,
251         pub it_value: crate::timeval,
252     }
253 
254     // <sys/times.h>
255     pub struct tms {
256         pub tms_utime: crate::clock_t,
257         pub tms_stime: crate::clock_t,
258         pub tms_cutime: crate::clock_t,
259         pub tms_cstime: crate::clock_t,
260     }
261 
262     pub struct servent {
263         pub s_name: *mut c_char,
264         pub s_aliases: *mut *mut c_char,
265         pub s_port: c_int,
266         pub s_proto: *mut c_char,
267     }
268 
269     pub struct protoent {
270         pub p_name: *mut c_char,
271         pub p_aliases: *mut *mut c_char,
272         pub p_proto: c_int,
273     }
274 
275     pub struct aiocb {
276         pub aio_fildes: c_int,
277         pub aio_lio_opcode: c_int,
278         pub aio_reqprio: c_int,
279         pub aio_buf: *mut c_void,
280         pub aio_nbytes: size_t,
281         pub aio_sigevent: crate::sigevent,
282         __td: *mut c_void,
283         __lock: [c_int; 2],
284         __err: c_int,
285         __ret: ssize_t,
286         pub aio_offset: off_t,
287         __next: *mut c_void,
288         __prev: *mut c_void,
289         #[cfg(target_pointer_width = "32")]
290         __dummy4: [c_char; 24],
291         #[cfg(target_pointer_width = "64")]
292         __dummy4: [c_char; 16],
293     }
294 
295     pub struct sigaction {
296         pub sa_sigaction: crate::sighandler_t,
297         pub sa_mask: crate::sigset_t,
298         pub sa_flags: c_int,
299         pub sa_restorer: Option<extern "C" fn()>,
300     }
301 
302     pub struct termios {
303         pub c_iflag: crate::tcflag_t,
304         pub c_oflag: crate::tcflag_t,
305         pub c_cflag: crate::tcflag_t,
306         pub c_lflag: crate::tcflag_t,
307         pub c_line: crate::cc_t,
308         pub c_cc: [crate::cc_t; crate::NCCS],
309         pub __c_ispeed: crate::speed_t,
310         pub __c_ospeed: crate::speed_t,
311     }
312 
313     pub struct flock {
314         pub l_type: c_short,
315         pub l_whence: c_short,
316         pub l_start: off_t,
317         pub l_len: off_t,
318         pub l_pid: crate::pid_t,
319     }
320 
321     pub struct ucred {
322         pub pid: crate::pid_t,
323         pub uid: crate::uid_t,
324         pub gid: crate::gid_t,
325     }
326 
327     pub struct sockaddr {
328         pub sa_family: sa_family_t,
329         pub sa_data: [c_char; 14],
330     }
331 
332     pub struct sockaddr_in {
333         pub sin_family: sa_family_t,
334         pub sin_port: crate::in_port_t,
335         pub sin_addr: crate::in_addr,
336         pub sin_zero: [u8; 8],
337     }
338 
339     pub struct sockaddr_in6 {
340         pub sin6_family: sa_family_t,
341         pub sin6_port: crate::in_port_t,
342         pub sin6_flowinfo: u32,
343         pub sin6_addr: crate::in6_addr,
344         pub sin6_scope_id: u32,
345     }
346 
347     pub struct sockaddr_vm {
348         pub svm_family: sa_family_t,
349         pub svm_reserved1: c_ushort,
350         pub svm_port: crate::in_port_t,
351         pub svm_cid: c_uint,
352         pub svm_zero: [u8; 4],
353     }
354 
355     pub struct addrinfo {
356         pub ai_flags: c_int,
357         pub ai_family: c_int,
358         pub ai_socktype: c_int,
359         pub ai_protocol: c_int,
360         pub ai_addrlen: socklen_t,
361 
362         pub ai_addr: *mut crate::sockaddr,
363 
364         pub ai_canonname: *mut c_char,
365 
366         pub ai_next: *mut addrinfo,
367     }
368 
369     pub struct sockaddr_ll {
370         pub sll_family: c_ushort,
371         pub sll_protocol: c_ushort,
372         pub sll_ifindex: c_int,
373         pub sll_hatype: c_ushort,
374         pub sll_pkttype: c_uchar,
375         pub sll_halen: c_uchar,
376         pub sll_addr: [c_uchar; 8],
377     }
378 
379     pub struct fd_set {
380         fds_bits: [c_ulong; FD_SETSIZE as usize / ULONG_SIZE],
381     }
382 
383     pub struct tm {
384         pub tm_sec: c_int,
385         pub tm_min: c_int,
386         pub tm_hour: c_int,
387         pub tm_mday: c_int,
388         pub tm_mon: c_int,
389         pub tm_year: c_int,
390         pub tm_wday: c_int,
391         pub tm_yday: c_int,
392         pub tm_isdst: c_int,
393         pub tm_gmtoff: c_long,
394         pub tm_zone: *const c_char,
395     }
396 
397     pub struct sched_param {
398         pub sched_priority: c_int,
399         pub sched_ss_low_priority: c_int,
400         pub sched_ss_repl_period: crate::timespec,
401         pub sched_ss_init_budget: crate::timespec,
402         pub sched_ss_max_repl: c_int,
403     }
404 
405     pub struct Dl_info {
406         pub dli_fname: *const c_char,
407         pub dli_fbase: *mut c_void,
408         pub dli_sname: *const c_char,
409         pub dli_saddr: *mut c_void,
410     }
411 
412     pub struct epoll_event {
413         pub events: u32,
414         pub u64: u64,
415     }
416 
417     pub struct lconv {
418         pub decimal_point: *mut c_char,
419         pub thousands_sep: *mut c_char,
420         pub grouping: *mut c_char,
421         pub int_curr_symbol: *mut c_char,
422         pub currency_symbol: *mut c_char,
423         pub mon_decimal_point: *mut c_char,
424         pub mon_thousands_sep: *mut c_char,
425         pub mon_grouping: *mut c_char,
426         pub positive_sign: *mut c_char,
427         pub negative_sign: *mut c_char,
428         pub int_frac_digits: c_char,
429         pub frac_digits: c_char,
430         pub p_cs_precedes: c_char,
431         pub p_sep_by_space: c_char,
432         pub n_cs_precedes: c_char,
433         pub n_sep_by_space: c_char,
434         pub p_sign_posn: c_char,
435         pub n_sign_posn: c_char,
436         pub int_p_cs_precedes: c_char,
437         pub int_p_sep_by_space: c_char,
438         pub int_n_cs_precedes: c_char,
439         pub int_n_sep_by_space: c_char,
440         pub int_p_sign_posn: c_char,
441         pub int_n_sign_posn: c_char,
442     }
443 
444     pub struct rlimit64 {
445         pub rlim_cur: rlim64_t,
446         pub rlim_max: rlim64_t,
447     }
448 
449     pub struct glob_t {
450         pub gl_pathc: size_t,
451         pub gl_pathv: *mut *mut c_char,
452         pub gl_offs: size_t,
453         pub gl_flags: c_int,
454 
455         __unused1: *mut c_void,
456         __unused2: *mut c_void,
457         __unused3: *mut c_void,
458         __unused4: *mut c_void,
459         __unused5: *mut c_void,
460     }
461 
462     pub struct ifaddrs {
463         pub ifa_next: *mut ifaddrs,
464         pub ifa_name: *mut c_char,
465         pub ifa_flags: c_uint,
466         pub ifa_addr: *mut crate::sockaddr,
467         pub ifa_netmask: *mut crate::sockaddr,
468         pub ifa_ifu: *mut crate::sockaddr, // FIXME(union) This should be a union
469         pub ifa_data: *mut c_void,
470     }
471 
472     pub struct passwd {
473         pub pw_name: *mut c_char,
474         pub pw_passwd: *mut c_char,
475         pub pw_uid: crate::uid_t,
476         pub pw_gid: crate::gid_t,
477         pub pw_gecos: *mut c_char,
478         pub pw_dir: *mut c_char,
479         pub pw_shell: *mut c_char,
480     }
481 
482     pub struct spwd {
483         pub sp_namp: *mut c_char,
484         pub sp_pwdp: *mut c_char,
485         pub sp_lstchg: c_long,
486         pub sp_min: c_long,
487         pub sp_max: c_long,
488         pub sp_warn: c_long,
489         pub sp_inact: c_long,
490         pub sp_expire: c_long,
491         pub sp_flag: c_ulong,
492     }
493 
494     pub struct statvfs {
495         pub f_bsize: c_ulong,
496         pub f_frsize: c_ulong,
497         pub f_blocks: crate::fsblkcnt_t,
498         pub f_bfree: crate::fsblkcnt_t,
499         pub f_bavail: crate::fsblkcnt_t,
500         pub f_files: crate::fsfilcnt_t,
501         pub f_ffree: crate::fsfilcnt_t,
502         pub f_favail: crate::fsfilcnt_t,
503         #[cfg(target_endian = "little")]
504         pub f_fsid: c_ulong,
505         #[cfg(all(target_pointer_width = "32", not(target_arch = "x86_64")))]
506         __f_unused: c_int,
507         #[cfg(target_endian = "big")]
508         pub f_fsid: c_ulong,
509         pub f_flag: c_ulong,
510         pub f_namemax: c_ulong,
511         __f_spare: [c_int; 6],
512     }
513 
514     pub struct dqblk {
515         pub dqb_bhardlimit: u64,
516         pub dqb_bsoftlimit: u64,
517         pub dqb_curspace: u64,
518         pub dqb_ihardlimit: u64,
519         pub dqb_isoftlimit: u64,
520         pub dqb_curinodes: u64,
521         pub dqb_btime: u64,
522         pub dqb_itime: u64,
523         pub dqb_valid: u32,
524     }
525 
526     pub struct signalfd_siginfo {
527         pub ssi_signo: u32,
528         pub ssi_errno: i32,
529         pub ssi_code: i32,
530         pub ssi_pid: u32,
531         pub ssi_uid: u32,
532         pub ssi_fd: i32,
533         pub ssi_tid: u32,
534         pub ssi_band: u32,
535         pub ssi_overrun: u32,
536         pub ssi_trapno: u32,
537         pub ssi_status: i32,
538         pub ssi_int: i32,
539         pub ssi_ptr: u64,
540         pub ssi_utime: u64,
541         pub ssi_stime: u64,
542         pub ssi_addr: u64,
543         pub ssi_addr_lsb: u16,
544         _pad2: u16,
545         pub ssi_syscall: i32,
546         pub ssi_call_addr: u64,
547         pub ssi_arch: u32,
548         _pad: [u8; 28],
549     }
550 
551     pub struct itimerspec {
552         pub it_interval: crate::timespec,
553         pub it_value: crate::timespec,
554     }
555 
556     pub struct fsid_t {
557         __val: [c_int; 2],
558     }
559 
560     pub struct cpu_set_t {
561         #[cfg(all(target_pointer_width = "32", not(target_arch = "x86_64")))]
562         bits: [u32; 32],
563         #[cfg(not(all(target_pointer_width = "32", not(target_arch = "x86_64"))))]
564         bits: [u64; 16],
565     }
566 
567     pub struct if_nameindex {
568         pub if_index: c_uint,
569         pub if_name: *mut c_char,
570     }
571 
572     // System V IPC
573     pub struct msginfo {
574         pub msgpool: c_int,
575         pub msgmap: c_int,
576         pub msgmax: c_int,
577         pub msgmnb: c_int,
578         pub msgmni: c_int,
579         pub msgssz: c_int,
580         pub msgtql: c_int,
581         pub msgseg: c_ushort,
582     }
583 
584     pub struct mmsghdr {
585         pub msg_hdr: crate::msghdr,
586         pub msg_len: c_uint,
587     }
588 
589     pub struct sembuf {
590         pub sem_num: c_ushort,
591         pub sem_op: c_short,
592         pub sem_flg: c_short,
593     }
594 
595     pub struct input_event {
596         pub time: crate::timeval,
597         pub type_: crate::__u16,
598         pub code: crate::__u16,
599         pub value: crate::__s32,
600     }
601 
602     pub struct input_id {
603         pub bustype: crate::__u16,
604         pub vendor: crate::__u16,
605         pub product: crate::__u16,
606         pub version: crate::__u16,
607     }
608 
609     pub struct input_absinfo {
610         pub value: crate::__s32,
611         pub minimum: crate::__s32,
612         pub maximum: crate::__s32,
613         pub fuzz: crate::__s32,
614         pub flat: crate::__s32,
615         pub resolution: crate::__s32,
616     }
617 
618     pub struct input_keymap_entry {
619         pub flags: crate::__u8,
620         pub len: crate::__u8,
621         pub index: crate::__u16,
622         pub keycode: crate::__u32,
623         pub scancode: [crate::__u8; 32],
624     }
625 
626     pub struct input_mask {
627         pub type_: crate::__u32,
628         pub codes_size: crate::__u32,
629         pub codes_ptr: crate::__u64,
630     }
631 
632     pub struct ff_replay {
633         pub length: crate::__u16,
634         pub delay: crate::__u16,
635     }
636 
637     pub struct ff_trigger {
638         pub button: crate::__u16,
639         pub interval: crate::__u16,
640     }
641 
642     pub struct ff_envelope {
643         pub attack_length: crate::__u16,
644         pub attack_level: crate::__u16,
645         pub fade_length: crate::__u16,
646         pub fade_level: crate::__u16,
647     }
648 
649     pub struct ff_constant_effect {
650         pub level: crate::__s16,
651         pub envelope: ff_envelope,
652     }
653 
654     pub struct ff_ramp_effect {
655         pub start_level: crate::__s16,
656         pub end_level: crate::__s16,
657         pub envelope: ff_envelope,
658     }
659 
660     pub struct ff_condition_effect {
661         pub right_saturation: crate::__u16,
662         pub left_saturation: crate::__u16,
663 
664         pub right_coeff: crate::__s16,
665         pub left_coeff: crate::__s16,
666 
667         pub deadband: crate::__u16,
668         pub center: crate::__s16,
669     }
670 
671     pub struct ff_periodic_effect {
672         pub waveform: crate::__u16,
673         pub period: crate::__u16,
674         pub magnitude: crate::__s16,
675         pub offset: crate::__s16,
676         pub phase: crate::__u16,
677 
678         pub envelope: ff_envelope,
679 
680         pub custom_len: crate::__u32,
681         pub custom_data: *mut crate::__s16,
682     }
683 
684     pub struct ff_rumble_effect {
685         pub strong_magnitude: crate::__u16,
686         pub weak_magnitude: crate::__u16,
687     }
688 
689     pub struct ff_effect {
690         pub type_: crate::__u16,
691         pub id: crate::__s16,
692         pub direction: crate::__u16,
693         pub trigger: ff_trigger,
694         pub replay: ff_replay,
695         // FIXME(1.0): this is actually a union
696         #[cfg(target_pointer_width = "64")]
697         pub u: [u64; 4],
698         #[cfg(target_pointer_width = "32")]
699         pub u: [u32; 7],
700     }
701 
702     pub struct dl_phdr_info {
703         #[cfg(target_pointer_width = "64")]
704         pub dlpi_addr: Elf64_Addr,
705         #[cfg(target_pointer_width = "32")]
706         pub dlpi_addr: Elf32_Addr,
707 
708         pub dlpi_name: *const c_char,
709 
710         #[cfg(target_pointer_width = "64")]
711         pub dlpi_phdr: *const Elf64_Phdr,
712         #[cfg(target_pointer_width = "32")]
713         pub dlpi_phdr: *const Elf32_Phdr,
714 
715         #[cfg(target_pointer_width = "64")]
716         pub dlpi_phnum: Elf64_Half,
717         #[cfg(target_pointer_width = "32")]
718         pub dlpi_phnum: Elf32_Half,
719 
720         pub dlpi_adds: c_ulonglong,
721         pub dlpi_subs: c_ulonglong,
722         pub dlpi_tls_modid: size_t,
723         pub dlpi_tls_data: *mut c_void,
724     }
725 
726     pub struct Elf32_Phdr {
727         pub p_type: Elf32_Word,
728         pub p_offset: Elf32_Off,
729         pub p_vaddr: Elf32_Addr,
730         pub p_paddr: Elf32_Addr,
731         pub p_filesz: Elf32_Word,
732         pub p_memsz: Elf32_Word,
733         pub p_flags: Elf32_Word,
734         pub p_align: Elf32_Word,
735     }
736 
737     pub struct Elf64_Phdr {
738         pub p_type: Elf64_Word,
739         pub p_flags: Elf64_Word,
740         pub p_offset: Elf64_Off,
741         pub p_vaddr: Elf64_Addr,
742         pub p_paddr: Elf64_Addr,
743         pub p_filesz: Elf64_Xword,
744         pub p_memsz: Elf64_Xword,
745         pub p_align: Elf64_Xword,
746     }
747 
748     pub struct statfs64 {
749         pub f_type: c_ulong,
750         pub f_bsize: c_ulong,
751         pub f_blocks: crate::fsblkcnt_t,
752         pub f_bfree: crate::fsblkcnt_t,
753         pub f_bavail: crate::fsblkcnt_t,
754         pub f_files: crate::fsfilcnt_t,
755         pub f_ffree: crate::fsfilcnt_t,
756         pub f_fsid: crate::fsid_t,
757         pub f_namelen: c_ulong,
758         pub f_frsize: c_ulong,
759         pub f_flags: c_ulong,
760         pub f_spare: [c_ulong; 4],
761     }
762 
763     pub struct statvfs64 {
764         pub f_bsize: c_ulong,
765         pub f_frsize: c_ulong,
766         pub f_blocks: u64,
767         pub f_bfree: u64,
768         pub f_bavail: u64,
769         pub f_files: u64,
770         pub f_ffree: u64,
771         pub f_favail: u64,
772         pub f_fsid: c_ulong,
773         pub f_flag: c_ulong,
774         pub f_namemax: c_ulong,
775         __f_spare: [c_int; 6],
776     }
777 
778     pub struct stack_t {
779         pub ss_sp: *mut c_void,
780         pub ss_flags: c_int,
781         pub ss_size: size_t,
782     }
783 
784     pub struct pthread_attr_t {
785         __size: [u64; 7],
786     }
787 
788     pub struct sigset_t {
789         __val: [c_ulong; 16],
790     }
791 
792     pub struct shmid_ds {
793         pub shm_perm: crate::ipc_perm,
794         pub shm_segsz: size_t,
795         pub shm_atime: crate::time_t,
796         pub shm_dtime: crate::time_t,
797         pub shm_ctime: crate::time_t,
798         pub shm_cpid: crate::pid_t,
799         pub shm_lpid: crate::pid_t,
800         pub shm_nattch: c_ulong,
801         __pad1: c_ulong,
802         __pad2: c_ulong,
803     }
804 
805     pub struct msqid_ds {
806         pub msg_perm: crate::ipc_perm,
807         pub msg_stime: crate::time_t,
808         pub msg_rtime: crate::time_t,
809         pub msg_ctime: crate::time_t,
810         pub __msg_cbytes: c_ulong,
811         pub msg_qnum: crate::msgqnum_t,
812         pub msg_qbytes: crate::msglen_t,
813         pub msg_lspid: crate::pid_t,
814         pub msg_lrpid: crate::pid_t,
815         __pad1: c_ulong,
816         __pad2: c_ulong,
817     }
818 
819     pub struct statfs {
820         pub f_type: c_ulong,
821         pub f_bsize: c_ulong,
822         pub f_blocks: crate::fsblkcnt_t,
823         pub f_bfree: crate::fsblkcnt_t,
824         pub f_bavail: crate::fsblkcnt_t,
825         pub f_files: crate::fsfilcnt_t,
826         pub f_ffree: crate::fsfilcnt_t,
827         pub f_fsid: crate::fsid_t,
828         pub f_namelen: c_ulong,
829         pub f_frsize: c_ulong,
830         pub f_flags: c_ulong,
831         pub f_spare: [c_ulong; 4],
832     }
833 
834     pub struct msghdr {
835         pub msg_name: *mut c_void,
836         pub msg_namelen: crate::socklen_t,
837         pub msg_iov: *mut crate::iovec,
838         pub msg_iovlen: c_int,
839         __pad1: c_int,
840         pub msg_control: *mut c_void,
841         pub msg_controllen: crate::socklen_t,
842         __pad2: crate::socklen_t,
843         pub msg_flags: c_int,
844     }
845 
846     pub struct cmsghdr {
847         pub cmsg_len: crate::socklen_t,
848         pub __pad1: c_int,
849         pub cmsg_level: c_int,
850         pub cmsg_type: c_int,
851     }
852 
853     pub struct sem_t {
854         __val: [c_int; 8],
855     }
856 
857     pub struct siginfo_t {
858         pub si_signo: c_int,
859         pub si_errno: c_int,
860         pub si_code: c_int,
861         pub _pad: [c_int; 29],
862         _align: [usize; 0],
863     }
864 
865     pub struct termios2 {
866         pub c_iflag: crate::tcflag_t,
867         pub c_oflag: crate::tcflag_t,
868         pub c_cflag: crate::tcflag_t,
869         pub c_lflag: crate::tcflag_t,
870         pub c_line: crate::cc_t,
871         pub c_cc: [crate::cc_t; 19],
872         pub c_ispeed: crate::speed_t,
873         pub c_ospeed: crate::speed_t,
874     }
875 
876     pub struct in6_pktinfo {
877         pub ipi6_addr: crate::in6_addr,
878         pub ipi6_ifindex: c_uint,
879     }
880 
881     #[cfg_attr(
882         any(target_pointer_width = "32", target_arch = "x86_64"),
883         repr(align(4))
884     )]
885     #[cfg_attr(
886         not(any(target_pointer_width = "32", target_arch = "x86_64")),
887         repr(align(8))
888     )]
889     pub struct pthread_mutexattr_t {
890         size: [u8; crate::__SIZEOF_PTHREAD_MUTEXATTR_T],
891     }
892 
893     #[cfg_attr(target_pointer_width = "32", repr(align(4)))]
894     #[cfg_attr(target_pointer_width = "64", repr(align(8)))]
895     pub struct pthread_rwlockattr_t {
896         size: [u8; crate::__SIZEOF_PTHREAD_RWLOCKATTR_T],
897     }
898 
899     #[repr(align(4))]
900     pub struct pthread_condattr_t {
901         size: [u8; crate::__SIZEOF_PTHREAD_CONDATTR_T],
902     }
903 }
904 
905 s_no_extra_traits! {
906     pub struct sysinfo {
907         pub uptime: c_ulong,
908         pub loads: [c_ulong; 3],
909         pub totalram: c_ulong,
910         pub freeram: c_ulong,
911         pub sharedram: c_ulong,
912         pub bufferram: c_ulong,
913         pub totalswap: c_ulong,
914         pub freeswap: c_ulong,
915         pub procs: c_ushort,
916         pub pad: c_ushort,
917         pub totalhigh: c_ulong,
918         pub freehigh: c_ulong,
919         pub mem_unit: c_uint,
920         pub __reserved: [c_char; 256],
921     }
922 
923     pub struct sockaddr_un {
924         pub sun_family: sa_family_t,
925         pub sun_path: [c_char; 108],
926     }
927 
928     pub struct sockaddr_storage {
929         pub ss_family: sa_family_t,
930         __ss_pad2: [u8; 128 - 2 - 8],
931         __ss_align: size_t,
932     }
933 
934     pub struct utsname {
935         pub sysname: [c_char; 65],
936         pub nodename: [c_char; 65],
937         pub release: [c_char; 65],
938         pub version: [c_char; 65],
939         pub machine: [c_char; 65],
940         pub domainname: [c_char; 65],
941     }
942 
943     pub struct dirent {
944         pub d_ino: crate::ino_t,
945         pub d_off: off_t,
946         pub d_reclen: c_ushort,
947         pub d_type: c_uchar,
948         pub d_name: [c_char; 256],
949     }
950 
951     pub struct dirent64 {
952         pub d_ino: crate::ino64_t,
953         pub d_off: off64_t,
954         pub d_reclen: c_ushort,
955         pub d_type: c_uchar,
956         pub d_name: [c_char; 256],
957     }
958 
959     // x32 compatibility
960     // See https://sourceware.org/bugzilla/show_bug.cgi?id=21279
961     pub struct mq_attr {
962         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
963         pub mq_flags: i64,
964         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
965         pub mq_maxmsg: i64,
966         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
967         pub mq_msgsize: i64,
968         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
969         pub mq_curmsgs: i64,
970         #[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
971         pad: [i64; 4],
972 
973         #[cfg(not(all(target_arch = "x86_64", target_pointer_width = "32")))]
974         pub mq_flags: c_long,
975         #[cfg(not(all(target_arch = "x86_64", target_pointer_width = "32")))]
976         pub mq_maxmsg: c_long,
977         #[cfg(not(all(target_arch = "x86_64", target_pointer_width = "32")))]
978         pub mq_msgsize: c_long,
979         #[cfg(not(all(target_arch = "x86_64", target_pointer_width = "32")))]
980         pub mq_curmsgs: c_long,
981         #[cfg(not(all(target_arch = "x86_64", target_pointer_width = "32")))]
982         pad: [c_long; 4],
983     }
984 
985     pub struct sockaddr_nl {
986         pub nl_family: crate::sa_family_t,
987         nl_pad: c_ushort,
988         pub nl_pid: u32,
989         pub nl_groups: u32,
990     }
991 
992     pub struct sigevent {
993         pub sigev_value: crate::sigval,
994         pub sigev_signo: c_int,
995         pub sigev_notify: c_int,
996         pub sigev_notify_function: fn(crate::sigval),
997         pub sigev_notify_attributes: *mut pthread_attr_t,
998         pub __pad: [c_char; 56 - 3 * 8],
999     }
1000 
1001     #[cfg_attr(
1002         all(
1003             target_pointer_width = "32",
1004             any(target_arch = "arm", target_arch = "x86_64")
1005         ),
1006         repr(align(4))
1007     )]
1008     #[cfg_attr(
1009         any(
1010             target_pointer_width = "64",
1011             not(any(target_arch = "arm", target_arch = "x86_64"))
1012         ),
1013         repr(align(8))
1014     )]
1015     pub struct pthread_mutex_t {
1016         size: [u8; crate::__SIZEOF_PTHREAD_MUTEX_T],
1017     }
1018 
1019     #[cfg_attr(
1020         all(
1021             target_pointer_width = "32",
1022             any(target_arch = "arm", target_arch = "x86_64")
1023         ),
1024         repr(align(4))
1025     )]
1026     #[cfg_attr(
1027         any(
1028             target_pointer_width = "64",
1029             not(any(target_arch = "arm", target_arch = "x86_64"))
1030         ),
1031         repr(align(8))
1032     )]
1033     pub struct pthread_rwlock_t {
1034         size: [u8; crate::__SIZEOF_PTHREAD_RWLOCK_T],
1035     }
1036 
1037     #[cfg_attr(target_pointer_width = "32", repr(align(4)))]
1038     #[cfg_attr(target_pointer_width = "64", repr(align(8)))]
1039     #[cfg_attr(target_arch = "x86", repr(align(4)))]
1040     #[cfg_attr(not(target_arch = "x86"), repr(align(8)))]
1041     pub struct pthread_cond_t {
1042         size: [u8; crate::__SIZEOF_PTHREAD_COND_T],
1043     }
1044 }
1045 
1046 cfg_if! {
1047     if #[cfg(feature = "extra_traits")] {
1048         impl PartialEq for sysinfo {
1049             fn eq(&self, other: &sysinfo) -> bool {
1050                 self.uptime == other.uptime
1051                     && self.loads == other.loads
1052                     && self.totalram == other.totalram
1053                     && self.freeram == other.freeram
1054                     && self.sharedram == other.sharedram
1055                     && self.bufferram == other.bufferram
1056                     && self.totalswap == other.totalswap
1057                     && self.freeswap == other.freeswap
1058                     && self.procs == other.procs
1059                     && self.pad == other.pad
1060                     && self.totalhigh == other.totalhigh
1061                     && self.freehigh == other.freehigh
1062                     && self.mem_unit == other.mem_unit
1063                     && self
1064                         .__reserved
1065                         .iter()
1066                         .zip(other.__reserved.iter())
1067                         .all(|(a, b)| a == b)
1068             }
1069         }
1070         impl Eq for sysinfo {}
1071         impl fmt::Debug for sysinfo {
1072             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1073                 f.debug_struct("sysinfo")
1074                     .field("uptime", &self.uptime)
1075                     .field("loads", &self.loads)
1076                     .field("totalram", &self.totalram)
1077                     .field("freeram", &self.freeram)
1078                     .field("sharedram", &self.sharedram)
1079                     .field("bufferram", &self.bufferram)
1080                     .field("totalswap", &self.totalswap)
1081                     .field("freeswap", &self.freeswap)
1082                     .field("procs", &self.procs)
1083                     .field("pad", &self.pad)
1084                     .field("totalhigh", &self.totalhigh)
1085                     .field("freehigh", &self.freehigh)
1086                     .field("mem_unit", &self.mem_unit)
1087                     // FIXME(debug): .field("__reserved", &self.__reserved)
1088                     .finish()
1089             }
1090         }
1091         impl hash::Hash for sysinfo {
1092             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1093                 self.uptime.hash(state);
1094                 self.loads.hash(state);
1095                 self.totalram.hash(state);
1096                 self.freeram.hash(state);
1097                 self.sharedram.hash(state);
1098                 self.bufferram.hash(state);
1099                 self.totalswap.hash(state);
1100                 self.freeswap.hash(state);
1101                 self.procs.hash(state);
1102                 self.pad.hash(state);
1103                 self.totalhigh.hash(state);
1104                 self.freehigh.hash(state);
1105                 self.mem_unit.hash(state);
1106                 self.__reserved.hash(state);
1107             }
1108         }
1109 
1110         impl PartialEq for sockaddr_un {
1111             fn eq(&self, other: &sockaddr_un) -> bool {
1112                 self.sun_family == other.sun_family
1113                     && self
1114                         .sun_path
1115                         .iter()
1116                         .zip(other.sun_path.iter())
1117                         .all(|(a, b)| a == b)
1118             }
1119         }
1120         impl Eq for sockaddr_un {}
1121         impl fmt::Debug for sockaddr_un {
1122             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1123                 f.debug_struct("sockaddr_un")
1124                     .field("sun_family", &self.sun_family)
1125                     // FIXME(debug): .field("sun_path", &self.sun_path)
1126                     .finish()
1127             }
1128         }
1129         impl hash::Hash for sockaddr_un {
1130             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1131                 self.sun_family.hash(state);
1132                 self.sun_path.hash(state);
1133             }
1134         }
1135 
1136         impl PartialEq for sockaddr_storage {
1137             fn eq(&self, other: &sockaddr_storage) -> bool {
1138                 self.ss_family == other.ss_family
1139                     && self.__ss_align == other.__ss_align
1140                     && self
1141                         .__ss_pad2
1142                         .iter()
1143                         .zip(other.__ss_pad2.iter())
1144                         .all(|(a, b)| a == b)
1145             }
1146         }
1147         impl Eq for sockaddr_storage {}
1148         impl fmt::Debug for sockaddr_storage {
1149             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1150                 f.debug_struct("sockaddr_storage")
1151                     .field("ss_family", &self.ss_family)
1152                     .field("__ss_align", &self.__ss_align)
1153                     // FIXME(debug): .field("__ss_pad2", &self.__ss_pad2)
1154                     .finish()
1155             }
1156         }
1157         impl hash::Hash for sockaddr_storage {
1158             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1159                 self.ss_family.hash(state);
1160                 self.__ss_align.hash(state);
1161                 self.__ss_pad2.hash(state);
1162             }
1163         }
1164 
1165         impl PartialEq for utsname {
1166             fn eq(&self, other: &utsname) -> bool {
1167                 self.sysname
1168                     .iter()
1169                     .zip(other.sysname.iter())
1170                     .all(|(a, b)| a == b)
1171                     && self
1172                         .nodename
1173                         .iter()
1174                         .zip(other.nodename.iter())
1175                         .all(|(a, b)| a == b)
1176                     && self
1177                         .release
1178                         .iter()
1179                         .zip(other.release.iter())
1180                         .all(|(a, b)| a == b)
1181                     && self
1182                         .version
1183                         .iter()
1184                         .zip(other.version.iter())
1185                         .all(|(a, b)| a == b)
1186                     && self
1187                         .machine
1188                         .iter()
1189                         .zip(other.machine.iter())
1190                         .all(|(a, b)| a == b)
1191             }
1192         }
1193         impl Eq for utsname {}
1194         impl fmt::Debug for utsname {
1195             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1196                 f.debug_struct("utsname")
1197                     // FIXME(debug): .field("sysname", &self.sysname)
1198                     // FIXME(debug): .field("nodename", &self.nodename)
1199                     // FIXME(debug): .field("release", &self.release)
1200                     // FIXME(debug): .field("version", &self.version)
1201                     // FIXME(debug): .field("machine", &self.machine)
1202                     .finish()
1203             }
1204         }
1205         impl hash::Hash for utsname {
1206             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1207                 self.sysname.hash(state);
1208                 self.nodename.hash(state);
1209                 self.release.hash(state);
1210                 self.version.hash(state);
1211                 self.machine.hash(state);
1212             }
1213         }
1214 
1215         impl PartialEq for dirent {
1216             fn eq(&self, other: &dirent) -> bool {
1217                 self.d_ino == other.d_ino
1218                     && self.d_off == other.d_off
1219                     && self.d_reclen == other.d_reclen
1220                     && self.d_type == other.d_type
1221                     && self
1222                         .d_name
1223                         .iter()
1224                         .zip(other.d_name.iter())
1225                         .all(|(a, b)| a == b)
1226             }
1227         }
1228         impl Eq for dirent {}
1229         impl fmt::Debug for dirent {
1230             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1231                 f.debug_struct("dirent")
1232                     .field("d_ino", &self.d_ino)
1233                     .field("d_off", &self.d_off)
1234                     .field("d_reclen", &self.d_reclen)
1235                     .field("d_type", &self.d_type)
1236                     // FIXME(debug): .field("d_name", &self.d_name)
1237                     .finish()
1238             }
1239         }
1240         impl hash::Hash for dirent {
1241             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1242                 self.d_ino.hash(state);
1243                 self.d_off.hash(state);
1244                 self.d_reclen.hash(state);
1245                 self.d_type.hash(state);
1246                 self.d_name.hash(state);
1247             }
1248         }
1249 
1250         impl PartialEq for dirent64 {
1251             fn eq(&self, other: &dirent64) -> bool {
1252                 self.d_ino == other.d_ino
1253                     && self.d_off == other.d_off
1254                     && self.d_reclen == other.d_reclen
1255                     && self.d_type == other.d_type
1256                     && self
1257                         .d_name
1258                         .iter()
1259                         .zip(other.d_name.iter())
1260                         .all(|(a, b)| a == b)
1261             }
1262         }
1263         impl Eq for dirent64 {}
1264         impl fmt::Debug for dirent64 {
1265             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1266                 f.debug_struct("dirent64")
1267                     .field("d_ino", &self.d_ino)
1268                     .field("d_off", &self.d_off)
1269                     .field("d_reclen", &self.d_reclen)
1270                     .field("d_type", &self.d_type)
1271                     // FIXME(debug): .field("d_name", &self.d_name)
1272                     .finish()
1273             }
1274         }
1275         impl hash::Hash for dirent64 {
1276             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1277                 self.d_ino.hash(state);
1278                 self.d_off.hash(state);
1279                 self.d_reclen.hash(state);
1280                 self.d_type.hash(state);
1281                 self.d_name.hash(state);
1282             }
1283         }
1284 
1285         impl PartialEq for mq_attr {
1286             fn eq(&self, other: &mq_attr) -> bool {
1287                 self.mq_flags == other.mq_flags
1288                     && self.mq_maxmsg == other.mq_maxmsg
1289                     && self.mq_msgsize == other.mq_msgsize
1290                     && self.mq_curmsgs == other.mq_curmsgs
1291             }
1292         }
1293         impl Eq for mq_attr {}
1294         impl fmt::Debug for mq_attr {
1295             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1296                 f.debug_struct("mq_attr")
1297                     .field("mq_flags", &self.mq_flags)
1298                     .field("mq_maxmsg", &self.mq_maxmsg)
1299                     .field("mq_msgsize", &self.mq_msgsize)
1300                     .field("mq_curmsgs", &self.mq_curmsgs)
1301                     .finish()
1302             }
1303         }
1304         impl hash::Hash for mq_attr {
1305             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1306                 self.mq_flags.hash(state);
1307                 self.mq_maxmsg.hash(state);
1308                 self.mq_msgsize.hash(state);
1309                 self.mq_curmsgs.hash(state);
1310             }
1311         }
1312 
1313         impl PartialEq for sockaddr_nl {
1314             fn eq(&self, other: &sockaddr_nl) -> bool {
1315                 self.nl_family == other.nl_family
1316                     && self.nl_pid == other.nl_pid
1317                     && self.nl_groups == other.nl_groups
1318             }
1319         }
1320         impl Eq for sockaddr_nl {}
1321         impl fmt::Debug for sockaddr_nl {
1322             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1323                 f.debug_struct("sockaddr_nl")
1324                     .field("nl_family", &self.nl_family)
1325                     .field("nl_pid", &self.nl_pid)
1326                     .field("nl_groups", &self.nl_groups)
1327                     .finish()
1328             }
1329         }
1330         impl hash::Hash for sockaddr_nl {
1331             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1332                 self.nl_family.hash(state);
1333                 self.nl_pid.hash(state);
1334                 self.nl_groups.hash(state);
1335             }
1336         }
1337 
1338         // FIXME(msrv): suggested method was added in 1.85
1339         #[allow(unpredictable_function_pointer_comparisons)]
1340         impl PartialEq for sigevent {
1341             fn eq(&self, other: &sigevent) -> bool {
1342                 self.sigev_value == other.sigev_value
1343                     && self.sigev_signo == other.sigev_signo
1344                     && self.sigev_notify == other.sigev_notify
1345                     && self.sigev_notify_function == other.sigev_notify_function
1346                     && self.sigev_notify_attributes == other.sigev_notify_attributes
1347             }
1348         }
1349         impl Eq for sigevent {}
1350         impl fmt::Debug for sigevent {
1351             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1352                 f.debug_struct("sigevent")
1353                     .field("sigev_value", &self.sigev_value)
1354                     .field("sigev_signo", &self.sigev_signo)
1355                     .field("sigev_notify", &self.sigev_notify)
1356                     .field("sigev_notify_function", &self.sigev_notify_function)
1357                     .field("sigev_notify_attributes", &self.sigev_notify_attributes)
1358                     .finish()
1359             }
1360         }
1361         impl hash::Hash for sigevent {
1362             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1363                 self.sigev_value.hash(state);
1364                 self.sigev_signo.hash(state);
1365                 self.sigev_notify.hash(state);
1366                 self.sigev_notify_function.hash(state);
1367                 self.sigev_notify_attributes.hash(state);
1368             }
1369         }
1370 
1371         impl PartialEq for pthread_cond_t {
1372             fn eq(&self, other: &pthread_cond_t) -> bool {
1373                 self.size.iter().zip(other.size.iter()).all(|(a, b)| a == b)
1374             }
1375         }
1376         impl Eq for pthread_cond_t {}
1377         impl fmt::Debug for pthread_cond_t {
1378             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1379                 f.debug_struct("pthread_cond_t")
1380                     // FIXME(debug): .field("size", &self.size)
1381                     .finish()
1382             }
1383         }
1384         impl hash::Hash for pthread_cond_t {
1385             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1386                 self.size.hash(state);
1387             }
1388         }
1389 
1390         impl PartialEq for pthread_mutex_t {
1391             fn eq(&self, other: &pthread_mutex_t) -> bool {
1392                 self.size.iter().zip(other.size.iter()).all(|(a, b)| a == b)
1393             }
1394         }
1395         impl Eq for pthread_mutex_t {}
1396         impl fmt::Debug for pthread_mutex_t {
1397             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1398                 f.debug_struct("pthread_mutex_t")
1399                     // FIXME(debug): .field("size", &self.size)
1400                     .finish()
1401             }
1402         }
1403         impl hash::Hash for pthread_mutex_t {
1404             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1405                 self.size.hash(state);
1406             }
1407         }
1408 
1409         impl PartialEq for pthread_rwlock_t {
1410             fn eq(&self, other: &pthread_rwlock_t) -> bool {
1411                 self.size.iter().zip(other.size.iter()).all(|(a, b)| a == b)
1412             }
1413         }
1414         impl Eq for pthread_rwlock_t {}
1415         impl fmt::Debug for pthread_rwlock_t {
1416             fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
1417                 f.debug_struct("pthread_rwlock_t")
1418                     // FIXME(debug): .field("size", &self.size)
1419                     .finish()
1420             }
1421         }
1422         impl hash::Hash for pthread_rwlock_t {
1423             fn hash<H: hash::Hasher>(&self, state: &mut H) {
1424                 self.size.hash(state);
1425             }
1426         }
1427     }
1428 }
1429 
1430 // PUB_CONST
1431 
1432 pub const INT_MIN: c_int = -2147483648;
1433 pub const INT_MAX: c_int = 2147483647;
1434 
1435 pub const SIG_DFL: sighandler_t = 0 as sighandler_t;
1436 pub const SIG_IGN: sighandler_t = 1 as sighandler_t;
1437 pub const SIG_ERR: sighandler_t = !0 as sighandler_t;
1438 
1439 pub const DT_UNKNOWN: u8 = 0;
1440 pub const DT_FIFO: u8 = 1;
1441 pub const DT_CHR: u8 = 2;
1442 pub const DT_DIR: u8 = 4;
1443 pub const DT_BLK: u8 = 6;
1444 pub const DT_REG: u8 = 8;
1445 pub const DT_LNK: u8 = 10;
1446 pub const DT_SOCK: u8 = 12;
1447 
1448 pub const FD_CLOEXEC: c_int = 0x1;
1449 
1450 pub const USRQUOTA: c_int = 0;
1451 pub const GRPQUOTA: c_int = 1;
1452 
1453 pub const SIGIOT: c_int = 6;
1454 
1455 pub const S_ISUID: mode_t = 0o4000;
1456 pub const S_ISGID: mode_t = 0o2000;
1457 pub const S_ISVTX: mode_t = 0o1000;
1458 
1459 pub const IF_NAMESIZE: size_t = 16;
1460 pub const IFNAMSIZ: size_t = IF_NAMESIZE;
1461 
1462 pub const LOG_EMERG: c_int = 0;
1463 pub const LOG_ALERT: c_int = 1;
1464 pub const LOG_CRIT: c_int = 2;
1465 pub const LOG_ERR: c_int = 3;
1466 pub const LOG_WARNING: c_int = 4;
1467 pub const LOG_NOTICE: c_int = 5;
1468 pub const LOG_INFO: c_int = 6;
1469 pub const LOG_DEBUG: c_int = 7;
1470 
1471 pub const LOG_KERN: c_int = 0;
1472 pub const LOG_USER: c_int = 1 << 3;
1473 pub const LOG_MAIL: c_int = 2 << 3;
1474 pub const LOG_DAEMON: c_int = 3 << 3;
1475 pub const LOG_AUTH: c_int = 4 << 3;
1476 pub const LOG_SYSLOG: c_int = 5 << 3;
1477 pub const LOG_LPR: c_int = 6 << 3;
1478 pub const LOG_NEWS: c_int = 7 << 3;
1479 pub const LOG_UUCP: c_int = 8 << 3;
1480 pub const LOG_LOCAL0: c_int = 16 << 3;
1481 pub const LOG_LOCAL1: c_int = 17 << 3;
1482 pub const LOG_LOCAL2: c_int = 18 << 3;
1483 pub const LOG_LOCAL3: c_int = 19 << 3;
1484 pub const LOG_LOCAL4: c_int = 20 << 3;
1485 pub const LOG_LOCAL5: c_int = 21 << 3;
1486 pub const LOG_LOCAL6: c_int = 22 << 3;
1487 pub const LOG_LOCAL7: c_int = 23 << 3;
1488 
1489 pub const LOG_PID: c_int = 0x01;
1490 pub const LOG_CONS: c_int = 0x02;
1491 pub const LOG_ODELAY: c_int = 0x04;
1492 pub const LOG_NDELAY: c_int = 0x08;
1493 pub const LOG_NOWAIT: c_int = 0x10;
1494 
1495 pub const LOG_PRIMASK: c_int = 7;
1496 pub const LOG_FACMASK: c_int = 0x3f8;
1497 
1498 pub const PRIO_PROCESS: c_int = 0;
1499 pub const PRIO_PGRP: c_int = 1;
1500 pub const PRIO_USER: c_int = 2;
1501 
1502 pub const PRIO_MIN: c_int = -20;
1503 pub const PRIO_MAX: c_int = 20;
1504 
1505 pub const IPPROTO_ICMP: c_int = 1;
1506 pub const IPPROTO_ICMPV6: c_int = 58;
1507 pub const IPPROTO_TCP: c_int = 6;
1508 pub const IPPROTO_UDP: c_int = 17;
1509 pub const IPPROTO_IP: c_int = 0;
1510 pub const IPPROTO_IPV6: c_int = 41;
1511 
1512 pub const INADDR_LOOPBACK: in_addr_t = 2130706433;
1513 pub const INADDR_ANY: in_addr_t = 0;
1514 pub const INADDR_BROADCAST: in_addr_t = 4294967295;
1515 pub const INADDR_NONE: in_addr_t = 4294967295;
1516 
1517 pub const EXIT_FAILURE: c_int = 1;
1518 pub const EXIT_SUCCESS: c_int = 0;
1519 pub const RAND_MAX: c_int = 2147483647;
1520 pub const EOF: c_int = -1;
1521 pub const SEEK_SET: c_int = 0;
1522 pub const SEEK_CUR: c_int = 1;
1523 pub const SEEK_END: c_int = 2;
1524 pub const _IOFBF: c_int = 0;
1525 pub const _IONBF: c_int = 2;
1526 pub const _IOLBF: c_int = 1;
1527 
1528 pub const F_DUPFD: c_int = 0;
1529 pub const F_GETFD: c_int = 1;
1530 pub const F_SETFD: c_int = 2;
1531 pub const F_GETFL: c_int = 3;
1532 pub const F_SETFL: c_int = 4;
1533 
1534 // Linux-specific fcntls
1535 pub const F_SETLEASE: c_int = 1024;
1536 pub const F_GETLEASE: c_int = 1025;
1537 pub const F_NOTIFY: c_int = 1026;
1538 pub const F_CANCELLK: c_int = 1029;
1539 pub const F_DUPFD_CLOEXEC: c_int = 1030;
1540 pub const F_SETPIPE_SZ: c_int = 1031;
1541 pub const F_GETPIPE_SZ: c_int = 1032;
1542 pub const F_ADD_SEALS: c_int = 1033;
1543 pub const F_GET_SEALS: c_int = 1034;
1544 
1545 pub const F_SEAL_SEAL: c_int = 0x0001;
1546 pub const F_SEAL_SHRINK: c_int = 0x0002;
1547 pub const F_SEAL_GROW: c_int = 0x0004;
1548 pub const F_SEAL_WRITE: c_int = 0x0008;
1549 
1550 // FIXME(#235): Include file sealing fcntls once we have a way to verify them.
1551 
1552 pub const SIGTRAP: c_int = 5;
1553 
1554 pub const PTHREAD_CREATE_JOINABLE: c_int = 0;
1555 pub const PTHREAD_CREATE_DETACHED: c_int = 1;
1556 
1557 pub const CLOCK_REALTIME: crate::clockid_t = 0;
1558 pub const CLOCK_MONOTONIC: crate::clockid_t = 1;
1559 pub const CLOCK_PROCESS_CPUTIME_ID: crate::clockid_t = 2;
1560 pub const CLOCK_THREAD_CPUTIME_ID: crate::clockid_t = 3;
1561 pub const CLOCK_MONOTONIC_RAW: crate::clockid_t = 4;
1562 pub const CLOCK_REALTIME_COARSE: crate::clockid_t = 5;
1563 pub const CLOCK_MONOTONIC_COARSE: crate::clockid_t = 6;
1564 pub const CLOCK_BOOTTIME: crate::clockid_t = 7;
1565 pub const CLOCK_REALTIME_ALARM: crate::clockid_t = 8;
1566 pub const CLOCK_BOOTTIME_ALARM: crate::clockid_t = 9;
1567 pub const CLOCK_SGI_CYCLE: crate::clockid_t = 10;
1568 pub const CLOCK_TAI: crate::clockid_t = 11;
1569 pub const TIMER_ABSTIME: c_int = 1;
1570 
1571 pub const RLIMIT_CPU: c_int = 0;
1572 pub const RLIMIT_FSIZE: c_int = 1;
1573 pub const RLIMIT_DATA: c_int = 2;
1574 pub const RLIMIT_STACK: c_int = 3;
1575 pub const RLIMIT_CORE: c_int = 4;
1576 pub const RLIMIT_LOCKS: c_int = 10;
1577 pub const RLIMIT_SIGPENDING: c_int = 11;
1578 pub const RLIMIT_MSGQUEUE: c_int = 12;
1579 pub const RLIMIT_NICE: c_int = 13;
1580 pub const RLIMIT_RTPRIO: c_int = 14;
1581 
1582 pub const RUSAGE_SELF: c_int = 0;
1583 
1584 pub const O_RDONLY: c_int = 0;
1585 pub const O_WRONLY: c_int = 1;
1586 pub const O_RDWR: c_int = 2;
1587 
1588 pub const S_IFIFO: mode_t = 0o1_0000;
1589 pub const S_IFCHR: mode_t = 0o2_0000;
1590 pub const S_IFBLK: mode_t = 0o6_0000;
1591 pub const S_IFDIR: mode_t = 0o4_0000;
1592 pub const S_IFREG: mode_t = 0o10_0000;
1593 pub const S_IFLNK: mode_t = 0o12_0000;
1594 pub const S_IFSOCK: mode_t = 0o14_0000;
1595 pub const S_IFMT: mode_t = 0o17_0000;
1596 pub const S_IRWXU: mode_t = 0o0700;
1597 pub const S_IXUSR: mode_t = 0o0100;
1598 pub const S_IWUSR: mode_t = 0o0200;
1599 pub const S_IRUSR: mode_t = 0o0400;
1600 pub const S_IRWXG: mode_t = 0o0070;
1601 pub const S_IXGRP: mode_t = 0o0010;
1602 pub const S_IWGRP: mode_t = 0o0020;
1603 pub const S_IRGRP: mode_t = 0o0040;
1604 pub const S_IRWXO: mode_t = 0o0007;
1605 pub const S_IXOTH: mode_t = 0o0001;
1606 pub const S_IWOTH: mode_t = 0o0002;
1607 pub const S_IROTH: mode_t = 0o0004;
1608 pub const F_OK: c_int = 0;
1609 pub const R_OK: c_int = 4;
1610 pub const W_OK: c_int = 2;
1611 pub const X_OK: c_int = 1;
1612 pub const STDIN_FILENO: c_int = 0;
1613 pub const STDOUT_FILENO: c_int = 1;
1614 pub const STDERR_FILENO: c_int = 2;
1615 pub const SIGHUP: c_int = 1;
1616 pub const SIGINT: c_int = 2;
1617 pub const SIGQUIT: c_int = 3;
1618 pub const SIGILL: c_int = 4;
1619 pub const SIGABRT: c_int = 6;
1620 pub const SIGFPE: c_int = 8;
1621 pub const SIGKILL: c_int = 9;
1622 pub const SIGSEGV: c_int = 11;
1623 pub const SIGPIPE: c_int = 13;
1624 pub const SIGALRM: c_int = 14;
1625 pub const SIGTERM: c_int = 15;
1626 
1627 pub const PROT_NONE: c_int = 0;
1628 pub const PROT_READ: c_int = 1;
1629 pub const PROT_WRITE: c_int = 2;
1630 pub const PROT_EXEC: c_int = 4;
1631 
1632 pub const LC_CTYPE: c_int = 0;
1633 pub const LC_NUMERIC: c_int = 1;
1634 pub const LC_TIME: c_int = 2;
1635 pub const LC_COLLATE: c_int = 3;
1636 pub const LC_MONETARY: c_int = 4;
1637 pub const LC_MESSAGES: c_int = 5;
1638 pub const LC_ALL: c_int = 6;
1639 pub const LC_CTYPE_MASK: c_int = 1 << LC_CTYPE;
1640 pub const LC_NUMERIC_MASK: c_int = 1 << LC_NUMERIC;
1641 pub const LC_TIME_MASK: c_int = 1 << LC_TIME;
1642 pub const LC_COLLATE_MASK: c_int = 1 << LC_COLLATE;
1643 pub const LC_MONETARY_MASK: c_int = 1 << LC_MONETARY;
1644 pub const LC_MESSAGES_MASK: c_int = 1 << LC_MESSAGES;
1645 // LC_ALL_MASK defined per platform
1646 
1647 pub const MAP_FILE: c_int = 0x0000;
1648 pub const MAP_SHARED: c_int = 0x0001;
1649 pub const MAP_PRIVATE: c_int = 0x0002;
1650 pub const MAP_FIXED: c_int = 0x0010;
1651 
1652 pub const MAP_FAILED: *mut c_void = !0 as *mut c_void;
1653 
1654 // MS_ flags for msync(2)
1655 pub const MS_ASYNC: c_int = 0x0001;
1656 pub const MS_INVALIDATE: c_int = 0x0002;
1657 pub const MS_SYNC: c_int = 0x0004;
1658 
1659 // MS_ flags for mount(2)
1660 pub const MS_RDONLY: c_ulong = 0x01;
1661 pub const MS_NOSUID: c_ulong = 0x02;
1662 pub const MS_NODEV: c_ulong = 0x04;
1663 pub const MS_NOEXEC: c_ulong = 0x08;
1664 pub const MS_SYNCHRONOUS: c_ulong = 0x10;
1665 pub const MS_REMOUNT: c_ulong = 0x20;
1666 pub const MS_MANDLOCK: c_ulong = 0x40;
1667 pub const MS_DIRSYNC: c_ulong = 0x80;
1668 pub const MS_NOATIME: c_ulong = 0x0400;
1669 pub const MS_NODIRATIME: c_ulong = 0x0800;
1670 pub const MS_BIND: c_ulong = 0x1000;
1671 pub const MS_MOVE: c_ulong = 0x2000;
1672 pub const MS_REC: c_ulong = 0x4000;
1673 pub const MS_SILENT: c_ulong = 0x8000;
1674 pub const MS_POSIXACL: c_ulong = 0x010000;
1675 pub const MS_UNBINDABLE: c_ulong = 0x020000;
1676 pub const MS_PRIVATE: c_ulong = 0x040000;
1677 pub const MS_SLAVE: c_ulong = 0x080000;
1678 pub const MS_SHARED: c_ulong = 0x100000;
1679 pub const MS_RELATIME: c_ulong = 0x200000;
1680 pub const MS_KERNMOUNT: c_ulong = 0x400000;
1681 pub const MS_I_VERSION: c_ulong = 0x800000;
1682 pub const MS_STRICTATIME: c_ulong = 0x1000000;
1683 pub const MS_ACTIVE: c_ulong = 0x40000000;
1684 pub const MS_NOUSER: c_ulong = 0x80000000;
1685 pub const MS_MGC_VAL: c_ulong = 0xc0ed0000;
1686 pub const MS_MGC_MSK: c_ulong = 0xffff0000;
1687 pub const MS_RMT_MASK: c_ulong = 0x800051;
1688 
1689 pub const EPERM: c_int = 1;
1690 pub const ENOENT: c_int = 2;
1691 pub const ESRCH: c_int = 3;
1692 pub const EINTR: c_int = 4;
1693 pub const EIO: c_int = 5;
1694 pub const ENXIO: c_int = 6;
1695 pub const E2BIG: c_int = 7;
1696 pub const ENOEXEC: c_int = 8;
1697 pub const EBADF: c_int = 9;
1698 pub const ECHILD: c_int = 10;
1699 pub const EAGAIN: c_int = 11;
1700 pub const ENOMEM: c_int = 12;
1701 pub const EACCES: c_int = 13;
1702 pub const EFAULT: c_int = 14;
1703 pub const ENOTBLK: c_int = 15;
1704 pub const EBUSY: c_int = 16;
1705 pub const EEXIST: c_int = 17;
1706 pub const EXDEV: c_int = 18;
1707 pub const ENODEV: c_int = 19;
1708 pub const ENOTDIR: c_int = 20;
1709 pub const EISDIR: c_int = 21;
1710 pub const EINVAL: c_int = 22;
1711 pub const ENFILE: c_int = 23;
1712 pub const EMFILE: c_int = 24;
1713 pub const ENOTTY: c_int = 25;
1714 pub const ETXTBSY: c_int = 26;
1715 pub const EFBIG: c_int = 27;
1716 pub const ENOSPC: c_int = 28;
1717 pub const ESPIPE: c_int = 29;
1718 pub const EROFS: c_int = 30;
1719 pub const EMLINK: c_int = 31;
1720 pub const EPIPE: c_int = 32;
1721 pub const EDOM: c_int = 33;
1722 pub const ERANGE: c_int = 34;
1723 pub const EWOULDBLOCK: c_int = EAGAIN;
1724 
1725 pub const SCM_RIGHTS: c_int = 0x01;
1726 pub const SCM_CREDENTIALS: c_int = 0x02;
1727 
1728 pub const PROT_GROWSDOWN: c_int = 0x1000000;
1729 pub const PROT_GROWSUP: c_int = 0x2000000;
1730 
1731 pub const MAP_TYPE: c_int = 0x000f;
1732 
1733 pub const MADV_NORMAL: c_int = 0;
1734 pub const MADV_RANDOM: c_int = 1;
1735 pub const MADV_SEQUENTIAL: c_int = 2;
1736 pub const MADV_WILLNEED: c_int = 3;
1737 pub const MADV_DONTNEED: c_int = 4;
1738 pub const MADV_FREE: c_int = 8;
1739 pub const MADV_REMOVE: c_int = 9;
1740 pub const MADV_DONTFORK: c_int = 10;
1741 pub const MADV_DOFORK: c_int = 11;
1742 pub const MADV_MERGEABLE: c_int = 12;
1743 pub const MADV_UNMERGEABLE: c_int = 13;
1744 pub const MADV_HUGEPAGE: c_int = 14;
1745 pub const MADV_NOHUGEPAGE: c_int = 15;
1746 pub const MADV_DONTDUMP: c_int = 16;
1747 pub const MADV_DODUMP: c_int = 17;
1748 pub const MADV_HWPOISON: c_int = 100;
1749 pub const MADV_SOFT_OFFLINE: c_int = 101;
1750 
1751 pub const IFF_UP: c_int = 0x1;
1752 pub const IFF_BROADCAST: c_int = 0x2;
1753 pub const IFF_DEBUG: c_int = 0x4;
1754 pub const IFF_LOOPBACK: c_int = 0x8;
1755 pub const IFF_POINTOPOINT: c_int = 0x10;
1756 pub const IFF_NOTRAILERS: c_int = 0x20;
1757 pub const IFF_RUNNING: c_int = 0x40;
1758 pub const IFF_NOARP: c_int = 0x80;
1759 pub const IFF_PROMISC: c_int = 0x100;
1760 pub const IFF_ALLMULTI: c_int = 0x200;
1761 pub const IFF_MASTER: c_int = 0x400;
1762 pub const IFF_SLAVE: c_int = 0x800;
1763 pub const IFF_MULTICAST: c_int = 0x1000;
1764 pub const IFF_PORTSEL: c_int = 0x2000;
1765 pub const IFF_AUTOMEDIA: c_int = 0x4000;
1766 pub const IFF_DYNAMIC: c_int = 0x8000;
1767 pub const IFF_TUN: c_int = 0x0001;
1768 pub const IFF_TAP: c_int = 0x0002;
1769 pub const IFF_NO_PI: c_int = 0x1000;
1770 
1771 pub const SOL_IP: c_int = 0;
1772 pub const SOL_TCP: c_int = 6;
1773 pub const SOL_UDP: c_int = 17;
1774 pub const SOL_IPV6: c_int = 41;
1775 pub const SOL_ICMPV6: c_int = 58;
1776 pub const SOL_RAW: c_int = 255;
1777 pub const SOL_DECNET: c_int = 261;
1778 pub const SOL_X25: c_int = 262;
1779 pub const SOL_PACKET: c_int = 263;
1780 pub const SOL_ATM: c_int = 264;
1781 pub const SOL_AAL: c_int = 265;
1782 pub const SOL_IRDA: c_int = 266;
1783 pub const SOL_NETBEUI: c_int = 267;
1784 pub const SOL_LLC: c_int = 268;
1785 pub const SOL_DCCP: c_int = 269;
1786 pub const SOL_NETLINK: c_int = 270;
1787 pub const SOL_TIPC: c_int = 271;
1788 
1789 pub const AF_UNSPEC: c_int = 0;
1790 pub const AF_UNIX: c_int = 1;
1791 pub const AF_LOCAL: c_int = 1;
1792 pub const AF_INET: c_int = 2;
1793 pub const AF_AX25: c_int = 3;
1794 pub const AF_IPX: c_int = 4;
1795 pub const AF_APPLETALK: c_int = 5;
1796 pub const AF_NETROM: c_int = 6;
1797 pub const AF_BRIDGE: c_int = 7;
1798 pub const AF_ATMPVC: c_int = 8;
1799 pub const AF_X25: c_int = 9;
1800 pub const AF_INET6: c_int = 10;
1801 pub const AF_ROSE: c_int = 11;
1802 pub const AF_DECnet: c_int = 12;
1803 pub const AF_NETBEUI: c_int = 13;
1804 pub const AF_SECURITY: c_int = 14;
1805 pub const AF_KEY: c_int = 15;
1806 pub const AF_NETLINK: c_int = 16;
1807 pub const AF_ROUTE: c_int = AF_NETLINK;
1808 pub const AF_PACKET: c_int = 17;
1809 pub const AF_ASH: c_int = 18;
1810 pub const AF_ECONET: c_int = 19;
1811 pub const AF_ATMSVC: c_int = 20;
1812 pub const AF_RDS: c_int = 21;
1813 pub const AF_SNA: c_int = 22;
1814 pub const AF_IRDA: c_int = 23;
1815 pub const AF_PPPOX: c_int = 24;
1816 pub const AF_WANPIPE: c_int = 25;
1817 pub const AF_LLC: c_int = 26;
1818 pub const AF_CAN: c_int = 29;
1819 pub const AF_TIPC: c_int = 30;
1820 pub const AF_BLUETOOTH: c_int = 31;
1821 pub const AF_IUCV: c_int = 32;
1822 pub const AF_RXRPC: c_int = 33;
1823 pub const AF_ISDN: c_int = 34;
1824 pub const AF_PHONET: c_int = 35;
1825 pub const AF_IEEE802154: c_int = 36;
1826 pub const AF_CAIF: c_int = 37;
1827 pub const AF_ALG: c_int = 38;
1828 
1829 pub const PF_UNSPEC: c_int = AF_UNSPEC;
1830 pub const PF_UNIX: c_int = AF_UNIX;
1831 pub const PF_LOCAL: c_int = AF_LOCAL;
1832 pub const PF_INET: c_int = AF_INET;
1833 pub const PF_AX25: c_int = AF_AX25;
1834 pub const PF_IPX: c_int = AF_IPX;
1835 pub const PF_APPLETALK: c_int = AF_APPLETALK;
1836 pub const PF_NETROM: c_int = AF_NETROM;
1837 pub const PF_BRIDGE: c_int = AF_BRIDGE;
1838 pub const PF_ATMPVC: c_int = AF_ATMPVC;
1839 pub const PF_X25: c_int = AF_X25;
1840 pub const PF_INET6: c_int = AF_INET6;
1841 pub const PF_ROSE: c_int = AF_ROSE;
1842 pub const PF_DECnet: c_int = AF_DECnet;
1843 pub const PF_NETBEUI: c_int = AF_NETBEUI;
1844 pub const PF_SECURITY: c_int = AF_SECURITY;
1845 pub const PF_KEY: c_int = AF_KEY;
1846 pub const PF_NETLINK: c_int = AF_NETLINK;
1847 pub const PF_ROUTE: c_int = AF_ROUTE;
1848 pub const PF_PACKET: c_int = AF_PACKET;
1849 pub const PF_ASH: c_int = AF_ASH;
1850 pub const PF_ECONET: c_int = AF_ECONET;
1851 pub const PF_ATMSVC: c_int = AF_ATMSVC;
1852 pub const PF_RDS: c_int = AF_RDS;
1853 pub const PF_SNA: c_int = AF_SNA;
1854 pub const PF_IRDA: c_int = AF_IRDA;
1855 pub const PF_PPPOX: c_int = AF_PPPOX;
1856 pub const PF_WANPIPE: c_int = AF_WANPIPE;
1857 pub const PF_LLC: c_int = AF_LLC;
1858 pub const PF_CAN: c_int = AF_CAN;
1859 pub const PF_TIPC: c_int = AF_TIPC;
1860 pub const PF_BLUETOOTH: c_int = AF_BLUETOOTH;
1861 pub const PF_IUCV: c_int = AF_IUCV;
1862 pub const PF_RXRPC: c_int = AF_RXRPC;
1863 pub const PF_ISDN: c_int = AF_ISDN;
1864 pub const PF_PHONET: c_int = AF_PHONET;
1865 pub const PF_IEEE802154: c_int = AF_IEEE802154;
1866 pub const PF_CAIF: c_int = AF_CAIF;
1867 pub const PF_ALG: c_int = AF_ALG;
1868 
1869 pub const SOMAXCONN: c_int = 128;
1870 
1871 pub const MSG_OOB: c_int = 1;
1872 pub const MSG_PEEK: c_int = 2;
1873 pub const MSG_DONTROUTE: c_int = 4;
1874 pub const MSG_CTRUNC: c_int = 8;
1875 pub const MSG_TRUNC: c_int = 0x20;
1876 pub const MSG_DONTWAIT: c_int = 0x40;
1877 pub const MSG_EOR: c_int = 0x80;
1878 pub const MSG_WAITALL: c_int = 0x100;
1879 pub const MSG_FIN: c_int = 0x200;
1880 pub const MSG_SYN: c_int = 0x400;
1881 pub const MSG_CONFIRM: c_int = 0x800;
1882 pub const MSG_RST: c_int = 0x1000;
1883 pub const MSG_ERRQUEUE: c_int = 0x2000;
1884 pub const MSG_NOSIGNAL: c_int = 0x4000;
1885 pub const MSG_MORE: c_int = 0x8000;
1886 pub const MSG_WAITFORONE: c_int = 0x10000;
1887 pub const MSG_FASTOPEN: c_int = 0x20000000;
1888 pub const MSG_CMSG_CLOEXEC: c_int = 0x40000000;
1889 
1890 pub const SCM_TIMESTAMP: c_int = SO_TIMESTAMP;
1891 
1892 pub const SOCK_RAW: c_int = 3;
1893 pub const SOCK_RDM: c_int = 4;
1894 
1895 pub const IP_TOS: c_int = 1;
1896 pub const IP_TTL: c_int = 2;
1897 pub const IP_HDRINCL: c_int = 3;
1898 pub const IP_RECVTOS: c_int = 13;
1899 pub const IP_FREEBIND: c_int = 15;
1900 pub const IP_TRANSPARENT: c_int = 19;
1901 pub const IP_MULTICAST_IF: c_int = 32;
1902 pub const IP_MULTICAST_TTL: c_int = 33;
1903 pub const IP_MULTICAST_LOOP: c_int = 34;
1904 pub const IP_ADD_MEMBERSHIP: c_int = 35;
1905 pub const IP_DROP_MEMBERSHIP: c_int = 36;
1906 
1907 pub const IPV6_UNICAST_HOPS: c_int = 16;
1908 pub const IPV6_MULTICAST_IF: c_int = 17;
1909 pub const IPV6_MULTICAST_HOPS: c_int = 18;
1910 pub const IPV6_MULTICAST_LOOP: c_int = 19;
1911 pub const IPV6_ADD_MEMBERSHIP: c_int = 20;
1912 pub const IPV6_DROP_MEMBERSHIP: c_int = 21;
1913 pub const IPV6_V6ONLY: c_int = 26;
1914 pub const IPV6_RECVPKTINFO: c_int = 49;
1915 pub const IPV6_RECVTCLASS: c_int = 66;
1916 pub const IPV6_TCLASS: c_int = 67;
1917 
1918 pub const TCP_NODELAY: c_int = 1;
1919 pub const TCP_MAXSEG: c_int = 2;
1920 pub const TCP_CORK: c_int = 3;
1921 pub const TCP_KEEPIDLE: c_int = 4;
1922 pub const TCP_KEEPINTVL: c_int = 5;
1923 pub const TCP_KEEPCNT: c_int = 6;
1924 pub const TCP_SYNCNT: c_int = 7;
1925 pub const TCP_LINGER2: c_int = 8;
1926 pub const TCP_DEFER_ACCEPT: c_int = 9;
1927 pub const TCP_WINDOW_CLAMP: c_int = 10;
1928 pub const TCP_INFO: c_int = 11;
1929 pub const TCP_QUICKACK: c_int = 12;
1930 pub const TCP_CONGESTION: c_int = 13;
1931 
1932 pub const SO_DEBUG: c_int = 1;
1933 
1934 pub const SHUT_RD: c_int = 0;
1935 pub const SHUT_WR: c_int = 1;
1936 pub const SHUT_RDWR: c_int = 2;
1937 
1938 pub const LOCK_SH: c_int = 1;
1939 pub const LOCK_EX: c_int = 2;
1940 pub const LOCK_NB: c_int = 4;
1941 pub const LOCK_UN: c_int = 8;
1942 
1943 pub const SS_ONSTACK: c_int = 1;
1944 pub const SS_DISABLE: c_int = 2;
1945 
1946 pub const PATH_MAX: c_int = 4096;
1947 
1948 pub const FD_SETSIZE: usize = 1024;
1949 
1950 pub const EPOLLIN: c_int = 0x1;
1951 pub const EPOLLPRI: c_int = 0x2;
1952 pub const EPOLLOUT: c_int = 0x4;
1953 pub const EPOLLRDNORM: c_int = 0x40;
1954 pub const EPOLLRDBAND: c_int = 0x80;
1955 pub const EPOLLWRNORM: c_int = 0x100;
1956 pub const EPOLLWRBAND: c_int = 0x200;
1957 pub const EPOLLMSG: c_int = 0x400;
1958 pub const EPOLLERR: c_int = 0x8;
1959 pub const EPOLLHUP: c_int = 0x10;
1960 pub const EPOLLET: c_int = 0x80000000;
1961 
1962 pub const EPOLL_CTL_ADD: c_int = 1;
1963 pub const EPOLL_CTL_MOD: c_int = 3;
1964 pub const EPOLL_CTL_DEL: c_int = 2;
1965 
1966 pub const MNT_DETACH: c_int = 0x2;
1967 pub const MNT_EXPIRE: c_int = 0x4;
1968 
1969 pub const Q_GETFMT: c_int = 0x800004;
1970 pub const Q_GETINFO: c_int = 0x800005;
1971 pub const Q_SETINFO: c_int = 0x800006;
1972 pub const QIF_BLIMITS: u32 = 1;
1973 pub const QIF_SPACE: u32 = 2;
1974 pub const QIF_ILIMITS: u32 = 4;
1975 pub const QIF_INODES: u32 = 8;
1976 pub const QIF_BTIME: u32 = 16;
1977 pub const QIF_ITIME: u32 = 32;
1978 pub const QIF_LIMITS: u32 = 5;
1979 pub const QIF_USAGE: u32 = 10;
1980 pub const QIF_TIMES: u32 = 48;
1981 pub const QIF_ALL: u32 = 63;
1982 
1983 pub const MNT_FORCE: c_int = 0x1;
1984 
1985 pub const Q_SYNC: c_int = 0x800001;
1986 pub const Q_QUOTAON: c_int = 0x800002;
1987 pub const Q_QUOTAOFF: c_int = 0x800003;
1988 pub const Q_GETQUOTA: c_int = 0x800007;
1989 pub const Q_SETQUOTA: c_int = 0x800008;
1990 
1991 pub const TCIOFF: c_int = 2;
1992 pub const TCION: c_int = 3;
1993 pub const TCOOFF: c_int = 0;
1994 pub const TCOON: c_int = 1;
1995 pub const TCIFLUSH: c_int = 0;
1996 pub const TCOFLUSH: c_int = 1;
1997 pub const TCIOFLUSH: c_int = 2;
1998 pub const NL0: c_int = 0x00000000;
1999 pub const NL1: c_int = 0x00000100;
2000 pub const TAB0: c_int = 0x00000000;
2001 pub const CR0: c_int = 0x00000000;
2002 pub const FF0: c_int = 0x00000000;
2003 pub const BS0: c_int = 0x00000000;
2004 pub const VT0: c_int = 0x00000000;
2005 pub const VERASE: usize = 2;
2006 pub const VKILL: usize = 3;
2007 pub const VINTR: usize = 0;
2008 pub const VQUIT: usize = 1;
2009 pub const VLNEXT: usize = 15;
2010 pub const IGNBRK: crate::tcflag_t = 0x00000001;
2011 pub const BRKINT: crate::tcflag_t = 0x00000002;
2012 pub const IGNPAR: crate::tcflag_t = 0x00000004;
2013 pub const PARMRK: crate::tcflag_t = 0x00000008;
2014 pub const INPCK: crate::tcflag_t = 0x00000010;
2015 pub const ISTRIP: crate::tcflag_t = 0x00000020;
2016 pub const INLCR: crate::tcflag_t = 0x00000040;
2017 pub const IGNCR: crate::tcflag_t = 0x00000080;
2018 pub const ICRNL: crate::tcflag_t = 0x00000100;
2019 pub const IXANY: crate::tcflag_t = 0x00000800;
2020 pub const IMAXBEL: crate::tcflag_t = 0x00002000;
2021 pub const OPOST: crate::tcflag_t = 0x1;
2022 pub const CS5: crate::tcflag_t = 0x00000000;
2023 pub const CRTSCTS: crate::tcflag_t = 0x80000000;
2024 pub const ECHO: crate::tcflag_t = 0x00000008;
2025 pub const OCRNL: crate::tcflag_t = 0o000010;
2026 pub const ONOCR: crate::tcflag_t = 0o000020;
2027 pub const ONLRET: crate::tcflag_t = 0o000040;
2028 pub const OFILL: crate::tcflag_t = 0o000100;
2029 pub const OFDEL: crate::tcflag_t = 0o000200;
2030 
2031 pub const CLONE_VM: c_int = 0x100;
2032 pub const CLONE_FS: c_int = 0x200;
2033 pub const CLONE_FILES: c_int = 0x400;
2034 pub const CLONE_SIGHAND: c_int = 0x800;
2035 pub const CLONE_PTRACE: c_int = 0x2000;
2036 pub const CLONE_VFORK: c_int = 0x4000;
2037 pub const CLONE_PARENT: c_int = 0x8000;
2038 pub const CLONE_THREAD: c_int = 0x10000;
2039 pub const CLONE_NEWNS: c_int = 0x20000;
2040 pub const CLONE_SYSVSEM: c_int = 0x40000;
2041 pub const CLONE_SETTLS: c_int = 0x80000;
2042 pub const CLONE_PARENT_SETTID: c_int = 0x100000;
2043 pub const CLONE_CHILD_CLEARTID: c_int = 0x200000;
2044 pub const CLONE_DETACHED: c_int = 0x400000;
2045 pub const CLONE_UNTRACED: c_int = 0x800000;
2046 pub const CLONE_CHILD_SETTID: c_int = 0x01000000;
2047 pub const CLONE_NEWUTS: c_int = 0x04000000;
2048 pub const CLONE_NEWIPC: c_int = 0x08000000;
2049 pub const CLONE_NEWUSER: c_int = 0x10000000;
2050 pub const CLONE_NEWPID: c_int = 0x20000000;
2051 pub const CLONE_NEWNET: c_int = 0x40000000;
2052 pub const CLONE_IO: c_int = 0x80000000;
2053 pub const CLONE_NEWCGROUP: c_int = 0x02000000;
2054 
2055 pub const WNOHANG: c_int = 0x00000001;
2056 pub const WUNTRACED: c_int = 0x00000002;
2057 pub const WSTOPPED: c_int = WUNTRACED;
2058 pub const WEXITED: c_int = 0x00000004;
2059 pub const WCONTINUED: c_int = 0x00000008;
2060 pub const WNOWAIT: c_int = 0x01000000;
2061 
2062 // Options set using PTRACE_SETOPTIONS.
2063 pub const PTRACE_O_TRACESYSGOOD: c_int = 0x00000001;
2064 pub const PTRACE_O_TRACEFORK: c_int = 0x00000002;
2065 pub const PTRACE_O_TRACEVFORK: c_int = 0x00000004;
2066 pub const PTRACE_O_TRACECLONE: c_int = 0x00000008;
2067 pub const PTRACE_O_TRACEEXEC: c_int = 0x00000010;
2068 pub const PTRACE_O_TRACEVFORKDONE: c_int = 0x00000020;
2069 pub const PTRACE_O_TRACEEXIT: c_int = 0x00000040;
2070 pub const PTRACE_O_TRACESECCOMP: c_int = 0x00000080;
2071 pub const PTRACE_O_EXITKILL: c_int = 0x00100000;
2072 pub const PTRACE_O_SUSPEND_SECCOMP: c_int = 0x00200000;
2073 pub const PTRACE_O_MASK: c_int = 0x003000ff;
2074 
2075 // Wait extended result codes for the above trace options.
2076 pub const PTRACE_EVENT_FORK: c_int = 1;
2077 pub const PTRACE_EVENT_VFORK: c_int = 2;
2078 pub const PTRACE_EVENT_CLONE: c_int = 3;
2079 pub const PTRACE_EVENT_EXEC: c_int = 4;
2080 pub const PTRACE_EVENT_VFORK_DONE: c_int = 5;
2081 pub const PTRACE_EVENT_EXIT: c_int = 6;
2082 pub const PTRACE_EVENT_SECCOMP: c_int = 7;
2083 // PTRACE_EVENT_STOP was added to glibc in 2.26
2084 // pub const PTRACE_EVENT_STOP: c_int = 128;
2085 
2086 pub const __WNOTHREAD: c_int = 0x20000000;
2087 pub const __WALL: c_int = 0x40000000;
2088 pub const __WCLONE: c_int = 0x80000000;
2089 
2090 pub const SPLICE_F_MOVE: c_uint = 0x01;
2091 pub const SPLICE_F_NONBLOCK: c_uint = 0x02;
2092 pub const SPLICE_F_MORE: c_uint = 0x04;
2093 pub const SPLICE_F_GIFT: c_uint = 0x08;
2094 
2095 pub const RTLD_LOCAL: c_int = 0;
2096 pub const RTLD_LAZY: c_int = 1;
2097 
2098 pub const POSIX_FADV_NORMAL: c_int = 0;
2099 pub const POSIX_FADV_RANDOM: c_int = 1;
2100 pub const POSIX_FADV_SEQUENTIAL: c_int = 2;
2101 pub const POSIX_FADV_WILLNEED: c_int = 3;
2102 
2103 pub const AT_FDCWD: c_int = -100;
2104 pub const AT_SYMLINK_NOFOLLOW: c_int = 0x100;
2105 pub const AT_REMOVEDIR: c_int = 0x200;
2106 pub const AT_EACCESS: c_int = 0x200;
2107 pub const AT_SYMLINK_FOLLOW: c_int = 0x400;
2108 pub const AT_NO_AUTOMOUNT: c_int = 0x800;
2109 pub const AT_EMPTY_PATH: c_int = 0x1000;
2110 
2111 pub const LOG_CRON: c_int = 9 << 3;
2112 pub const LOG_AUTHPRIV: c_int = 10 << 3;
2113 pub const LOG_FTP: c_int = 11 << 3;
2114 pub const LOG_PERROR: c_int = 0x20;
2115 
2116 pub const PIPE_BUF: usize = 4096;
2117 
2118 pub const SI_LOAD_SHIFT: c_uint = 16;
2119 
2120 pub const CLD_EXITED: c_int = 1;
2121 pub const CLD_KILLED: c_int = 2;
2122 pub const CLD_DUMPED: c_int = 3;
2123 pub const CLD_TRAPPED: c_int = 4;
2124 pub const CLD_STOPPED: c_int = 5;
2125 pub const CLD_CONTINUED: c_int = 6;
2126 
2127 pub const SIGEV_SIGNAL: c_int = 0;
2128 pub const SIGEV_NONE: c_int = 1;
2129 pub const SIGEV_THREAD: c_int = 2;
2130 
2131 pub const P_ALL: idtype_t = 0;
2132 pub const P_PID: idtype_t = 1;
2133 pub const P_PGID: idtype_t = 2;
2134 
2135 pub const UTIME_OMIT: c_long = 1073741822;
2136 pub const UTIME_NOW: c_long = 1073741823;
2137 
2138 pub const POLLIN: c_short = 0x1;
2139 pub const POLLPRI: c_short = 0x2;
2140 pub const POLLOUT: c_short = 0x4;
2141 pub const POLLERR: c_short = 0x8;
2142 pub const POLLHUP: c_short = 0x10;
2143 pub const POLLNVAL: c_short = 0x20;
2144 pub const POLLRDNORM: c_short = 0x040;
2145 pub const POLLRDBAND: c_short = 0x080;
2146 
2147 pub const ABDAY_1: crate::nl_item = 0x20000;
2148 pub const ABDAY_2: crate::nl_item = 0x20001;
2149 pub const ABDAY_3: crate::nl_item = 0x20002;
2150 pub const ABDAY_4: crate::nl_item = 0x20003;
2151 pub const ABDAY_5: crate::nl_item = 0x20004;
2152 pub const ABDAY_6: crate::nl_item = 0x20005;
2153 pub const ABDAY_7: crate::nl_item = 0x20006;
2154 
2155 pub const DAY_1: crate::nl_item = 0x20007;
2156 pub const DAY_2: crate::nl_item = 0x20008;
2157 pub const DAY_3: crate::nl_item = 0x20009;
2158 pub const DAY_4: crate::nl_item = 0x2000A;
2159 pub const DAY_5: crate::nl_item = 0x2000B;
2160 pub const DAY_6: crate::nl_item = 0x2000C;
2161 pub const DAY_7: crate::nl_item = 0x2000D;
2162 
2163 pub const ABMON_1: crate::nl_item = 0x2000E;
2164 pub const ABMON_2: crate::nl_item = 0x2000F;
2165 pub const ABMON_3: crate::nl_item = 0x20010;
2166 pub const ABMON_4: crate::nl_item = 0x20011;
2167 pub const ABMON_5: crate::nl_item = 0x20012;
2168 pub const ABMON_6: crate::nl_item = 0x20013;
2169 pub const ABMON_7: crate::nl_item = 0x20014;
2170 pub const ABMON_8: crate::nl_item = 0x20015;
2171 pub const ABMON_9: crate::nl_item = 0x20016;
2172 pub const ABMON_10: crate::nl_item = 0x20017;
2173 pub const ABMON_11: crate::nl_item = 0x20018;
2174 pub const ABMON_12: crate::nl_item = 0x20019;
2175 
2176 pub const MON_1: crate::nl_item = 0x2001A;
2177 pub const MON_2: crate::nl_item = 0x2001B;
2178 pub const MON_3: crate::nl_item = 0x2001C;
2179 pub const MON_4: crate::nl_item = 0x2001D;
2180 pub const MON_5: crate::nl_item = 0x2001E;
2181 pub const MON_6: crate::nl_item = 0x2001F;
2182 pub const MON_7: crate::nl_item = 0x20020;
2183 pub const MON_8: crate::nl_item = 0x20021;
2184 pub const MON_9: crate::nl_item = 0x20022;
2185 pub const MON_10: crate::nl_item = 0x20023;
2186 pub const MON_11: crate::nl_item = 0x20024;
2187 pub const MON_12: crate::nl_item = 0x20025;
2188 
2189 pub const AM_STR: crate::nl_item = 0x20026;
2190 pub const PM_STR: crate::nl_item = 0x20027;
2191 
2192 pub const D_T_FMT: crate::nl_item = 0x20028;
2193 pub const D_FMT: crate::nl_item = 0x20029;
2194 pub const T_FMT: crate::nl_item = 0x2002A;
2195 pub const T_FMT_AMPM: crate::nl_item = 0x2002B;
2196 
2197 pub const ERA: crate::nl_item = 0x2002C;
2198 pub const ERA_D_FMT: crate::nl_item = 0x2002E;
2199 pub const ALT_DIGITS: crate::nl_item = 0x2002F;
2200 pub const ERA_D_T_FMT: crate::nl_item = 0x20030;
2201 pub const ERA_T_FMT: crate::nl_item = 0x20031;
2202 
2203 pub const CODESET: crate::nl_item = 14;
2204 
2205 pub const CRNCYSTR: crate::nl_item = 0x4000F;
2206 
2207 pub const RUSAGE_THREAD: c_int = 1;
2208 pub const RUSAGE_CHILDREN: c_int = -1;
2209 
2210 pub const RADIXCHAR: crate::nl_item = 0x10000;
2211 pub const THOUSEP: crate::nl_item = 0x10001;
2212 
2213 pub const YESEXPR: crate::nl_item = 0x50000;
2214 pub const NOEXPR: crate::nl_item = 0x50001;
2215 pub const YESSTR: crate::nl_item = 0x50002;
2216 pub const NOSTR: crate::nl_item = 0x50003;
2217 
2218 pub const FILENAME_MAX: c_uint = 4096;
2219 pub const L_tmpnam: c_uint = 20;
2220 pub const _PC_LINK_MAX: c_int = 0;
2221 pub const _PC_MAX_CANON: c_int = 1;
2222 pub const _PC_MAX_INPUT: c_int = 2;
2223 pub const _PC_NAME_MAX: c_int = 3;
2224 pub const _PC_PATH_MAX: c_int = 4;
2225 pub const _PC_PIPE_BUF: c_int = 5;
2226 pub const _PC_CHOWN_RESTRICTED: c_int = 6;
2227 pub const _PC_NO_TRUNC: c_int = 7;
2228 pub const _PC_VDISABLE: c_int = 8;
2229 pub const _PC_SYNC_IO: c_int = 9;
2230 pub const _PC_ASYNC_IO: c_int = 10;
2231 pub const _PC_PRIO_IO: c_int = 11;
2232 pub const _PC_SOCK_MAXBUF: c_int = 12;
2233 pub const _PC_FILESIZEBITS: c_int = 13;
2234 pub const _PC_REC_INCR_XFER_SIZE: c_int = 14;
2235 pub const _PC_REC_MAX_XFER_SIZE: c_int = 15;
2236 pub const _PC_REC_MIN_XFER_SIZE: c_int = 16;
2237 pub const _PC_REC_XFER_ALIGN: c_int = 17;
2238 pub const _PC_ALLOC_SIZE_MIN: c_int = 18;
2239 pub const _PC_SYMLINK_MAX: c_int = 19;
2240 pub const _PC_2_SYMLINKS: c_int = 20;
2241 
2242 pub const _SC_ARG_MAX: c_int = 0;
2243 pub const _SC_CHILD_MAX: c_int = 1;
2244 pub const _SC_CLK_TCK: c_int = 2;
2245 pub const _SC_NGROUPS_MAX: c_int = 3;
2246 pub const _SC_OPEN_MAX: c_int = 4;
2247 pub const _SC_STREAM_MAX: c_int = 5;
2248 pub const _SC_TZNAME_MAX: c_int = 6;
2249 pub const _SC_JOB_CONTROL: c_int = 7;
2250 pub const _SC_SAVED_IDS: c_int = 8;
2251 pub const _SC_REALTIME_SIGNALS: c_int = 9;
2252 pub const _SC_PRIORITY_SCHEDULING: c_int = 10;
2253 pub const _SC_TIMERS: c_int = 11;
2254 pub const _SC_ASYNCHRONOUS_IO: c_int = 12;
2255 pub const _SC_PRIORITIZED_IO: c_int = 13;
2256 pub const _SC_SYNCHRONIZED_IO: c_int = 14;
2257 pub const _SC_FSYNC: c_int = 15;
2258 pub const _SC_MAPPED_FILES: c_int = 16;
2259 pub const _SC_MEMLOCK: c_int = 17;
2260 pub const _SC_MEMLOCK_RANGE: c_int = 18;
2261 pub const _SC_MEMORY_PROTECTION: c_int = 19;
2262 pub const _SC_MESSAGE_PASSING: c_int = 20;
2263 pub const _SC_SEMAPHORES: c_int = 21;
2264 pub const _SC_SHARED_MEMORY_OBJECTS: c_int = 22;
2265 pub const _SC_AIO_LISTIO_MAX: c_int = 23;
2266 pub const _SC_AIO_MAX: c_int = 24;
2267 pub const _SC_AIO_PRIO_DELTA_MAX: c_int = 25;
2268 pub const _SC_DELAYTIMER_MAX: c_int = 26;
2269 pub const _SC_MQ_OPEN_MAX: c_int = 27;
2270 pub const _SC_MQ_PRIO_MAX: c_int = 28;
2271 pub const _SC_VERSION: c_int = 29;
2272 pub const _SC_PAGESIZE: c_int = 30;
2273 pub const _SC_PAGE_SIZE: c_int = _SC_PAGESIZE;
2274 pub const _SC_RTSIG_MAX: c_int = 31;
2275 pub const _SC_SEM_NSEMS_MAX: c_int = 32;
2276 pub const _SC_SEM_VALUE_MAX: c_int = 33;
2277 pub const _SC_SIGQUEUE_MAX: c_int = 34;
2278 pub const _SC_TIMER_MAX: c_int = 35;
2279 pub const _SC_BC_BASE_MAX: c_int = 36;
2280 pub const _SC_BC_DIM_MAX: c_int = 37;
2281 pub const _SC_BC_SCALE_MAX: c_int = 38;
2282 pub const _SC_BC_STRING_MAX: c_int = 39;
2283 pub const _SC_COLL_WEIGHTS_MAX: c_int = 40;
2284 pub const _SC_EXPR_NEST_MAX: c_int = 42;
2285 pub const _SC_LINE_MAX: c_int = 43;
2286 pub const _SC_RE_DUP_MAX: c_int = 44;
2287 pub const _SC_2_VERSION: c_int = 46;
2288 pub const _SC_2_C_BIND: c_int = 47;
2289 pub const _SC_2_C_DEV: c_int = 48;
2290 pub const _SC_2_FORT_DEV: c_int = 49;
2291 pub const _SC_2_FORT_RUN: c_int = 50;
2292 pub const _SC_2_SW_DEV: c_int = 51;
2293 pub const _SC_2_LOCALEDEF: c_int = 52;
2294 pub const _SC_UIO_MAXIOV: c_int = 60;
2295 pub const _SC_IOV_MAX: c_int = 60;
2296 pub const _SC_THREADS: c_int = 67;
2297 pub const _SC_THREAD_SAFE_FUNCTIONS: c_int = 68;
2298 pub const _SC_GETGR_R_SIZE_MAX: c_int = 69;
2299 pub const _SC_GETPW_R_SIZE_MAX: c_int = 70;
2300 pub const _SC_LOGIN_NAME_MAX: c_int = 71;
2301 pub const _SC_TTY_NAME_MAX: c_int = 72;
2302 pub const _SC_THREAD_DESTRUCTOR_ITERATIONS: c_int = 73;
2303 pub const _SC_THREAD_KEYS_MAX: c_int = 74;
2304 pub const _SC_THREAD_STACK_MIN: c_int = 75;
2305 pub const _SC_THREAD_THREADS_MAX: c_int = 76;
2306 pub const _SC_THREAD_ATTR_STACKADDR: c_int = 77;
2307 pub const _SC_THREAD_ATTR_STACKSIZE: c_int = 78;
2308 pub const _SC_THREAD_PRIORITY_SCHEDULING: c_int = 79;
2309 pub const _SC_THREAD_PRIO_INHERIT: c_int = 80;
2310 pub const _SC_THREAD_PRIO_PROTECT: c_int = 81;
2311 pub const _SC_THREAD_PROCESS_SHARED: c_int = 82;
2312 pub const _SC_NPROCESSORS_CONF: c_int = 83;
2313 pub const _SC_NPROCESSORS_ONLN: c_int = 84;
2314 pub const _SC_PHYS_PAGES: c_int = 85;
2315 pub const _SC_AVPHYS_PAGES: c_int = 86;
2316 pub const _SC_ATEXIT_MAX: c_int = 87;
2317 pub const _SC_PASS_MAX: c_int = 88;
2318 pub const _SC_XOPEN_VERSION: c_int = 89;
2319 pub const _SC_XOPEN_XCU_VERSION: c_int = 90;
2320 pub const _SC_XOPEN_UNIX: c_int = 91;
2321 pub const _SC_XOPEN_CRYPT: c_int = 92;
2322 pub const _SC_XOPEN_ENH_I18N: c_int = 93;
2323 pub const _SC_XOPEN_SHM: c_int = 94;
2324 pub const _SC_2_CHAR_TERM: c_int = 95;
2325 pub const _SC_2_UPE: c_int = 97;
2326 pub const _SC_XOPEN_XPG2: c_int = 98;
2327 pub const _SC_XOPEN_XPG3: c_int = 99;
2328 pub const _SC_XOPEN_XPG4: c_int = 100;
2329 pub const _SC_NZERO: c_int = 109;
2330 pub const _SC_XBS5_ILP32_OFF32: c_int = 125;
2331 pub const _SC_XBS5_ILP32_OFFBIG: c_int = 126;
2332 pub const _SC_XBS5_LP64_OFF64: c_int = 127;
2333 pub const _SC_XBS5_LPBIG_OFFBIG: c_int = 128;
2334 pub const _SC_XOPEN_LEGACY: c_int = 129;
2335 pub const _SC_XOPEN_REALTIME: c_int = 130;
2336 pub const _SC_XOPEN_REALTIME_THREADS: c_int = 131;
2337 pub const _SC_ADVISORY_INFO: c_int = 132;
2338 pub const _SC_BARRIERS: c_int = 133;
2339 pub const _SC_CLOCK_SELECTION: c_int = 137;
2340 pub const _SC_CPUTIME: c_int = 138;
2341 pub const _SC_THREAD_CPUTIME: c_int = 139;
2342 pub const _SC_MONOTONIC_CLOCK: c_int = 149;
2343 pub const _SC_READER_WRITER_LOCKS: c_int = 153;
2344 pub const _SC_SPIN_LOCKS: c_int = 154;
2345 pub const _SC_REGEXP: c_int = 155;
2346 pub const _SC_SHELL: c_int = 157;
2347 pub const _SC_SPAWN: c_int = 159;
2348 pub const _SC_SPORADIC_SERVER: c_int = 160;
2349 pub const _SC_THREAD_SPORADIC_SERVER: c_int = 161;
2350 pub const _SC_TIMEOUTS: c_int = 164;
2351 pub const _SC_TYPED_MEMORY_OBJECTS: c_int = 165;
2352 pub const _SC_2_PBS: c_int = 168;
2353 pub const _SC_2_PBS_ACCOUNTING: c_int = 169;
2354 pub const _SC_2_PBS_LOCATE: c_int = 170;
2355 pub const _SC_2_PBS_MESSAGE: c_int = 171;
2356 pub const _SC_2_PBS_TRACK: c_int = 172;
2357 pub const _SC_SYMLOOP_MAX: c_int = 173;
2358 pub const _SC_STREAMS: c_int = 174;
2359 pub const _SC_2_PBS_CHECKPOINT: c_int = 175;
2360 pub const _SC_V6_ILP32_OFF32: c_int = 176;
2361 pub const _SC_V6_ILP32_OFFBIG: c_int = 177;
2362 pub const _SC_V6_LP64_OFF64: c_int = 178;
2363 pub const _SC_V6_LPBIG_OFFBIG: c_int = 179;
2364 pub const _SC_HOST_NAME_MAX: c_int = 180;
2365 pub const _SC_TRACE: c_int = 181;
2366 pub const _SC_TRACE_EVENT_FILTER: c_int = 182;
2367 pub const _SC_TRACE_INHERIT: c_int = 183;
2368 pub const _SC_TRACE_LOG: c_int = 184;
2369 pub const _SC_IPV6: c_int = 235;
2370 pub const _SC_RAW_SOCKETS: c_int = 236;
2371 pub const _SC_V7_ILP32_OFF32: c_int = 237;
2372 pub const _SC_V7_ILP32_OFFBIG: c_int = 238;
2373 pub const _SC_V7_LP64_OFF64: c_int = 239;
2374 pub const _SC_V7_LPBIG_OFFBIG: c_int = 240;
2375 pub const _SC_SS_REPL_MAX: c_int = 241;
2376 pub const _SC_TRACE_EVENT_NAME_MAX: c_int = 242;
2377 pub const _SC_TRACE_NAME_MAX: c_int = 243;
2378 pub const _SC_TRACE_SYS_MAX: c_int = 244;
2379 pub const _SC_TRACE_USER_EVENT_MAX: c_int = 245;
2380 pub const _SC_XOPEN_STREAMS: c_int = 246;
2381 pub const _SC_THREAD_ROBUST_PRIO_INHERIT: c_int = 247;
2382 pub const _SC_THREAD_ROBUST_PRIO_PROTECT: c_int = 248;
2383 
2384 pub const RLIM_SAVED_MAX: crate::rlim_t = RLIM_INFINITY;
2385 pub const RLIM_SAVED_CUR: crate::rlim_t = RLIM_INFINITY;
2386 
2387 pub const GLOB_ERR: c_int = 1 << 0;
2388 pub const GLOB_MARK: c_int = 1 << 1;
2389 pub const GLOB_NOSORT: c_int = 1 << 2;
2390 pub const GLOB_DOOFFS: c_int = 1 << 3;
2391 pub const GLOB_NOCHECK: c_int = 1 << 4;
2392 pub const GLOB_APPEND: c_int = 1 << 5;
2393 pub const GLOB_NOESCAPE: c_int = 1 << 6;
2394 
2395 pub const GLOB_NOSPACE: c_int = 1;
2396 pub const GLOB_ABORTED: c_int = 2;
2397 pub const GLOB_NOMATCH: c_int = 3;
2398 
2399 pub const POSIX_MADV_NORMAL: c_int = 0;
2400 pub const POSIX_MADV_RANDOM: c_int = 1;
2401 pub const POSIX_MADV_SEQUENTIAL: c_int = 2;
2402 pub const POSIX_MADV_WILLNEED: c_int = 3;
2403 
2404 pub const S_IEXEC: mode_t = 0o0100;
2405 pub const S_IWRITE: mode_t = 0o0200;
2406 pub const S_IREAD: mode_t = 0o0400;
2407 
2408 pub const F_LOCK: c_int = 1;
2409 pub const F_TEST: c_int = 3;
2410 pub const F_TLOCK: c_int = 2;
2411 pub const F_ULOCK: c_int = 0;
2412 
2413 pub const IFF_LOWER_UP: c_int = 0x10000;
2414 pub const IFF_DORMANT: c_int = 0x20000;
2415 pub const IFF_ECHO: c_int = 0x40000;
2416 
2417 pub const ST_RDONLY: c_ulong = 1;
2418 pub const ST_NOSUID: c_ulong = 2;
2419 pub const ST_NODEV: c_ulong = 4;
2420 pub const ST_NOEXEC: c_ulong = 8;
2421 pub const ST_SYNCHRONOUS: c_ulong = 16;
2422 pub const ST_MANDLOCK: c_ulong = 64;
2423 pub const ST_WRITE: c_ulong = 128;
2424 pub const ST_APPEND: c_ulong = 256;
2425 pub const ST_IMMUTABLE: c_ulong = 512;
2426 pub const ST_NOATIME: c_ulong = 1024;
2427 pub const ST_NODIRATIME: c_ulong = 2048;
2428 
2429 pub const RTLD_NEXT: *mut c_void = -1i64 as *mut c_void;
2430 pub const RTLD_DEFAULT: *mut c_void = 0i64 as *mut c_void;
2431 pub const RTLD_NODELETE: c_int = 0x1000;
2432 pub const RTLD_NOW: c_int = 0x2;
2433 
2434 pub const TCP_MD5SIG: c_int = 14;
2435 
2436 pub const PTHREAD_MUTEX_INITIALIZER: pthread_mutex_t = pthread_mutex_t {
2437     size: [0; __SIZEOF_PTHREAD_MUTEX_T],
2438 };
2439 pub const PTHREAD_COND_INITIALIZER: pthread_cond_t = pthread_cond_t {
2440     size: [0; __SIZEOF_PTHREAD_COND_T],
2441 };
2442 pub const PTHREAD_RWLOCK_INITIALIZER: pthread_rwlock_t = pthread_rwlock_t {
2443     size: [0; __SIZEOF_PTHREAD_RWLOCK_T],
2444 };
2445 pub const PTHREAD_MUTEX_NORMAL: c_int = 0;
2446 pub const PTHREAD_MUTEX_RECURSIVE: c_int = 1;
2447 pub const PTHREAD_MUTEX_ERRORCHECK: c_int = 2;
2448 pub const PTHREAD_MUTEX_DEFAULT: c_int = PTHREAD_MUTEX_NORMAL;
2449 pub const PTHREAD_PROCESS_PRIVATE: c_int = 0;
2450 pub const PTHREAD_PROCESS_SHARED: c_int = 1;
2451 pub const __SIZEOF_PTHREAD_COND_T: usize = 48;
2452 
2453 pub const RENAME_NOREPLACE: c_int = 1;
2454 pub const RENAME_EXCHANGE: c_int = 2;
2455 pub const RENAME_WHITEOUT: c_int = 4;
2456 
2457 pub const SCHED_OTHER: c_int = 0;
2458 pub const SCHED_FIFO: c_int = 1;
2459 pub const SCHED_RR: c_int = 2;
2460 pub const SCHED_BATCH: c_int = 3;
2461 pub const SCHED_IDLE: c_int = 5;
2462 
2463 // netinet/in.h
2464 // NOTE: These are in addition to the constants defined in src/unix/mod.rs
2465 
2466 // IPPROTO_IP defined in src/unix/mod.rs
2467 /// Hop-by-hop option header
2468 pub const IPPROTO_HOPOPTS: c_int = 0;
2469 // IPPROTO_ICMP defined in src/unix/mod.rs
2470 /// group mgmt protocol
2471 pub const IPPROTO_IGMP: c_int = 2;
2472 /// for compatibility
2473 pub const IPPROTO_IPIP: c_int = 4;
2474 // IPPROTO_TCP defined in src/unix/mod.rs
2475 /// exterior gateway protocol
2476 pub const IPPROTO_EGP: c_int = 8;
2477 /// pup
2478 pub const IPPROTO_PUP: c_int = 12;
2479 // IPPROTO_UDP defined in src/unix/mod.rs
2480 /// xns idp
2481 pub const IPPROTO_IDP: c_int = 22;
2482 /// tp-4 w/ class negotiation
2483 pub const IPPROTO_TP: c_int = 29;
2484 /// DCCP
2485 pub const IPPROTO_DCCP: c_int = 33;
2486 // IPPROTO_IPV6 defined in src/unix/mod.rs
2487 /// IP6 routing header
2488 pub const IPPROTO_ROUTING: c_int = 43;
2489 /// IP6 fragmentation header
2490 pub const IPPROTO_FRAGMENT: c_int = 44;
2491 /// resource reservation
2492 pub const IPPROTO_RSVP: c_int = 46;
2493 /// General Routing Encap.
2494 pub const IPPROTO_GRE: c_int = 47;
2495 /// IP6 Encap Sec. Payload
2496 pub const IPPROTO_ESP: c_int = 50;
2497 /// IP6 Auth Header
2498 pub const IPPROTO_AH: c_int = 51;
2499 // IPPROTO_ICMPV6 defined in src/unix/mod.rs
2500 /// IP6 no next header
2501 pub const IPPROTO_NONE: c_int = 59;
2502 /// IP6 destination option
2503 pub const IPPROTO_DSTOPTS: c_int = 60;
2504 pub const IPPROTO_MTP: c_int = 92;
2505 pub const IPPROTO_BEETPH: c_int = 94;
2506 /// encapsulation header
2507 pub const IPPROTO_ENCAP: c_int = 98;
2508 /// Protocol indep. multicast
2509 pub const IPPROTO_PIM: c_int = 103;
2510 /// IP Payload Comp. Protocol
2511 pub const IPPROTO_COMP: c_int = 108;
2512 /// SCTP
2513 pub const IPPROTO_SCTP: c_int = 132;
2514 pub const IPPROTO_MH: c_int = 135;
2515 pub const IPPROTO_UDPLITE: c_int = 136;
2516 pub const IPPROTO_MPLS: c_int = 137;
2517 /// raw IP packet
2518 pub const IPPROTO_RAW: c_int = 255;
2519 pub const IPPROTO_MAX: c_int = 256;
2520 
2521 pub const AF_IB: c_int = 27;
2522 pub const AF_MPLS: c_int = 28;
2523 pub const AF_NFC: c_int = 39;
2524 pub const AF_VSOCK: c_int = 40;
2525 pub const PF_IB: c_int = AF_IB;
2526 pub const PF_MPLS: c_int = AF_MPLS;
2527 pub const PF_NFC: c_int = AF_NFC;
2528 pub const PF_VSOCK: c_int = AF_VSOCK;
2529 
2530 // System V IPC
2531 pub const IPC_PRIVATE: crate::key_t = 0;
2532 
2533 pub const IPC_CREAT: c_int = 0o1000;
2534 pub const IPC_EXCL: c_int = 0o2000;
2535 pub const IPC_NOWAIT: c_int = 0o4000;
2536 
2537 pub const IPC_RMID: c_int = 0;
2538 pub const IPC_SET: c_int = 1;
2539 pub const IPC_STAT: c_int = 2;
2540 pub const IPC_INFO: c_int = 3;
2541 pub const MSG_STAT: c_int = 11;
2542 pub const MSG_INFO: c_int = 12;
2543 
2544 pub const MSG_NOERROR: c_int = 0o10000;
2545 pub const MSG_EXCEPT: c_int = 0o20000;
2546 pub const MSG_COPY: c_int = 0o40000;
2547 
2548 pub const SHM_R: c_int = 0o400;
2549 pub const SHM_W: c_int = 0o200;
2550 
2551 pub const SHM_RDONLY: c_int = 0o10000;
2552 pub const SHM_RND: c_int = 0o20000;
2553 pub const SHM_REMAP: c_int = 0o40000;
2554 pub const SHM_EXEC: c_int = 0o100000;
2555 
2556 pub const SHM_LOCK: c_int = 11;
2557 pub const SHM_UNLOCK: c_int = 12;
2558 
2559 pub const SHM_HUGETLB: c_int = 0o4000;
2560 pub const SHM_NORESERVE: c_int = 0o10000;
2561 
2562 pub const EPOLLRDHUP: c_int = 0x2000;
2563 pub const EPOLLEXCLUSIVE: c_int = 0x10000000;
2564 pub const EPOLLONESHOT: c_int = 0x40000000;
2565 
2566 pub const QFMT_VFS_OLD: c_int = 1;
2567 pub const QFMT_VFS_V0: c_int = 2;
2568 pub const QFMT_VFS_V1: c_int = 4;
2569 
2570 pub const EFD_SEMAPHORE: c_int = 0x1;
2571 
2572 pub const LOG_NFACILITIES: c_int = 24;
2573 
2574 pub const SEM_FAILED: *mut crate::sem_t = 0 as *mut sem_t;
2575 
2576 pub const RB_AUTOBOOT: c_int = 0x01234567u32 as i32;
2577 pub const RB_HALT_SYSTEM: c_int = 0xcdef0123u32 as i32;
2578 pub const RB_ENABLE_CAD: c_int = 0x89abcdefu32 as i32;
2579 pub const RB_DISABLE_CAD: c_int = 0x00000000u32 as i32;
2580 pub const RB_POWER_OFF: c_int = 0x4321fedcu32 as i32;
2581 pub const RB_SW_SUSPEND: c_int = 0xd000fce2u32 as i32;
2582 pub const RB_KEXEC: c_int = 0x45584543u32 as i32;
2583 
2584 pub const AI_PASSIVE: c_int = 0x0001;
2585 pub const AI_CANONNAME: c_int = 0x0002;
2586 pub const AI_NUMERICHOST: c_int = 0x0004;
2587 pub const AI_V4MAPPED: c_int = 0x0008;
2588 pub const AI_ALL: c_int = 0x0010;
2589 pub const AI_ADDRCONFIG: c_int = 0x0020;
2590 
2591 pub const AI_NUMERICSERV: c_int = 0x0400;
2592 
2593 pub const EAI_BADFLAGS: c_int = -1;
2594 pub const EAI_NONAME: c_int = -2;
2595 pub const EAI_AGAIN: c_int = -3;
2596 pub const EAI_FAIL: c_int = -4;
2597 pub const EAI_FAMILY: c_int = -6;
2598 pub const EAI_SOCKTYPE: c_int = -7;
2599 pub const EAI_SERVICE: c_int = -8;
2600 pub const EAI_MEMORY: c_int = -10;
2601 pub const EAI_OVERFLOW: c_int = -12;
2602 
2603 pub const NI_NUMERICHOST: c_int = 1;
2604 pub const NI_NUMERICSERV: c_int = 2;
2605 pub const NI_NOFQDN: c_int = 4;
2606 pub const NI_NAMEREQD: c_int = 8;
2607 pub const NI_DGRAM: c_int = 16;
2608 
2609 pub const SYNC_FILE_RANGE_WAIT_BEFORE: c_uint = 1;
2610 pub const SYNC_FILE_RANGE_WRITE: c_uint = 2;
2611 pub const SYNC_FILE_RANGE_WAIT_AFTER: c_uint = 4;
2612 
2613 pub const EAI_SYSTEM: c_int = -11;
2614 
2615 pub const AIO_CANCELED: c_int = 0;
2616 pub const AIO_NOTCANCELED: c_int = 1;
2617 pub const AIO_ALLDONE: c_int = 2;
2618 pub const LIO_READ: c_int = 0;
2619 pub const LIO_WRITE: c_int = 1;
2620 pub const LIO_NOP: c_int = 2;
2621 pub const LIO_WAIT: c_int = 0;
2622 pub const LIO_NOWAIT: c_int = 1;
2623 
2624 pub const MREMAP_MAYMOVE: c_int = 1;
2625 pub const MREMAP_FIXED: c_int = 2;
2626 
2627 pub const PR_SET_PDEATHSIG: c_int = 1;
2628 pub const PR_GET_PDEATHSIG: c_int = 2;
2629 
2630 pub const PR_GET_DUMPABLE: c_int = 3;
2631 pub const PR_SET_DUMPABLE: c_int = 4;
2632 
2633 pub const PR_GET_UNALIGN: c_int = 5;
2634 pub const PR_SET_UNALIGN: c_int = 6;
2635 pub const PR_UNALIGN_NOPRINT: c_int = 1;
2636 pub const PR_UNALIGN_SIGBUS: c_int = 2;
2637 
2638 pub const PR_GET_KEEPCAPS: c_int = 7;
2639 pub const PR_SET_KEEPCAPS: c_int = 8;
2640 
2641 pub const PR_GET_FPEMU: c_int = 9;
2642 pub const PR_SET_FPEMU: c_int = 10;
2643 pub const PR_FPEMU_NOPRINT: c_int = 1;
2644 pub const PR_FPEMU_SIGFPE: c_int = 2;
2645 
2646 pub const PR_GET_FPEXC: c_int = 11;
2647 pub const PR_SET_FPEXC: c_int = 12;
2648 pub const PR_FP_EXC_SW_ENABLE: c_int = 0x80;
2649 pub const PR_FP_EXC_DIV: c_int = 0x010000;
2650 pub const PR_FP_EXC_OVF: c_int = 0x020000;
2651 pub const PR_FP_EXC_UND: c_int = 0x040000;
2652 pub const PR_FP_EXC_RES: c_int = 0x080000;
2653 pub const PR_FP_EXC_INV: c_int = 0x100000;
2654 pub const PR_FP_EXC_DISABLED: c_int = 0;
2655 pub const PR_FP_EXC_NONRECOV: c_int = 1;
2656 pub const PR_FP_EXC_ASYNC: c_int = 2;
2657 pub const PR_FP_EXC_PRECISE: c_int = 3;
2658 
2659 pub const PR_GET_TIMING: c_int = 13;
2660 pub const PR_SET_TIMING: c_int = 14;
2661 pub const PR_TIMING_STATISTICAL: c_int = 0;
2662 pub const PR_TIMING_TIMESTAMP: c_int = 1;
2663 
2664 pub const PR_SET_NAME: c_int = 15;
2665 pub const PR_GET_NAME: c_int = 16;
2666 
2667 pub const PR_GET_ENDIAN: c_int = 19;
2668 pub const PR_SET_ENDIAN: c_int = 20;
2669 pub const PR_ENDIAN_BIG: c_int = 0;
2670 pub const PR_ENDIAN_LITTLE: c_int = 1;
2671 pub const PR_ENDIAN_PPC_LITTLE: c_int = 2;
2672 
2673 pub const PR_GET_SECCOMP: c_int = 21;
2674 pub const PR_SET_SECCOMP: c_int = 22;
2675 
2676 pub const PR_CAPBSET_READ: c_int = 23;
2677 pub const PR_CAPBSET_DROP: c_int = 24;
2678 
2679 pub const PR_GET_TSC: c_int = 25;
2680 pub const PR_SET_TSC: c_int = 26;
2681 pub const PR_TSC_ENABLE: c_int = 1;
2682 pub const PR_TSC_SIGSEGV: c_int = 2;
2683 
2684 pub const PR_GET_SECUREBITS: c_int = 27;
2685 pub const PR_SET_SECUREBITS: c_int = 28;
2686 
2687 pub const PR_SET_TIMERSLACK: c_int = 29;
2688 pub const PR_GET_TIMERSLACK: c_int = 30;
2689 
2690 pub const PR_TASK_PERF_EVENTS_DISABLE: c_int = 31;
2691 pub const PR_TASK_PERF_EVENTS_ENABLE: c_int = 32;
2692 
2693 pub const PR_MCE_KILL: c_int = 33;
2694 pub const PR_MCE_KILL_CLEAR: c_int = 0;
2695 pub const PR_MCE_KILL_SET: c_int = 1;
2696 
2697 pub const PR_MCE_KILL_LATE: c_int = 0;
2698 pub const PR_MCE_KILL_EARLY: c_int = 1;
2699 pub const PR_MCE_KILL_DEFAULT: c_int = 2;
2700 
2701 pub const PR_MCE_KILL_GET: c_int = 34;
2702 
2703 pub const PR_SET_MM: c_int = 35;
2704 pub const PR_SET_MM_START_CODE: c_int = 1;
2705 pub const PR_SET_MM_END_CODE: c_int = 2;
2706 pub const PR_SET_MM_START_DATA: c_int = 3;
2707 pub const PR_SET_MM_END_DATA: c_int = 4;
2708 pub const PR_SET_MM_START_STACK: c_int = 5;
2709 pub const PR_SET_MM_START_BRK: c_int = 6;
2710 pub const PR_SET_MM_BRK: c_int = 7;
2711 pub const PR_SET_MM_ARG_START: c_int = 8;
2712 pub const PR_SET_MM_ARG_END: c_int = 9;
2713 pub const PR_SET_MM_ENV_START: c_int = 10;
2714 pub const PR_SET_MM_ENV_END: c_int = 11;
2715 pub const PR_SET_MM_AUXV: c_int = 12;
2716 pub const PR_SET_MM_EXE_FILE: c_int = 13;
2717 pub const PR_SET_MM_MAP: c_int = 14;
2718 pub const PR_SET_MM_MAP_SIZE: c_int = 15;
2719 
2720 pub const PR_SET_PTRACER: c_int = 0x59616d61;
2721 pub const PR_SET_PTRACER_ANY: c_ulong = 0xffffffffffffffff;
2722 
2723 pub const PR_SET_CHILD_SUBREAPER: c_int = 36;
2724 pub const PR_GET_CHILD_SUBREAPER: c_int = 37;
2725 
2726 pub const PR_SET_NO_NEW_PRIVS: c_int = 38;
2727 pub const PR_GET_NO_NEW_PRIVS: c_int = 39;
2728 
2729 pub const PR_GET_TID_ADDRESS: c_int = 40;
2730 
2731 pub const PR_SET_THP_DISABLE: c_int = 41;
2732 pub const PR_GET_THP_DISABLE: c_int = 42;
2733 
2734 pub const PR_MPX_ENABLE_MANAGEMENT: c_int = 43;
2735 pub const PR_MPX_DISABLE_MANAGEMENT: c_int = 44;
2736 
2737 pub const PR_SET_FP_MODE: c_int = 45;
2738 pub const PR_GET_FP_MODE: c_int = 46;
2739 pub const PR_FP_MODE_FR: c_int = 1 << 0;
2740 pub const PR_FP_MODE_FRE: c_int = 1 << 1;
2741 
2742 pub const PR_CAP_AMBIENT: c_int = 47;
2743 pub const PR_CAP_AMBIENT_IS_SET: c_int = 1;
2744 pub const PR_CAP_AMBIENT_RAISE: c_int = 2;
2745 pub const PR_CAP_AMBIENT_LOWER: c_int = 3;
2746 pub const PR_CAP_AMBIENT_CLEAR_ALL: c_int = 4;
2747 
2748 pub const ITIMER_REAL: c_int = 0;
2749 pub const ITIMER_VIRTUAL: c_int = 1;
2750 pub const ITIMER_PROF: c_int = 2;
2751 
2752 pub const TFD_CLOEXEC: c_int = O_CLOEXEC;
2753 pub const TFD_NONBLOCK: c_int = O_NONBLOCK;
2754 pub const TFD_TIMER_ABSTIME: c_int = 1;
2755 
2756 pub const XATTR_CREATE: c_int = 0x1;
2757 pub const XATTR_REPLACE: c_int = 0x2;
2758 
2759 pub const _POSIX_VDISABLE: crate::cc_t = 0;
2760 
2761 pub const FALLOC_FL_KEEP_SIZE: c_int = 0x01;
2762 pub const FALLOC_FL_PUNCH_HOLE: c_int = 0x02;
2763 pub const FALLOC_FL_COLLAPSE_RANGE: c_int = 0x08;
2764 pub const FALLOC_FL_ZERO_RANGE: c_int = 0x10;
2765 pub const FALLOC_FL_INSERT_RANGE: c_int = 0x20;
2766 pub const FALLOC_FL_UNSHARE_RANGE: c_int = 0x40;
2767 
2768 // On Linux, libc doesn't define this constant, libattr does instead.
2769 // We still define it for Linux as it's defined by libc on other platforms,
2770 // and it's mentioned in the man pages for getxattr and setxattr.
2771 pub const ENOATTR: c_int = crate::ENODATA;
2772 
2773 pub const SO_ORIGINAL_DST: c_int = 80;
2774 pub const IUTF8: crate::tcflag_t = 0x00004000;
2775 pub const CMSPAR: crate::tcflag_t = 0o10000000000;
2776 
2777 pub const MFD_CLOEXEC: c_uint = 0x0001;
2778 pub const MFD_ALLOW_SEALING: c_uint = 0x0002;
2779 
2780 // these are used in the p_type field of Elf32_Phdr and Elf64_Phdr, which has
2781 // the type Elf32Word and Elf64Word respectively. Luckily, both of those are u32
2782 // so we can use that type here to avoid having to cast.
2783 pub const PT_NULL: u32 = 0;
2784 pub const PT_LOAD: u32 = 1;
2785 pub const PT_DYNAMIC: u32 = 2;
2786 pub const PT_INTERP: u32 = 3;
2787 pub const PT_NOTE: u32 = 4;
2788 pub const PT_SHLIB: u32 = 5;
2789 pub const PT_PHDR: u32 = 6;
2790 pub const PT_TLS: u32 = 7;
2791 pub const PT_NUM: u32 = 8;
2792 pub const PT_LOOS: u32 = 0x60000000;
2793 pub const PT_GNU_EH_FRAME: u32 = 0x6474e550;
2794 pub const PT_GNU_STACK: u32 = 0x6474e551;
2795 pub const PT_GNU_RELRO: u32 = 0x6474e552;
2796 
2797 // Ethernet protocol IDs.
2798 pub const ETH_P_LOOP: c_int = 0x0060;
2799 pub const ETH_P_PUP: c_int = 0x0200;
2800 pub const ETH_P_PUPAT: c_int = 0x0201;
2801 pub const ETH_P_IP: c_int = 0x0800;
2802 pub const ETH_P_X25: c_int = 0x0805;
2803 pub const ETH_P_ARP: c_int = 0x0806;
2804 pub const ETH_P_BPQ: c_int = 0x08FF;
2805 pub const ETH_P_IEEEPUP: c_int = 0x0a00;
2806 pub const ETH_P_IEEEPUPAT: c_int = 0x0a01;
2807 pub const ETH_P_BATMAN: c_int = 0x4305;
2808 pub const ETH_P_DEC: c_int = 0x6000;
2809 pub const ETH_P_DNA_DL: c_int = 0x6001;
2810 pub const ETH_P_DNA_RC: c_int = 0x6002;
2811 pub const ETH_P_DNA_RT: c_int = 0x6003;
2812 pub const ETH_P_LAT: c_int = 0x6004;
2813 pub const ETH_P_DIAG: c_int = 0x6005;
2814 pub const ETH_P_CUST: c_int = 0x6006;
2815 pub const ETH_P_SCA: c_int = 0x6007;
2816 pub const ETH_P_TEB: c_int = 0x6558;
2817 pub const ETH_P_RARP: c_int = 0x8035;
2818 pub const ETH_P_ATALK: c_int = 0x809B;
2819 pub const ETH_P_AARP: c_int = 0x80F3;
2820 pub const ETH_P_8021Q: c_int = 0x8100;
2821 pub const ETH_P_IPX: c_int = 0x8137;
2822 pub const ETH_P_IPV6: c_int = 0x86DD;
2823 pub const ETH_P_PAUSE: c_int = 0x8808;
2824 pub const ETH_P_SLOW: c_int = 0x8809;
2825 pub const ETH_P_WCCP: c_int = 0x883E;
2826 pub const ETH_P_MPLS_UC: c_int = 0x8847;
2827 pub const ETH_P_MPLS_MC: c_int = 0x8848;
2828 pub const ETH_P_ATMMPOA: c_int = 0x884c;
2829 pub const ETH_P_PPP_DISC: c_int = 0x8863;
2830 pub const ETH_P_PPP_SES: c_int = 0x8864;
2831 pub const ETH_P_LINK_CTL: c_int = 0x886c;
2832 pub const ETH_P_ATMFATE: c_int = 0x8884;
2833 pub const ETH_P_PAE: c_int = 0x888E;
2834 pub const ETH_P_AOE: c_int = 0x88A2;
2835 pub const ETH_P_8021AD: c_int = 0x88A8;
2836 pub const ETH_P_802_EX1: c_int = 0x88B5;
2837 pub const ETH_P_TIPC: c_int = 0x88CA;
2838 pub const ETH_P_8021AH: c_int = 0x88E7;
2839 pub const ETH_P_MVRP: c_int = 0x88F5;
2840 pub const ETH_P_1588: c_int = 0x88F7;
2841 pub const ETH_P_PRP: c_int = 0x88FB;
2842 pub const ETH_P_FCOE: c_int = 0x8906;
2843 pub const ETH_P_TDLS: c_int = 0x890D;
2844 pub const ETH_P_FIP: c_int = 0x8914;
2845 pub const ETH_P_80221: c_int = 0x8917;
2846 pub const ETH_P_LOOPBACK: c_int = 0x9000;
2847 pub const ETH_P_QINQ1: c_int = 0x9100;
2848 pub const ETH_P_QINQ2: c_int = 0x9200;
2849 pub const ETH_P_QINQ3: c_int = 0x9300;
2850 pub const ETH_P_EDSA: c_int = 0xDADA;
2851 pub const ETH_P_AF_IUCV: c_int = 0xFBFB;
2852 
2853 pub const ETH_P_802_3_MIN: c_int = 0x0600;
2854 
2855 pub const ETH_P_802_3: c_int = 0x0001;
2856 pub const ETH_P_AX25: c_int = 0x0002;
2857 pub const ETH_P_ALL: c_int = 0x0003;
2858 pub const ETH_P_802_2: c_int = 0x0004;
2859 pub const ETH_P_SNAP: c_int = 0x0005;
2860 pub const ETH_P_DDCMP: c_int = 0x0006;
2861 pub const ETH_P_WAN_PPP: c_int = 0x0007;
2862 pub const ETH_P_PPP_MP: c_int = 0x0008;
2863 pub const ETH_P_LOCALTALK: c_int = 0x0009;
2864 pub const ETH_P_CAN: c_int = 0x000C;
2865 pub const ETH_P_CANFD: c_int = 0x000D;
2866 pub const ETH_P_PPPTALK: c_int = 0x0010;
2867 pub const ETH_P_TR_802_2: c_int = 0x0011;
2868 pub const ETH_P_MOBITEX: c_int = 0x0015;
2869 pub const ETH_P_CONTROL: c_int = 0x0016;
2870 pub const ETH_P_IRDA: c_int = 0x0017;
2871 pub const ETH_P_ECONET: c_int = 0x0018;
2872 pub const ETH_P_HDLC: c_int = 0x0019;
2873 pub const ETH_P_ARCNET: c_int = 0x001A;
2874 pub const ETH_P_DSA: c_int = 0x001B;
2875 pub const ETH_P_TRAILER: c_int = 0x001C;
2876 pub const ETH_P_PHONET: c_int = 0x00F5;
2877 pub const ETH_P_IEEE802154: c_int = 0x00F6;
2878 pub const ETH_P_CAIF: c_int = 0x00F7;
2879 
2880 pub const SFD_CLOEXEC: c_int = 0x080000;
2881 
2882 pub const NCCS: usize = 32;
2883 
2884 pub const O_TRUNC: c_int = 0x00040000;
2885 pub const O_NOATIME: c_int = 0x00002000;
2886 pub const O_CLOEXEC: c_int = 0x00000100;
2887 pub const O_TMPFILE: c_int = 0x00004000;
2888 
2889 pub const EBFONT: c_int = 59;
2890 pub const ENOSTR: c_int = 60;
2891 pub const ENODATA: c_int = 61;
2892 pub const ETIME: c_int = 62;
2893 pub const ENOSR: c_int = 63;
2894 pub const ENONET: c_int = 64;
2895 pub const ENOPKG: c_int = 65;
2896 pub const EREMOTE: c_int = 66;
2897 pub const ENOLINK: c_int = 67;
2898 pub const EADV: c_int = 68;
2899 pub const ESRMNT: c_int = 69;
2900 pub const ECOMM: c_int = 70;
2901 pub const EPROTO: c_int = 71;
2902 pub const EDOTDOT: c_int = 73;
2903 
2904 pub const SA_NODEFER: c_int = 0x40000000;
2905 pub const SA_RESETHAND: c_int = 0x80000000;
2906 pub const SA_RESTART: c_int = 0x10000000;
2907 pub const SA_NOCLDSTOP: c_int = 0x00000001;
2908 
2909 pub const EPOLL_CLOEXEC: c_int = 0x80000;
2910 
2911 pub const EFD_CLOEXEC: c_int = 0x80000;
2912 
2913 pub const BUFSIZ: c_uint = 1024;
2914 pub const TMP_MAX: c_uint = 10000;
2915 pub const FOPEN_MAX: c_uint = 1000;
2916 pub const O_PATH: c_int = 0x00400000;
2917 pub const O_EXEC: c_int = O_PATH;
2918 pub const O_SEARCH: c_int = O_PATH;
2919 pub const O_ACCMODE: c_int = 03 | O_SEARCH;
2920 pub const O_NDELAY: c_int = O_NONBLOCK;
2921 pub const NI_MAXHOST: crate::socklen_t = 255;
2922 pub const PTHREAD_STACK_MIN: size_t = 2048;
2923 pub const POSIX_FADV_DONTNEED: c_int = 4;
2924 pub const POSIX_FADV_NOREUSE: c_int = 5;
2925 
2926 pub const POSIX_MADV_DONTNEED: c_int = 4;
2927 
2928 pub const RLIM_INFINITY: crate::rlim_t = !0;
2929 pub const RLIMIT_RTTIME: c_int = 15;
2930 #[deprecated(since = "0.2.64", note = "Not stable across OS versions")]
2931 pub const RLIMIT_NLIMITS: c_int = 16;
2932 #[allow(deprecated)]
2933 #[deprecated(since = "0.2.64", note = "Not stable across OS versions")]
2934 pub const RLIM_NLIMITS: c_int = RLIMIT_NLIMITS;
2935 
2936 pub const MAP_ANONYMOUS: c_int = MAP_ANON;
2937 
2938 pub const SOCK_DCCP: c_int = 6;
2939 pub const SOCK_PACKET: c_int = 10;
2940 
2941 pub const TCP_COOKIE_TRANSACTIONS: c_int = 15;
2942 pub const TCP_THIN_LINEAR_TIMEOUTS: c_int = 16;
2943 pub const TCP_THIN_DUPACK: c_int = 17;
2944 pub const TCP_USER_TIMEOUT: c_int = 18;
2945 pub const TCP_REPAIR: c_int = 19;
2946 pub const TCP_REPAIR_QUEUE: c_int = 20;
2947 pub const TCP_QUEUE_SEQ: c_int = 21;
2948 pub const TCP_REPAIR_OPTIONS: c_int = 22;
2949 pub const TCP_FASTOPEN: c_int = 23;
2950 pub const TCP_TIMESTAMP: c_int = 24;
2951 
2952 pub const SIGUNUSED: c_int = crate::SIGSYS;
2953 
2954 pub const __SIZEOF_PTHREAD_CONDATTR_T: usize = 4;
2955 pub const __SIZEOF_PTHREAD_MUTEXATTR_T: usize = 4;
2956 pub const __SIZEOF_PTHREAD_RWLOCKATTR_T: usize = 8;
2957 
2958 pub const CPU_SETSIZE: c_int = 128;
2959 
2960 pub const PTRACE_TRACEME: c_int = 0;
2961 pub const PTRACE_PEEKTEXT: c_int = 1;
2962 pub const PTRACE_PEEKDATA: c_int = 2;
2963 pub const PTRACE_PEEKUSER: c_int = 3;
2964 pub const PTRACE_POKETEXT: c_int = 4;
2965 pub const PTRACE_POKEDATA: c_int = 5;
2966 pub const PTRACE_POKEUSER: c_int = 6;
2967 pub const PTRACE_CONT: c_int = 7;
2968 pub const PTRACE_KILL: c_int = 8;
2969 pub const PTRACE_SINGLESTEP: c_int = 9;
2970 pub const PTRACE_GETREGS: c_int = 12;
2971 pub const PTRACE_SETREGS: c_int = 13;
2972 pub const PTRACE_GETFPREGS: c_int = 14;
2973 pub const PTRACE_SETFPREGS: c_int = 15;
2974 pub const PTRACE_ATTACH: c_int = 16;
2975 pub const PTRACE_DETACH: c_int = 17;
2976 pub const PTRACE_GETFPXREGS: c_int = 18;
2977 pub const PTRACE_SETFPXREGS: c_int = 19;
2978 pub const PTRACE_SYSCALL: c_int = 24;
2979 pub const PTRACE_SETOPTIONS: c_int = 0x4200;
2980 pub const PTRACE_GETEVENTMSG: c_int = 0x4201;
2981 pub const PTRACE_GETSIGINFO: c_int = 0x4202;
2982 pub const PTRACE_SETSIGINFO: c_int = 0x4203;
2983 pub const PTRACE_GETREGSET: c_int = 0x4204;
2984 pub const PTRACE_SETREGSET: c_int = 0x4205;
2985 pub const PTRACE_SEIZE: c_int = 0x4206;
2986 pub const PTRACE_INTERRUPT: c_int = 0x4207;
2987 pub const PTRACE_LISTEN: c_int = 0x4208;
2988 pub const PTRACE_PEEKSIGINFO: c_int = 0x4209;
2989 
2990 pub const EPOLLWAKEUP: c_int = 0x20000000;
2991 
2992 pub const EFD_NONBLOCK: c_int = crate::O_NONBLOCK;
2993 
2994 pub const SFD_NONBLOCK: c_int = crate::O_NONBLOCK;
2995 
2996 pub const TCSANOW: c_int = 0;
2997 pub const TCSADRAIN: c_int = 1;
2998 pub const TCSAFLUSH: c_int = 2;
2999 
3000 pub const TIOCINQ: c_int = crate::FIONREAD;
3001 
3002 pub const RTLD_GLOBAL: c_int = 0x100;
3003 pub const RTLD_NOLOAD: c_int = 0x4;
3004 
3005 pub const MCL_CURRENT: c_int = 0x0001;
3006 pub const MCL_FUTURE: c_int = 0x0002;
3007 
3008 pub const CBAUD: crate::tcflag_t = 0o0010017;
3009 pub const TAB1: c_int = 0x00000800;
3010 pub const TAB2: c_int = 0x00001000;
3011 pub const TAB3: c_int = 0x00001800;
3012 pub const CR1: c_int = 0x00000200;
3013 pub const CR2: c_int = 0x00000400;
3014 pub const CR3: c_int = 0x00000600;
3015 pub const FF1: c_int = 0x00008000;
3016 pub const BS1: c_int = 0x00002000;
3017 pub const VT1: c_int = 0x00004000;
3018 pub const VWERASE: usize = 14;
3019 pub const VREPRINT: usize = 12;
3020 pub const VSUSP: usize = 10;
3021 pub const VSTART: usize = 8;
3022 pub const VSTOP: usize = 9;
3023 pub const VDISCARD: usize = 13;
3024 pub const VTIME: usize = 5;
3025 pub const IXON: crate::tcflag_t = 0x00000400;
3026 pub const IXOFF: crate::tcflag_t = 0x00001000;
3027 pub const ONLCR: crate::tcflag_t = 0x4;
3028 pub const CSIZE: crate::tcflag_t = 0x00000030;
3029 pub const CS6: crate::tcflag_t = 0x00000010;
3030 pub const CS7: crate::tcflag_t = 0x00000020;
3031 pub const CS8: crate::tcflag_t = 0x00000030;
3032 pub const CSTOPB: crate::tcflag_t = 0x00000040;
3033 pub const CREAD: crate::tcflag_t = 0x00000080;
3034 pub const PARENB: crate::tcflag_t = 0x00000100;
3035 pub const PARODD: crate::tcflag_t = 0x00000200;
3036 pub const HUPCL: crate::tcflag_t = 0x00000400;
3037 pub const CLOCAL: crate::tcflag_t = 0x00000800;
3038 pub const ECHOKE: crate::tcflag_t = 0x00000800;
3039 pub const ECHOE: crate::tcflag_t = 0x00000010;
3040 pub const ECHOK: crate::tcflag_t = 0x00000020;
3041 pub const ECHONL: crate::tcflag_t = 0x00000040;
3042 pub const ECHOPRT: crate::tcflag_t = 0x00000400;
3043 pub const ECHOCTL: crate::tcflag_t = 0x00000200;
3044 pub const ISIG: crate::tcflag_t = 0x00000001;
3045 pub const ICANON: crate::tcflag_t = 0x00000002;
3046 pub const PENDIN: crate::tcflag_t = 0x00004000;
3047 pub const NOFLSH: crate::tcflag_t = 0x00000080;
3048 pub const CIBAUD: crate::tcflag_t = 0o02003600000;
3049 pub const CBAUDEX: crate::tcflag_t = 0o010000;
3050 pub const VSWTC: usize = 7;
3051 pub const OLCUC: crate::tcflag_t = 0o000002;
3052 pub const NLDLY: crate::tcflag_t = 0o000400;
3053 pub const CRDLY: crate::tcflag_t = 0o003000;
3054 pub const TABDLY: crate::tcflag_t = 0o014000;
3055 pub const BSDLY: crate::tcflag_t = 0o020000;
3056 pub const FFDLY: crate::tcflag_t = 0o100000;
3057 pub const VTDLY: crate::tcflag_t = 0o040000;
3058 pub const XTABS: crate::tcflag_t = 0o014000;
3059 
3060 pub const B0: crate::speed_t = 0o000000;
3061 pub const B50: crate::speed_t = 0o000001;
3062 pub const B75: crate::speed_t = 0o000002;
3063 pub const B110: crate::speed_t = 0o000003;
3064 pub const B134: crate::speed_t = 0o000004;
3065 pub const B150: crate::speed_t = 0o000005;
3066 pub const B200: crate::speed_t = 0o000006;
3067 pub const B300: crate::speed_t = 0o000007;
3068 pub const B600: crate::speed_t = 0o000010;
3069 pub const B1200: crate::speed_t = 0o000011;
3070 pub const B1800: crate::speed_t = 0o000012;
3071 pub const B2400: crate::speed_t = 0o000013;
3072 pub const B4800: crate::speed_t = 0o000014;
3073 pub const B9600: crate::speed_t = 0o000015;
3074 pub const B19200: crate::speed_t = 0o000016;
3075 pub const B38400: crate::speed_t = 0o000017;
3076 pub const EXTA: crate::speed_t = B19200;
3077 pub const EXTB: crate::speed_t = B38400;
3078 pub const B57600: crate::speed_t = 0o010001;
3079 pub const B115200: crate::speed_t = 0o010002;
3080 pub const B230400: crate::speed_t = 0o010003;
3081 pub const B460800: crate::speed_t = 0o010004;
3082 pub const B500000: crate::speed_t = 0o010005;
3083 pub const B576000: crate::speed_t = 0o010006;
3084 pub const B921600: crate::speed_t = 0o010007;
3085 pub const B1000000: crate::speed_t = 0o010010;
3086 pub const B1152000: crate::speed_t = 0o010011;
3087 pub const B1500000: crate::speed_t = 0o010012;
3088 pub const B2000000: crate::speed_t = 0o010013;
3089 pub const B2500000: crate::speed_t = 0o010014;
3090 pub const B3000000: crate::speed_t = 0o010015;
3091 pub const B3500000: crate::speed_t = 0o010016;
3092 pub const B4000000: crate::speed_t = 0o010017;
3093 
3094 pub const SO_BINDTODEVICE: c_int = 25;
3095 pub const SO_TIMESTAMP: c_int = 29;
3096 pub const SO_MARK: c_int = 36;
3097 pub const SO_RXQ_OVFL: c_int = 40;
3098 pub const SO_PEEK_OFF: c_int = 42;
3099 pub const SO_BUSY_POLL: c_int = 46;
3100 pub const SO_BINDTOIFINDEX: c_int = 62;
3101 
3102 pub const __SIZEOF_PTHREAD_RWLOCK_T: usize = 56;
3103 pub const __SIZEOF_PTHREAD_MUTEX_T: usize = 40;
3104 
3105 pub const O_ASYNC: c_int = 0x00000400;
3106 
3107 pub const FIOCLEX: c_int = 0x5451;
3108 pub const FIONBIO: c_int = 0x5421;
3109 
3110 pub const RLIMIT_RSS: c_int = 5;
3111 pub const RLIMIT_NOFILE: c_int = 7;
3112 pub const RLIMIT_AS: c_int = 9;
3113 pub const RLIMIT_NPROC: c_int = 6;
3114 pub const RLIMIT_MEMLOCK: c_int = 8;
3115 
3116 pub const O_APPEND: c_int = 0x00100000;
3117 pub const O_CREAT: c_int = 0x00010000;
3118 pub const O_EXCL: c_int = 0x00020000;
3119 pub const O_NOCTTY: c_int = 0x00000200;
3120 pub const O_NONBLOCK: c_int = 0x00000010;
3121 pub const O_SYNC: c_int = 0x00000040 | O_DSYNC;
3122 pub const O_RSYNC: c_int = O_SYNC;
3123 pub const O_DSYNC: c_int = 0x00000020;
3124 
3125 pub const SOCK_CLOEXEC: c_int = 0o2000000;
3126 pub const SOCK_NONBLOCK: c_int = 0o4000;
3127 
3128 pub const MAP_ANON: c_int = 0x0020;
3129 pub const MAP_GROWSDOWN: c_int = 0x0100;
3130 pub const MAP_DENYWRITE: c_int = 0x0800;
3131 pub const MAP_EXECUTABLE: c_int = 0x01000;
3132 pub const MAP_LOCKED: c_int = 0x02000;
3133 pub const MAP_NORESERVE: c_int = 0x04000;
3134 pub const MAP_POPULATE: c_int = 0x08000;
3135 pub const MAP_NONBLOCK: c_int = 0x010000;
3136 pub const MAP_STACK: c_int = 0x020000;
3137 
3138 pub const SOCK_STREAM: c_int = 1;
3139 pub const SOCK_DGRAM: c_int = 2;
3140 pub const SOCK_SEQPACKET: c_int = 5;
3141 
3142 pub const SOL_SOCKET: c_int = 1;
3143 
3144 pub const EDEADLK: c_int = 35;
3145 pub const ENAMETOOLONG: c_int = 36;
3146 pub const ENOLCK: c_int = 37;
3147 pub const ENOSYS: c_int = 38;
3148 pub const ENOTEMPTY: c_int = 39;
3149 pub const ELOOP: c_int = 40;
3150 pub const ENOMSG: c_int = 42;
3151 pub const EIDRM: c_int = 43;
3152 pub const ECHRNG: c_int = 44;
3153 pub const EL2NSYNC: c_int = 45;
3154 pub const EL3HLT: c_int = 46;
3155 pub const EL3RST: c_int = 47;
3156 pub const ELNRNG: c_int = 48;
3157 pub const EUNATCH: c_int = 49;
3158 pub const ENOCSI: c_int = 50;
3159 pub const EL2HLT: c_int = 51;
3160 pub const EBADE: c_int = 52;
3161 pub const EBADR: c_int = 53;
3162 pub const EXFULL: c_int = 54;
3163 pub const ENOANO: c_int = 55;
3164 pub const EBADRQC: c_int = 56;
3165 pub const EBADSLT: c_int = 57;
3166 pub const EDEADLOCK: c_int = EDEADLK;
3167 pub const EMULTIHOP: c_int = 72;
3168 pub const EBADMSG: c_int = 74;
3169 pub const EOVERFLOW: c_int = 75;
3170 pub const ENOTUNIQ: c_int = 76;
3171 pub const EBADFD: c_int = 77;
3172 pub const EREMCHG: c_int = 78;
3173 pub const ELIBACC: c_int = 79;
3174 pub const ELIBBAD: c_int = 80;
3175 pub const ELIBSCN: c_int = 81;
3176 pub const ELIBMAX: c_int = 82;
3177 pub const ELIBEXEC: c_int = 83;
3178 pub const EILSEQ: c_int = 84;
3179 pub const ERESTART: c_int = 85;
3180 pub const ESTRPIPE: c_int = 86;
3181 pub const EUSERS: c_int = 87;
3182 pub const ENOTSOCK: c_int = 88;
3183 pub const EDESTADDRREQ: c_int = 89;
3184 pub const EMSGSIZE: c_int = 90;
3185 pub const EPROTOTYPE: c_int = 91;
3186 pub const ENOPROTOOPT: c_int = 92;
3187 pub const EPROTONOSUPPORT: c_int = 93;
3188 pub const ESOCKTNOSUPPORT: c_int = 94;
3189 pub const EOPNOTSUPP: c_int = 95;
3190 pub const ENOTSUP: c_int = EOPNOTSUPP;
3191 pub const EPFNOSUPPORT: c_int = 96;
3192 pub const EAFNOSUPPORT: c_int = 97;
3193 pub const EADDRINUSE: c_int = 98;
3194 pub const EADDRNOTAVAIL: c_int = 99;
3195 pub const ENETDOWN: c_int = 100;
3196 pub const ENETUNREACH: c_int = 101;
3197 pub const ENETRESET: c_int = 102;
3198 pub const ECONNABORTED: c_int = 103;
3199 pub const ECONNRESET: c_int = 104;
3200 pub const ENOBUFS: c_int = 105;
3201 pub const EISCONN: c_int = 106;
3202 pub const ENOTCONN: c_int = 107;
3203 pub const ESHUTDOWN: c_int = 108;
3204 pub const ETOOMANYREFS: c_int = 109;
3205 pub const ETIMEDOUT: c_int = 110;
3206 pub const ECONNREFUSED: c_int = 111;
3207 pub const EHOSTDOWN: c_int = 112;
3208 pub const EHOSTUNREACH: c_int = 113;
3209 pub const EALREADY: c_int = 114;
3210 pub const EINPROGRESS: c_int = 115;
3211 pub const ESTALE: c_int = 116;
3212 pub const EUCLEAN: c_int = 117;
3213 pub const ENOTNAM: c_int = 118;
3214 pub const ENAVAIL: c_int = 119;
3215 pub const EISNAM: c_int = 120;
3216 pub const EREMOTEIO: c_int = 121;
3217 pub const EDQUOT: c_int = 122;
3218 pub const ENOMEDIUM: c_int = 123;
3219 pub const EMEDIUMTYPE: c_int = 124;
3220 pub const ECANCELED: c_int = 125;
3221 pub const ENOKEY: c_int = 126;
3222 pub const EKEYEXPIRED: c_int = 127;
3223 pub const EKEYREVOKED: c_int = 128;
3224 pub const EKEYREJECTED: c_int = 129;
3225 pub const EOWNERDEAD: c_int = 130;
3226 pub const ENOTRECOVERABLE: c_int = 131;
3227 pub const ERFKILL: c_int = 132;
3228 pub const EHWPOISON: c_int = 133;
3229 
3230 pub const SO_REUSEADDR: c_int = 2;
3231 pub const SO_TYPE: c_int = 3;
3232 pub const SO_ERROR: c_int = 4;
3233 pub const SO_DONTROUTE: c_int = 5;
3234 pub const SO_BROADCAST: c_int = 6;
3235 pub const SO_SNDBUF: c_int = 7;
3236 pub const SO_RCVBUF: c_int = 8;
3237 pub const SO_KEEPALIVE: c_int = 9;
3238 pub const SO_OOBINLINE: c_int = 10;
3239 pub const SO_NO_CHECK: c_int = 11;
3240 pub const SO_PRIORITY: c_int = 12;
3241 pub const SO_LINGER: c_int = 13;
3242 pub const SO_BSDCOMPAT: c_int = 14;
3243 pub const SO_REUSEPORT: c_int = 15;
3244 pub const SO_PASSCRED: c_int = 16;
3245 pub const SO_PEERCRED: c_int = 17;
3246 pub const SO_RCVLOWAT: c_int = 18;
3247 pub const SO_SNDLOWAT: c_int = 19;
3248 pub const SO_RCVTIMEO: c_int = 20;
3249 pub const SO_SNDTIMEO: c_int = 21;
3250 pub const SO_ACCEPTCONN: c_int = 30;
3251 pub const SO_SNDBUFFORCE: c_int = 32;
3252 pub const SO_RCVBUFFORCE: c_int = 33;
3253 pub const SO_PROTOCOL: c_int = 38;
3254 pub const SO_DOMAIN: c_int = 39;
3255 
3256 pub const SA_ONSTACK: c_int = 0x08000000;
3257 pub const SA_SIGINFO: c_int = 0x00000004;
3258 pub const SA_NOCLDWAIT: c_int = 0x00000002;
3259 
3260 pub const SIGCHLD: c_int = 17;
3261 pub const SIGBUS: c_int = 7;
3262 pub const SIGTTIN: c_int = 21;
3263 pub const SIGTTOU: c_int = 22;
3264 pub const SIGXCPU: c_int = 24;
3265 pub const SIGXFSZ: c_int = 25;
3266 pub const SIGVTALRM: c_int = 26;
3267 pub const SIGPROF: c_int = 27;
3268 pub const SIGWINCH: c_int = 28;
3269 pub const SIGUSR1: c_int = 10;
3270 pub const SIGUSR2: c_int = 12;
3271 pub const SIGCONT: c_int = 18;
3272 pub const SIGSTOP: c_int = 19;
3273 pub const SIGTSTP: c_int = 20;
3274 pub const SIGURG: c_int = 23;
3275 pub const SIGIO: c_int = 29;
3276 pub const SIGSYS: c_int = 31;
3277 pub const SIGSTKFLT: c_int = 16;
3278 pub const SIGPOLL: c_int = 29;
3279 pub const SIGPWR: c_int = 30;
3280 pub const SIG_SETMASK: c_int = 2;
3281 pub const SIG_BLOCK: c_int = 0x000000;
3282 pub const SIG_UNBLOCK: c_int = 0x01;
3283 
3284 pub const EXTPROC: crate::tcflag_t = 0x00010000;
3285 
3286 pub const MAP_HUGETLB: c_int = 0x040000;
3287 
3288 pub const F_GETLK: c_int = 5;
3289 pub const F_GETOWN: c_int = 9;
3290 pub const F_SETLK: c_int = 6;
3291 pub const F_SETLKW: c_int = 7;
3292 pub const F_SETOWN: c_int = 8;
3293 
3294 pub const VEOF: usize = 4;
3295 pub const VEOL: usize = 11;
3296 pub const VEOL2: usize = 16;
3297 pub const VMIN: usize = 6;
3298 pub const IEXTEN: crate::tcflag_t = 0x00008000;
3299 pub const TOSTOP: crate::tcflag_t = 0x00000100;
3300 pub const FLUSHO: crate::tcflag_t = 0x00001000;
3301 
3302 pub const TCGETS: c_int = 0x5401;
3303 pub const TCSETS: c_int = 0x5402;
3304 pub const TCSETSW: c_int = 0x5403;
3305 pub const TCSETSF: c_int = 0x5404;
3306 pub const TCGETA: c_int = 0x5405;
3307 pub const TCSETA: c_int = 0x5406;
3308 pub const TCSETAW: c_int = 0x5407;
3309 pub const TCSETAF: c_int = 0x5408;
3310 pub const TCSBRK: c_int = 0x5409;
3311 pub const TCXONC: c_int = 0x540A;
3312 pub const TCFLSH: c_int = 0x540B;
3313 pub const TIOCGSOFTCAR: c_int = 0x5419;
3314 pub const TIOCSSOFTCAR: c_int = 0x541A;
3315 pub const TIOCLINUX: c_int = 0x541C;
3316 pub const TIOCGSERIAL: c_int = 0x541E;
3317 pub const TIOCEXCL: c_int = 0x540C;
3318 pub const TIOCNXCL: c_int = 0x540D;
3319 pub const TIOCSCTTY: c_int = 0x540E;
3320 pub const TIOCGPGRP: c_int = 0x540F;
3321 pub const TIOCSPGRP: c_int = 0x5410;
3322 pub const TIOCOUTQ: c_int = 0x5411;
3323 pub const TIOCSTI: c_int = 0x5412;
3324 pub const TIOCGWINSZ: c_int = 0x5413;
3325 pub const TIOCSWINSZ: c_int = 0x5414;
3326 pub const TIOCMGET: c_int = 0x5415;
3327 pub const TIOCMBIS: c_int = 0x5416;
3328 pub const TIOCMBIC: c_int = 0x5417;
3329 pub const TIOCMSET: c_int = 0x5418;
3330 pub const FIONREAD: c_int = 0x541B;
3331 pub const TIOCCONS: c_int = 0x541D;
3332 
3333 pub const POLLWRNORM: c_short = 0x100;
3334 pub const POLLWRBAND: c_short = 0x200;
3335 
3336 pub const TIOCM_LE: c_int = 0x001;
3337 pub const TIOCM_DTR: c_int = 0x002;
3338 pub const TIOCM_RTS: c_int = 0x004;
3339 pub const TIOCM_ST: c_int = 0x008;
3340 pub const TIOCM_SR: c_int = 0x010;
3341 pub const TIOCM_CTS: c_int = 0x020;
3342 pub const TIOCM_CAR: c_int = 0x040;
3343 pub const TIOCM_RNG: c_int = 0x080;
3344 pub const TIOCM_DSR: c_int = 0x100;
3345 pub const TIOCM_CD: c_int = TIOCM_CAR;
3346 pub const TIOCM_RI: c_int = TIOCM_RNG;
3347 
3348 pub const O_DIRECTORY: c_int = 0x00080000;
3349 pub const O_DIRECT: c_int = 0x00000800;
3350 pub const O_LARGEFILE: c_int = 0x00001000;
3351 pub const O_NOFOLLOW: c_int = 0x00000080;
3352 
3353 pub const HUGETLB_FLAG_ENCODE_SHIFT: u32 = 26;
3354 pub const MAP_HUGE_SHIFT: u32 = 26;
3355 
3356 // intentionally not public, only used for fd_set
3357 cfg_if! {
3358     if #[cfg(target_pointer_width = "32")] {
3359         const ULONG_SIZE: usize = 32;
3360     } else if #[cfg(target_pointer_width = "64")] {
3361         const ULONG_SIZE: usize = 64;
3362     } else {
3363         // Unknown target_pointer_width
3364     }
3365 }
3366 
3367 // END_PUB_CONST
3368 
3369 f! {
3370     pub fn FD_CLR(fd: c_int, set: *mut fd_set) -> () {
3371         let fd = fd as usize;
3372         let size = mem::size_of_val(&(*set).fds_bits[0]) * 8;
3373         (*set).fds_bits[fd / size] &= !(1 << (fd % size));
3374         return;
3375     }
3376 
3377     pub fn FD_ISSET(fd: c_int, set: *const fd_set) -> bool {
3378         let fd = fd as usize;
3379         let size = mem::size_of_val(&(*set).fds_bits[0]) * 8;
3380         return ((*set).fds_bits[fd / size] & (1 << (fd % size))) != 0;
3381     }
3382 
3383     pub fn FD_SET(fd: c_int, set: *mut fd_set) -> () {
3384         let fd = fd as usize;
3385         let size = mem::size_of_val(&(*set).fds_bits[0]) * 8;
3386         (*set).fds_bits[fd / size] |= 1 << (fd % size);
3387         return;
3388     }
3389 
3390     pub fn FD_ZERO(set: *mut fd_set) -> () {
3391         for slot in (*set).fds_bits.iter_mut() {
3392             *slot = 0;
3393         }
3394     }
3395 
3396     pub fn CPU_ZERO(cpuset: &mut cpu_set_t) -> () {
3397         for slot in cpuset.bits.iter_mut() {
3398             *slot = 0;
3399         }
3400     }
3401 
3402     pub fn CPU_SET(cpu: usize, cpuset: &mut cpu_set_t) -> () {
3403         let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc
3404         let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);
3405         cpuset.bits[idx] |= 1 << offset;
3406         ()
3407     }
3408 
3409     pub fn CPU_CLR(cpu: usize, cpuset: &mut cpu_set_t) -> () {
3410         let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc
3411         let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);
3412         cpuset.bits[idx] &= !(1 << offset);
3413         ()
3414     }
3415 
3416     pub fn CPU_ISSET(cpu: usize, cpuset: &cpu_set_t) -> bool {
3417         let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]);
3418         let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);
3419         0 != (cpuset.bits[idx] & (1 << offset))
3420     }
3421 
3422     pub fn CPU_EQUAL(set1: &cpu_set_t, set2: &cpu_set_t) -> bool {
3423         set1.bits == set2.bits
3424     }
3425 
3426     pub fn CMSG_DATA(cmsg: *const cmsghdr) -> *mut c_uchar {
3427         cmsg.offset(1) as *mut c_uchar
3428     }
3429 
3430     pub fn CMSG_NXTHDR(mhdr: *const msghdr, cmsg: *const cmsghdr) -> *mut cmsghdr {
3431         if ((*cmsg).cmsg_len as size_t) < mem::size_of::<cmsghdr>() {
3432             core::ptr::null_mut::<cmsghdr>()
3433         } else if __CMSG_NEXT(cmsg).add(mem::size_of::<cmsghdr>()) >= __MHDR_END(mhdr) {
3434             core::ptr::null_mut::<cmsghdr>()
3435         } else {
3436             __CMSG_NEXT(cmsg).cast()
3437         }
3438     }
3439 
3440     pub fn CMSG_FIRSTHDR(mhdr: *const msghdr) -> *mut cmsghdr {
3441         if (*mhdr).msg_controllen as size_t >= mem::size_of::<cmsghdr>() {
3442             (*mhdr).msg_control.cast()
3443         } else {
3444             core::ptr::null_mut::<cmsghdr>()
3445         }
3446     }
3447 
3448     pub {const} fn CMSG_ALIGN(len: size_t) -> size_t {
3449         (len + mem::size_of::<size_t>() - 1) & !(mem::size_of::<size_t>() - 1)
3450     }
3451 
3452     pub {const} fn CMSG_SPACE(len: c_uint) -> c_uint {
3453         (CMSG_ALIGN(len as size_t) + CMSG_ALIGN(mem::size_of::<cmsghdr>())) as c_uint
3454     }
3455 
3456     pub {const} fn CMSG_LEN(len: c_uint) -> c_uint {
3457         (CMSG_ALIGN(mem::size_of::<cmsghdr>()) + len as size_t) as c_uint
3458     }
3459 }
3460 
3461 safe_f! {
3462     pub {const} fn WIFSTOPPED(status: c_int) -> bool {
3463         (status & 0xff) == 0x7f
3464     }
3465 
3466     pub {const} fn WSTOPSIG(status: c_int) -> c_int {
3467         (status >> 8) & 0xff
3468     }
3469 
3470     pub {const} fn WIFCONTINUED(status: c_int) -> bool {
3471         status == 0xffff
3472     }
3473 
3474     pub {const} fn WIFSIGNALED(status: c_int) -> bool {
3475         ((status & 0x7f) + 1) as i8 >= 2
3476     }
3477 
3478     pub {const} fn WTERMSIG(status: c_int) -> c_int {
3479         status & 0x7f
3480     }
3481 
3482     pub {const} fn WIFEXITED(status: c_int) -> bool {
3483         (status & 0x7f) == 0
3484     }
3485 
3486     pub {const} fn WEXITSTATUS(status: c_int) -> c_int {
3487         (status >> 8) & 0xff
3488     }
3489 
3490     pub {const} fn WCOREDUMP(status: c_int) -> bool {
3491         (status & 0x80) != 0
3492     }
3493 
3494     pub {const} fn QCMD(cmd: c_int, type_: c_int) -> c_int {
3495         (cmd << 8) | (type_ & 0x00ff)
3496     }
3497 
3498     pub {const} fn makedev(major: c_uint, minor: c_uint) -> crate::dev_t {
3499         let major = major as crate::dev_t;
3500         let minor = minor as crate::dev_t;
3501         let mut dev = 0;
3502         dev |= (major & 0x00000fff) << 8;
3503         dev |= (major & 0xfffff000) << 32;
3504         dev |= (minor & 0x000000ff) << 0;
3505         dev |= (minor & 0xffffff00) << 12;
3506         dev
3507     }
3508 
3509     pub {const} fn major(dev: crate::dev_t) -> c_uint {
3510         let mut major = 0;
3511         major |= (dev & 0x00000000000fff00) >> 8;
3512         major |= (dev & 0xfffff00000000000) >> 32;
3513         major as c_uint
3514     }
3515 
3516     pub {const} fn minor(dev: crate::dev_t) -> c_uint {
3517         let mut minor = 0;
3518         minor |= (dev & 0x00000000000000ff) >> 0;
3519         minor |= (dev & 0x00000ffffff00000) >> 12;
3520         minor as c_uint
3521     }
3522 }
3523 
3524 fn __CMSG_LEN(cmsg: *const cmsghdr) -> ssize_t {
3525     ((unsafe { (*cmsg).cmsg_len as size_t } + mem::size_of::<c_long>() - 1)
3526         & !(mem::size_of::<c_long>() - 1)) as ssize_t
3527 }
3528 
3529 fn __CMSG_NEXT(cmsg: *const cmsghdr) -> *mut c_uchar {
3530     (unsafe { cmsg.offset(__CMSG_LEN(cmsg)) }) as *mut c_uchar
3531 }
3532 
3533 fn __MHDR_END(mhdr: *const msghdr) -> *mut c_uchar {
3534     unsafe { (*mhdr).msg_control.offset((*mhdr).msg_controllen as isize) }.cast()
3535 }
3536 
3537 // EXTERN_FN
3538 
3539 #[link(name = "c")]
3540 #[link(name = "fdio")]
3541 extern "C" {}
3542 
3543 #[cfg_attr(feature = "extra_traits", derive(Debug))]
3544 pub enum FILE {}
3545 impl Copy for FILE {}
3546 impl Clone for FILE {
3547     fn clone(&self) -> FILE {
3548         *self
3549     }
3550 }
3551 #[cfg_attr(feature = "extra_traits", derive(Debug))]
3552 pub enum fpos_t {} // FIXME(fuchsia): fill this out with a struct
3553 impl Copy for fpos_t {}
3554 impl Clone for fpos_t {
3555     fn clone(&self) -> fpos_t {
3556         *self
3557     }
3558 }
3559 
3560 extern "C" {
3561     pub fn isalnum(c: c_int) -> c_int;
3562     pub fn isalpha(c: c_int) -> c_int;
3563     pub fn iscntrl(c: c_int) -> c_int;
3564     pub fn isdigit(c: c_int) -> c_int;
3565     pub fn isgraph(c: c_int) -> c_int;
3566     pub fn islower(c: c_int) -> c_int;
3567     pub fn isprint(c: c_int) -> c_int;
3568     pub fn ispunct(c: c_int) -> c_int;
3569     pub fn isspace(c: c_int) -> c_int;
3570     pub fn isupper(c: c_int) -> c_int;
3571     pub fn isxdigit(c: c_int) -> c_int;
3572     pub fn isblank(c: c_int) -> c_int;
3573     pub fn tolower(c: c_int) -> c_int;
3574     pub fn toupper(c: c_int) -> c_int;
3575     pub fn fopen(filename: *const c_char, mode: *const c_char) -> *mut FILE;
3576     pub fn freopen(filename: *const c_char, mode: *const c_char, file: *mut FILE) -> *mut FILE;
3577     pub fn fflush(file: *mut FILE) -> c_int;
3578     pub fn fclose(file: *mut FILE) -> c_int;
3579     pub fn remove(filename: *const c_char) -> c_int;
3580     pub fn rename(oldname: *const c_char, newname: *const c_char) -> c_int;
3581     pub fn tmpfile() -> *mut FILE;
3582     pub fn setvbuf(stream: *mut FILE, buffer: *mut c_char, mode: c_int, size: size_t) -> c_int;
3583     pub fn setbuf(stream: *mut FILE, buf: *mut c_char);
3584     pub fn getchar() -> c_int;
3585     pub fn putchar(c: c_int) -> c_int;
3586     pub fn fgetc(stream: *mut FILE) -> c_int;
3587     pub fn fgets(buf: *mut c_char, n: c_int, stream: *mut FILE) -> *mut c_char;
3588     pub fn fputc(c: c_int, stream: *mut FILE) -> c_int;
3589     pub fn fputs(s: *const c_char, stream: *mut FILE) -> c_int;
3590     pub fn puts(s: *const c_char) -> c_int;
3591     pub fn ungetc(c: c_int, stream: *mut FILE) -> c_int;
3592     pub fn fread(ptr: *mut c_void, size: size_t, nobj: size_t, stream: *mut FILE) -> size_t;
3593     pub fn fwrite(ptr: *const c_void, size: size_t, nobj: size_t, stream: *mut FILE) -> size_t;
3594     pub fn fseek(stream: *mut FILE, offset: c_long, whence: c_int) -> c_int;
3595     pub fn ftell(stream: *mut FILE) -> c_long;
3596     pub fn rewind(stream: *mut FILE);
3597     pub fn fgetpos(stream: *mut FILE, ptr: *mut fpos_t) -> c_int;
3598     pub fn fsetpos(stream: *mut FILE, ptr: *const fpos_t) -> c_int;
3599     pub fn feof(stream: *mut FILE) -> c_int;
3600     pub fn ferror(stream: *mut FILE) -> c_int;
3601     pub fn perror(s: *const c_char);
3602     pub fn atof(s: *const c_char) -> c_double;
3603     pub fn atoi(s: *const c_char) -> c_int;
3604     pub fn atol(s: *const c_char) -> c_long;
3605     pub fn atoll(s: *const c_char) -> c_longlong;
3606     pub fn strtod(s: *const c_char, endp: *mut *mut c_char) -> c_double;
3607     pub fn strtof(s: *const c_char, endp: *mut *mut c_char) -> c_float;
3608     pub fn strtol(s: *const c_char, endp: *mut *mut c_char, base: c_int) -> c_long;
3609     pub fn strtoll(s: *const c_char, endp: *mut *mut c_char, base: c_int) -> c_longlong;
3610     pub fn strtoul(s: *const c_char, endp: *mut *mut c_char, base: c_int) -> c_ulong;
3611     pub fn strtoull(s: *const c_char, endp: *mut *mut c_char, base: c_int) -> c_ulonglong;
3612     pub fn calloc(nobj: size_t, size: size_t) -> *mut c_void;
3613     pub fn malloc(size: size_t) -> *mut c_void;
3614     pub fn realloc(p: *mut c_void, size: size_t) -> *mut c_void;
3615     pub fn free(p: *mut c_void);
3616     pub fn abort() -> !;
3617     pub fn exit(status: c_int) -> !;
3618     pub fn _exit(status: c_int) -> !;
3619     pub fn atexit(cb: extern "C" fn()) -> c_int;
3620     pub fn system(s: *const c_char) -> c_int;
3621     pub fn getenv(s: *const c_char) -> *mut c_char;
3622 
3623     pub fn strcpy(dst: *mut c_char, src: *const c_char) -> *mut c_char;
3624     pub fn strncpy(dst: *mut c_char, src: *const c_char, n: size_t) -> *mut c_char;
3625     pub fn strcat(s: *mut c_char, ct: *const c_char) -> *mut c_char;
3626     pub fn strncat(s: *mut c_char, ct: *const c_char, n: size_t) -> *mut c_char;
3627     pub fn strcmp(cs: *const c_char, ct: *const c_char) -> c_int;
3628     pub fn strncmp(cs: *const c_char, ct: *const c_char, n: size_t) -> c_int;
3629     pub fn strcoll(cs: *const c_char, ct: *const c_char) -> c_int;
3630     pub fn strchr(cs: *const c_char, c: c_int) -> *mut c_char;
3631     pub fn strrchr(cs: *const c_char, c: c_int) -> *mut c_char;
3632     pub fn strspn(cs: *const c_char, ct: *const c_char) -> size_t;
3633     pub fn strcspn(cs: *const c_char, ct: *const c_char) -> size_t;
3634     pub fn strdup(cs: *const c_char) -> *mut c_char;
3635     pub fn strpbrk(cs: *const c_char, ct: *const c_char) -> *mut c_char;
3636     pub fn strstr(cs: *const c_char, ct: *const c_char) -> *mut c_char;
3637     pub fn strlen(cs: *const c_char) -> size_t;
3638     pub fn strnlen(cs: *const c_char, maxlen: size_t) -> size_t;
3639     pub fn strerror(n: c_int) -> *mut c_char;
3640     pub fn strtok(s: *mut c_char, t: *const c_char) -> *mut c_char;
3641     pub fn strxfrm(s: *mut c_char, ct: *const c_char, n: size_t) -> size_t;
3642     pub fn wcslen(buf: *const wchar_t) -> size_t;
3643     pub fn wcstombs(dest: *mut c_char, src: *const wchar_t, n: size_t) -> size_t;
3644 
3645     pub fn memchr(cx: *const c_void, c: c_int, n: size_t) -> *mut c_void;
3646     pub fn wmemchr(cx: *const wchar_t, c: wchar_t, n: size_t) -> *mut wchar_t;
3647     pub fn memcmp(cx: *const c_void, ct: *const c_void, n: size_t) -> c_int;
3648     pub fn memcpy(dest: *mut c_void, src: *const c_void, n: size_t) -> *mut c_void;
3649     pub fn memmove(dest: *mut c_void, src: *const c_void, n: size_t) -> *mut c_void;
3650     pub fn memset(dest: *mut c_void, c: c_int, n: size_t) -> *mut c_void;
3651 
3652     pub fn abs(i: c_int) -> c_int;
3653     pub fn labs(i: c_long) -> c_long;
3654     pub fn rand() -> c_int;
3655     pub fn srand(seed: c_uint);
3656 
3657     pub fn getpwnam(name: *const c_char) -> *mut passwd;
3658     pub fn getpwuid(uid: crate::uid_t) -> *mut passwd;
3659 
3660     pub fn fprintf(stream: *mut crate::FILE, format: *const c_char, ...) -> c_int;
3661     pub fn printf(format: *const c_char, ...) -> c_int;
3662     pub fn snprintf(s: *mut c_char, n: size_t, format: *const c_char, ...) -> c_int;
3663     pub fn sprintf(s: *mut c_char, format: *const c_char, ...) -> c_int;
3664     pub fn fscanf(stream: *mut crate::FILE, format: *const c_char, ...) -> c_int;
3665     pub fn scanf(format: *const c_char, ...) -> c_int;
3666     pub fn sscanf(s: *const c_char, format: *const c_char, ...) -> c_int;
3667     pub fn getchar_unlocked() -> c_int;
3668     pub fn putchar_unlocked(c: c_int) -> c_int;
3669 
3670     pub fn socket(domain: c_int, ty: c_int, protocol: c_int) -> c_int;
3671     pub fn connect(socket: c_int, address: *const sockaddr, len: socklen_t) -> c_int;
3672     pub fn listen(socket: c_int, backlog: c_int) -> c_int;
3673     pub fn accept(socket: c_int, address: *mut sockaddr, address_len: *mut socklen_t) -> c_int;
3674     pub fn getpeername(socket: c_int, address: *mut sockaddr, address_len: *mut socklen_t)
3675         -> c_int;
3676     pub fn getsockname(socket: c_int, address: *mut sockaddr, address_len: *mut socklen_t)
3677         -> c_int;
3678     pub fn setsockopt(
3679         socket: c_int,
3680         level: c_int,
3681         name: c_int,
3682         value: *const c_void,
3683         option_len: socklen_t,
3684     ) -> c_int;
3685     pub fn socketpair(
3686         domain: c_int,
3687         type_: c_int,
3688         protocol: c_int,
3689         socket_vector: *mut c_int,
3690     ) -> c_int;
3691     pub fn sendto(
3692         socket: c_int,
3693         buf: *const c_void,
3694         len: size_t,
3695         flags: c_int,
3696         addr: *const sockaddr,
3697         addrlen: socklen_t,
3698     ) -> ssize_t;
3699     pub fn shutdown(socket: c_int, how: c_int) -> c_int;
3700 
3701     pub fn chmod(path: *const c_char, mode: mode_t) -> c_int;
3702     pub fn fchmod(fd: c_int, mode: mode_t) -> c_int;
3703 
3704     pub fn fstat(fildes: c_int, buf: *mut stat) -> c_int;
3705 
3706     pub fn mkdir(path: *const c_char, mode: mode_t) -> c_int;
3707 
3708     pub fn stat(path: *const c_char, buf: *mut stat) -> c_int;
3709 
3710     pub fn pclose(stream: *mut crate::FILE) -> c_int;
3711     pub fn fdopen(fd: c_int, mode: *const c_char) -> *mut crate::FILE;
3712     pub fn fileno(stream: *mut crate::FILE) -> c_int;
3713 
3714     pub fn open(path: *const c_char, oflag: c_int, ...) -> c_int;
3715     pub fn creat(path: *const c_char, mode: mode_t) -> c_int;
3716     pub fn fcntl(fd: c_int, cmd: c_int, ...) -> c_int;
3717 
3718     pub fn opendir(dirname: *const c_char) -> *mut crate::DIR;
3719     pub fn readdir(dirp: *mut crate::DIR) -> *mut crate::dirent;
3720     pub fn readdir_r(
3721         dirp: *mut crate::DIR,
3722         entry: *mut crate::dirent,
3723         result: *mut *mut crate::dirent,
3724     ) -> c_int;
3725     pub fn closedir(dirp: *mut crate::DIR) -> c_int;
3726     pub fn rewinddir(dirp: *mut crate::DIR);
3727 
3728     pub fn openat(dirfd: c_int, pathname: *const c_char, flags: c_int, ...) -> c_int;
3729     pub fn fchmodat(dirfd: c_int, pathname: *const c_char, mode: mode_t, flags: c_int) -> c_int;
3730     pub fn fchown(fd: c_int, owner: crate::uid_t, group: crate::gid_t) -> c_int;
3731     pub fn fchownat(
3732         dirfd: c_int,
3733         pathname: *const c_char,
3734         owner: crate::uid_t,
3735         group: crate::gid_t,
3736         flags: c_int,
3737     ) -> c_int;
3738     pub fn fstatat(dirfd: c_int, pathname: *const c_char, buf: *mut stat, flags: c_int) -> c_int;
3739     pub fn linkat(
3740         olddirfd: c_int,
3741         oldpath: *const c_char,
3742         newdirfd: c_int,
3743         newpath: *const c_char,
3744         flags: c_int,
3745     ) -> c_int;
3746     pub fn mkdirat(dirfd: c_int, pathname: *const c_char, mode: mode_t) -> c_int;
3747     pub fn readlinkat(
3748         dirfd: c_int,
3749         pathname: *const c_char,
3750         buf: *mut c_char,
3751         bufsiz: size_t,
3752     ) -> ssize_t;
3753     pub fn renameat(
3754         olddirfd: c_int,
3755         oldpath: *const c_char,
3756         newdirfd: c_int,
3757         newpath: *const c_char,
3758     ) -> c_int;
3759     pub fn symlinkat(target: *const c_char, newdirfd: c_int, linkpath: *const c_char) -> c_int;
3760     pub fn unlinkat(dirfd: c_int, pathname: *const c_char, flags: c_int) -> c_int;
3761 
3762     pub fn access(path: *const c_char, amode: c_int) -> c_int;
3763     pub fn alarm(seconds: c_uint) -> c_uint;
3764     pub fn chdir(dir: *const c_char) -> c_int;
3765     pub fn chown(path: *const c_char, uid: uid_t, gid: gid_t) -> c_int;
3766     pub fn lchown(path: *const c_char, uid: uid_t, gid: gid_t) -> c_int;
3767     pub fn close(fd: c_int) -> c_int;
3768     pub fn dup(fd: c_int) -> c_int;
3769     pub fn dup2(src: c_int, dst: c_int) -> c_int;
3770 
3771     pub fn execl(path: *const c_char, arg0: *const c_char, ...) -> c_int;
3772     pub fn execle(path: *const c_char, arg0: *const c_char, ...) -> c_int;
3773     pub fn execlp(file: *const c_char, arg0: *const c_char, ...) -> c_int;
3774 
3775     // DIFF(main): changed to `*const *mut` in e77f551de9
3776     pub fn execv(prog: *const c_char, argv: *const *const c_char) -> c_int;
3777     pub fn execve(
3778         prog: *const c_char,
3779         argv: *const *const c_char,
3780         envp: *const *const c_char,
3781     ) -> c_int;
3782     pub fn execvp(c: *const c_char, argv: *const *const c_char) -> c_int;
3783 
3784     pub fn fork() -> pid_t;
3785     pub fn fpathconf(filedes: c_int, name: c_int) -> c_long;
3786     pub fn getcwd(buf: *mut c_char, size: size_t) -> *mut c_char;
3787     pub fn getegid() -> gid_t;
3788     pub fn geteuid() -> uid_t;
3789     pub fn getgid() -> gid_t;
3790     pub fn getgroups(ngroups_max: c_int, groups: *mut gid_t) -> c_int;
3791     pub fn getlogin() -> *mut c_char;
3792     pub fn getopt(argc: c_int, argv: *const *mut c_char, optstr: *const c_char) -> c_int;
3793     pub fn getpgid(pid: pid_t) -> pid_t;
3794     pub fn getpgrp() -> pid_t;
3795     pub fn getpid() -> pid_t;
3796     pub fn getppid() -> pid_t;
3797     pub fn getuid() -> uid_t;
3798     pub fn isatty(fd: c_int) -> c_int;
3799     pub fn link(src: *const c_char, dst: *const c_char) -> c_int;
3800     pub fn lseek(fd: c_int, offset: off_t, whence: c_int) -> off_t;
3801     pub fn pathconf(path: *const c_char, name: c_int) -> c_long;
3802     pub fn pause() -> c_int;
3803     pub fn pipe(fds: *mut c_int) -> c_int;
3804     pub fn posix_memalign(memptr: *mut *mut c_void, align: size_t, size: size_t) -> c_int;
3805     pub fn read(fd: c_int, buf: *mut c_void, count: size_t) -> ssize_t;
3806     pub fn rmdir(path: *const c_char) -> c_int;
3807     pub fn seteuid(uid: uid_t) -> c_int;
3808     pub fn setegid(gid: gid_t) -> c_int;
3809     pub fn setgid(gid: gid_t) -> c_int;
3810     pub fn setpgid(pid: pid_t, pgid: pid_t) -> c_int;
3811     pub fn setsid() -> pid_t;
3812     pub fn setuid(uid: uid_t) -> c_int;
3813     pub fn sleep(secs: c_uint) -> c_uint;
3814     pub fn nanosleep(rqtp: *const timespec, rmtp: *mut timespec) -> c_int;
3815     pub fn tcgetpgrp(fd: c_int) -> pid_t;
3816     pub fn tcsetpgrp(fd: c_int, pgrp: crate::pid_t) -> c_int;
3817     pub fn ttyname(fd: c_int) -> *mut c_char;
3818     pub fn unlink(c: *const c_char) -> c_int;
3819     pub fn wait(status: *mut c_int) -> pid_t;
3820     pub fn waitpid(pid: pid_t, status: *mut c_int, options: c_int) -> pid_t;
3821     pub fn write(fd: c_int, buf: *const c_void, count: size_t) -> ssize_t;
3822     pub fn pread(fd: c_int, buf: *mut c_void, count: size_t, offset: off_t) -> ssize_t;
3823     pub fn pwrite(fd: c_int, buf: *const c_void, count: size_t, offset: off_t) -> ssize_t;
3824     pub fn umask(mask: mode_t) -> mode_t;
3825 
3826     pub fn utime(file: *const c_char, buf: *const utimbuf) -> c_int;
3827 
3828     pub fn kill(pid: pid_t, sig: c_int) -> c_int;
3829 
3830     pub fn mlock(addr: *const c_void, len: size_t) -> c_int;
3831     pub fn munlock(addr: *const c_void, len: size_t) -> c_int;
3832     pub fn mlockall(flags: c_int) -> c_int;
3833     pub fn munlockall() -> c_int;
3834 
3835     pub fn mmap(
3836         addr: *mut c_void,
3837         len: size_t,
3838         prot: c_int,
3839         flags: c_int,
3840         fd: c_int,
3841         offset: off_t,
3842     ) -> *mut c_void;
3843     pub fn munmap(addr: *mut c_void, len: size_t) -> c_int;
3844 
3845     pub fn if_nametoindex(ifname: *const c_char) -> c_uint;
3846     pub fn if_indextoname(ifindex: c_uint, ifname: *mut c_char) -> *mut c_char;
3847 
3848     pub fn lstat(path: *const c_char, buf: *mut stat) -> c_int;
3849 
3850     pub fn fsync(fd: c_int) -> c_int;
3851 
3852     pub fn setenv(name: *const c_char, val: *const c_char, overwrite: c_int) -> c_int;
3853     pub fn unsetenv(name: *const c_char) -> c_int;
3854 
3855     pub fn symlink(path1: *const c_char, path2: *const c_char) -> c_int;
3856 
3857     pub fn ftruncate(fd: c_int, length: off_t) -> c_int;
3858 
3859     pub fn signal(signum: c_int, handler: sighandler_t) -> sighandler_t;
3860 
3861     pub fn realpath(pathname: *const c_char, resolved: *mut c_char) -> *mut c_char;
3862 
3863     pub fn flock(fd: c_int, operation: c_int) -> c_int;
3864 
3865     pub fn gettimeofday(tp: *mut crate::timeval, tz: *mut c_void) -> c_int;
3866     pub fn times(buf: *mut crate::tms) -> crate::clock_t;
3867 
3868     pub fn pthread_self() -> crate::pthread_t;
3869     pub fn pthread_join(native: crate::pthread_t, value: *mut *mut c_void) -> c_int;
3870     pub fn pthread_exit(value: *mut c_void) -> !;
3871     pub fn pthread_attr_init(attr: *mut crate::pthread_attr_t) -> c_int;
3872     pub fn pthread_attr_destroy(attr: *mut crate::pthread_attr_t) -> c_int;
3873     pub fn pthread_attr_getstacksize(
3874         attr: *const crate::pthread_attr_t,
3875         stacksize: *mut size_t,
3876     ) -> c_int;
3877     pub fn pthread_attr_setstacksize(attr: *mut crate::pthread_attr_t, stack_size: size_t)
3878         -> c_int;
3879     pub fn pthread_attr_setdetachstate(attr: *mut crate::pthread_attr_t, state: c_int) -> c_int;
3880     pub fn pthread_detach(thread: crate::pthread_t) -> c_int;
3881     pub fn sched_yield() -> c_int;
3882     pub fn pthread_key_create(
3883         key: *mut pthread_key_t,
3884         dtor: Option<unsafe extern "C" fn(*mut c_void)>,
3885     ) -> c_int;
3886     pub fn pthread_key_delete(key: pthread_key_t) -> c_int;
3887     pub fn pthread_getspecific(key: pthread_key_t) -> *mut c_void;
3888     pub fn pthread_setspecific(key: pthread_key_t, value: *const c_void) -> c_int;
3889     pub fn pthread_mutex_init(
3890         lock: *mut pthread_mutex_t,
3891         attr: *const pthread_mutexattr_t,
3892     ) -> c_int;
3893     pub fn pthread_mutex_destroy(lock: *mut pthread_mutex_t) -> c_int;
3894     pub fn pthread_mutex_lock(lock: *mut pthread_mutex_t) -> c_int;
3895     pub fn pthread_mutex_trylock(lock: *mut pthread_mutex_t) -> c_int;
3896     pub fn pthread_mutex_unlock(lock: *mut pthread_mutex_t) -> c_int;
3897 
3898     pub fn pthread_mutexattr_init(attr: *mut pthread_mutexattr_t) -> c_int;
3899     pub fn pthread_mutexattr_destroy(attr: *mut pthread_mutexattr_t) -> c_int;
3900     pub fn pthread_mutexattr_settype(attr: *mut pthread_mutexattr_t, _type: c_int) -> c_int;
3901 
3902     pub fn pthread_cond_init(cond: *mut pthread_cond_t, attr: *const pthread_condattr_t) -> c_int;
3903     pub fn pthread_cond_wait(cond: *mut pthread_cond_t, lock: *mut pthread_mutex_t) -> c_int;
3904     pub fn pthread_cond_timedwait(
3905         cond: *mut pthread_cond_t,
3906         lock: *mut pthread_mutex_t,
3907         abstime: *const crate::timespec,
3908     ) -> c_int;
3909     pub fn pthread_cond_signal(cond: *mut pthread_cond_t) -> c_int;
3910     pub fn pthread_cond_broadcast(cond: *mut pthread_cond_t) -> c_int;
3911     pub fn pthread_cond_destroy(cond: *mut pthread_cond_t) -> c_int;
3912     pub fn pthread_condattr_init(attr: *mut pthread_condattr_t) -> c_int;
3913     pub fn pthread_condattr_destroy(attr: *mut pthread_condattr_t) -> c_int;
3914     pub fn pthread_rwlock_init(
3915         lock: *mut pthread_rwlock_t,
3916         attr: *const pthread_rwlockattr_t,
3917     ) -> c_int;
3918     pub fn pthread_rwlock_destroy(lock: *mut pthread_rwlock_t) -> c_int;
3919     pub fn pthread_rwlock_rdlock(lock: *mut pthread_rwlock_t) -> c_int;
3920     pub fn pthread_rwlock_tryrdlock(lock: *mut pthread_rwlock_t) -> c_int;
3921     pub fn pthread_rwlock_wrlock(lock: *mut pthread_rwlock_t) -> c_int;
3922     pub fn pthread_rwlock_trywrlock(lock: *mut pthread_rwlock_t) -> c_int;
3923     pub fn pthread_rwlock_unlock(lock: *mut pthread_rwlock_t) -> c_int;
3924     pub fn pthread_rwlockattr_init(attr: *mut pthread_rwlockattr_t) -> c_int;
3925     pub fn pthread_rwlockattr_destroy(attr: *mut pthread_rwlockattr_t) -> c_int;
3926     pub fn pthread_getname_np(thread: crate::pthread_t, name: *mut c_char, len: size_t) -> c_int;
3927     pub fn pthread_setname_np(thread: crate::pthread_t, name: *const c_char) -> c_int;
3928     pub fn strerror_r(errnum: c_int, buf: *mut c_char, buflen: size_t) -> c_int;
3929 
3930     pub fn getsockopt(
3931         sockfd: c_int,
3932         level: c_int,
3933         optname: c_int,
3934         optval: *mut c_void,
3935         optlen: *mut crate::socklen_t,
3936     ) -> c_int;
3937     pub fn raise(signum: c_int) -> c_int;
3938     pub fn sigaction(signum: c_int, act: *const sigaction, oldact: *mut sigaction) -> c_int;
3939 
3940     pub fn utimes(filename: *const c_char, times: *const crate::timeval) -> c_int;
3941     pub fn dlopen(filename: *const c_char, flag: c_int) -> *mut c_void;
3942     pub fn dlerror() -> *mut c_char;
3943     pub fn dlsym(handle: *mut c_void, symbol: *const c_char) -> *mut c_void;
3944     pub fn dlclose(handle: *mut c_void) -> c_int;
3945     pub fn dladdr(addr: *const c_void, info: *mut Dl_info) -> c_int;
3946 
3947     pub fn getaddrinfo(
3948         node: *const c_char,
3949         service: *const c_char,
3950         hints: *const addrinfo,
3951         res: *mut *mut addrinfo,
3952     ) -> c_int;
3953     pub fn freeaddrinfo(res: *mut addrinfo);
3954     pub fn gai_strerror(errcode: c_int) -> *const c_char;
3955     pub fn res_init() -> c_int;
3956 
3957     pub fn gmtime_r(time_p: *const time_t, result: *mut tm) -> *mut tm;
3958     pub fn localtime_r(time_p: *const time_t, result: *mut tm) -> *mut tm;
3959     pub fn mktime(tm: *mut tm) -> time_t;
3960     pub fn time(time: *mut time_t) -> time_t;
3961     pub fn gmtime(time_p: *const time_t) -> *mut tm;
3962     pub fn localtime(time_p: *const time_t) -> *mut tm;
3963 
3964     pub fn mknod(pathname: *const c_char, mode: mode_t, dev: crate::dev_t) -> c_int;
3965     pub fn uname(buf: *mut crate::utsname) -> c_int;
3966     pub fn gethostname(name: *mut c_char, len: size_t) -> c_int;
3967     pub fn getservbyname(name: *const c_char, proto: *const c_char) -> *mut servent;
3968     pub fn getprotobyname(name: *const c_char) -> *mut protoent;
3969     pub fn getprotobynumber(proto: c_int) -> *mut protoent;
3970     pub fn usleep(secs: c_uint) -> c_int;
3971     pub fn send(socket: c_int, buf: *const c_void, len: size_t, flags: c_int) -> ssize_t;
3972     pub fn recv(socket: c_int, buf: *mut c_void, len: size_t, flags: c_int) -> ssize_t;
3973     pub fn putenv(string: *mut c_char) -> c_int;
3974     pub fn poll(fds: *mut pollfd, nfds: nfds_t, timeout: c_int) -> c_int;
3975     pub fn select(
3976         nfds: c_int,
3977         readfds: *mut fd_set,
3978         writefds: *mut fd_set,
3979         errorfds: *mut fd_set,
3980         timeout: *mut timeval,
3981     ) -> c_int;
3982     pub fn setlocale(category: c_int, locale: *const c_char) -> *mut c_char;
3983     pub fn localeconv() -> *mut lconv;
3984 
3985     pub fn sem_destroy(sem: *mut sem_t) -> c_int;
3986     pub fn sem_wait(sem: *mut sem_t) -> c_int;
3987     pub fn sem_trywait(sem: *mut sem_t) -> c_int;
3988     pub fn sem_post(sem: *mut sem_t) -> c_int;
3989     pub fn sem_init(sem: *mut sem_t, pshared: c_int, value: c_uint) -> c_int;
3990     pub fn statvfs(path: *const c_char, buf: *mut statvfs) -> c_int;
3991     pub fn fstatvfs(fd: c_int, buf: *mut statvfs) -> c_int;
3992 
3993     pub fn readlink(path: *const c_char, buf: *mut c_char, bufsz: size_t) -> ssize_t;
3994 
3995     pub fn sigemptyset(set: *mut sigset_t) -> c_int;
3996     pub fn sigaddset(set: *mut sigset_t, signum: c_int) -> c_int;
3997     pub fn sigfillset(set: *mut sigset_t) -> c_int;
3998     pub fn sigdelset(set: *mut sigset_t, signum: c_int) -> c_int;
3999     pub fn sigismember(set: *const sigset_t, signum: c_int) -> c_int;
4000 
4001     pub fn sigprocmask(how: c_int, set: *const sigset_t, oldset: *mut sigset_t) -> c_int;
4002     pub fn sigpending(set: *mut sigset_t) -> c_int;
4003 
4004     pub fn timegm(tm: *mut crate::tm) -> time_t;
4005 
4006     pub fn getsid(pid: pid_t) -> pid_t;
4007 
4008     pub fn sysconf(name: c_int) -> c_long;
4009 
4010     pub fn mkfifo(path: *const c_char, mode: mode_t) -> c_int;
4011 
4012     pub fn pselect(
4013         nfds: c_int,
4014         readfds: *mut fd_set,
4015         writefds: *mut fd_set,
4016         errorfds: *mut fd_set,
4017         timeout: *const timespec,
4018         sigmask: *const sigset_t,
4019     ) -> c_int;
4020     pub fn fseeko(stream: *mut crate::FILE, offset: off_t, whence: c_int) -> c_int;
4021     pub fn ftello(stream: *mut crate::FILE) -> off_t;
4022     pub fn tcdrain(fd: c_int) -> c_int;
4023     pub fn cfgetispeed(termios: *const crate::termios) -> crate::speed_t;
4024     pub fn cfgetospeed(termios: *const crate::termios) -> crate::speed_t;
4025     pub fn cfmakeraw(termios: *mut crate::termios);
4026     pub fn cfsetispeed(termios: *mut crate::termios, speed: crate::speed_t) -> c_int;
4027     pub fn cfsetospeed(termios: *mut crate::termios, speed: crate::speed_t) -> c_int;
4028     pub fn cfsetspeed(termios: *mut crate::termios, speed: crate::speed_t) -> c_int;
4029     pub fn tcgetattr(fd: c_int, termios: *mut crate::termios) -> c_int;
4030     pub fn tcsetattr(fd: c_int, optional_actions: c_int, termios: *const crate::termios) -> c_int;
4031     pub fn tcflow(fd: c_int, action: c_int) -> c_int;
4032     pub fn tcflush(fd: c_int, action: c_int) -> c_int;
4033     pub fn tcgetsid(fd: c_int) -> crate::pid_t;
4034     pub fn tcsendbreak(fd: c_int, duration: c_int) -> c_int;
4035     pub fn mkstemp(template: *mut c_char) -> c_int;
4036     pub fn mkdtemp(template: *mut c_char) -> *mut c_char;
4037 
4038     pub fn tmpnam(ptr: *mut c_char) -> *mut c_char;
4039 
4040     pub fn openlog(ident: *const c_char, logopt: c_int, facility: c_int);
4041     pub fn closelog();
4042     pub fn setlogmask(maskpri: c_int) -> c_int;
4043     pub fn syslog(priority: c_int, message: *const c_char, ...);
4044 
4045     pub fn grantpt(fd: c_int) -> c_int;
4046     pub fn posix_openpt(flags: c_int) -> c_int;
4047     pub fn ptsname(fd: c_int) -> *mut c_char;
4048     pub fn unlockpt(fd: c_int) -> c_int;
4049 
4050     pub fn fdatasync(fd: c_int) -> c_int;
4051     pub fn clock_getres(clk_id: crate::clockid_t, tp: *mut crate::timespec) -> c_int;
4052     pub fn clock_gettime(clk_id: crate::clockid_t, tp: *mut crate::timespec) -> c_int;
4053     pub fn clock_settime(clk_id: crate::clockid_t, tp: *const crate::timespec) -> c_int;
4054     pub fn dirfd(dirp: *mut crate::DIR) -> c_int;
4055 
4056     pub fn pthread_getattr_np(native: crate::pthread_t, attr: *mut crate::pthread_attr_t) -> c_int;
4057     pub fn pthread_attr_getstack(
4058         attr: *const crate::pthread_attr_t,
4059         stackaddr: *mut *mut c_void,
4060         stacksize: *mut size_t,
4061     ) -> c_int;
4062     pub fn memalign(align: size_t, size: size_t) -> *mut c_void;
4063     pub fn setgroups(ngroups: size_t, ptr: *const crate::gid_t) -> c_int;
4064     pub fn pipe2(fds: *mut c_int, flags: c_int) -> c_int;
4065     pub fn statfs(path: *const c_char, buf: *mut statfs) -> c_int;
4066     pub fn fstatfs(fd: c_int, buf: *mut statfs) -> c_int;
4067     pub fn memrchr(cx: *const c_void, c: c_int, n: size_t) -> *mut c_void;
4068 
4069     pub fn posix_fadvise(fd: c_int, offset: off_t, len: off_t, advise: c_int) -> c_int;
4070     pub fn futimens(fd: c_int, times: *const crate::timespec) -> c_int;
4071     pub fn utimensat(
4072         dirfd: c_int,
4073         path: *const c_char,
4074         times: *const crate::timespec,
4075         flag: c_int,
4076     ) -> c_int;
4077     pub fn duplocale(base: crate::locale_t) -> crate::locale_t;
4078     pub fn freelocale(loc: crate::locale_t);
4079     pub fn newlocale(mask: c_int, locale: *const c_char, base: crate::locale_t) -> crate::locale_t;
4080     pub fn uselocale(loc: crate::locale_t) -> crate::locale_t;
4081 
4082     pub fn fdopendir(fd: c_int) -> *mut crate::DIR;
4083 
4084     pub fn mknodat(dirfd: c_int, pathname: *const c_char, mode: mode_t, dev: dev_t) -> c_int;
4085     pub fn pthread_condattr_getclock(
4086         attr: *const pthread_condattr_t,
4087         clock_id: *mut clockid_t,
4088     ) -> c_int;
4089     pub fn pthread_condattr_setclock(
4090         attr: *mut pthread_condattr_t,
4091         clock_id: crate::clockid_t,
4092     ) -> c_int;
4093     pub fn accept4(
4094         fd: c_int,
4095         addr: *mut crate::sockaddr,
4096         len: *mut crate::socklen_t,
4097         flg: c_int,
4098     ) -> c_int;
4099     pub fn ptsname_r(fd: c_int, buf: *mut c_char, buflen: size_t) -> c_int;
4100     pub fn clearenv() -> c_int;
4101     pub fn waitid(
4102         idtype: idtype_t,
4103         id: id_t,
4104         infop: *mut crate::siginfo_t,
4105         options: c_int,
4106     ) -> c_int;
4107     pub fn setreuid(ruid: crate::uid_t, euid: crate::uid_t) -> c_int;
4108     pub fn setregid(rgid: crate::gid_t, egid: crate::gid_t) -> c_int;
4109     pub fn getresuid(
4110         ruid: *mut crate::uid_t,
4111         euid: *mut crate::uid_t,
4112         suid: *mut crate::uid_t,
4113     ) -> c_int;
4114     pub fn getresgid(
4115         rgid: *mut crate::gid_t,
4116         egid: *mut crate::gid_t,
4117         sgid: *mut crate::gid_t,
4118     ) -> c_int;
4119     pub fn acct(filename: *const c_char) -> c_int;
4120     pub fn brk(addr: *mut c_void) -> c_int;
4121     pub fn setresgid(rgid: crate::gid_t, egid: crate::gid_t, sgid: crate::gid_t) -> c_int;
4122     pub fn setresuid(ruid: crate::uid_t, euid: crate::uid_t, suid: crate::uid_t) -> c_int;
4123     pub fn openpty(
4124         amaster: *mut c_int,
4125         aslave: *mut c_int,
4126         name: *mut c_char,
4127         termp: *const termios,
4128         winp: *const crate::winsize,
4129     ) -> c_int;
4130 
4131     // DIFF(main): changed to `*const *mut` in e77f551de9
4132     pub fn execvpe(
4133         file: *const c_char,
4134         argv: *const *const c_char,
4135         envp: *const *const c_char,
4136     ) -> c_int;
4137     pub fn fexecve(fd: c_int, argv: *const *const c_char, envp: *const *const c_char) -> c_int;
4138 
4139     pub fn ioctl(fd: c_int, request: c_int, ...) -> c_int;
4140 
4141     pub fn lutimes(file: *const c_char, times: *const crate::timeval) -> c_int;
4142 
4143     pub fn setpwent();
4144     pub fn endpwent();
4145     pub fn getpwent() -> *mut passwd;
4146 
4147     pub fn shm_open(name: *const c_char, oflag: c_int, mode: mode_t) -> c_int;
4148 
4149     // System V IPC
4150     pub fn shmget(key: crate::key_t, size: size_t, shmflg: c_int) -> c_int;
4151     pub fn shmat(shmid: c_int, shmaddr: *const c_void, shmflg: c_int) -> *mut c_void;
4152     pub fn shmdt(shmaddr: *const c_void) -> c_int;
4153     pub fn shmctl(shmid: c_int, cmd: c_int, buf: *mut crate::shmid_ds) -> c_int;
4154     pub fn ftok(pathname: *const c_char, proj_id: c_int) -> crate::key_t;
4155     pub fn semget(key: crate::key_t, nsems: c_int, semflag: c_int) -> c_int;
4156     pub fn semop(semid: c_int, sops: *mut crate::sembuf, nsops: size_t) -> c_int;
4157     pub fn semctl(semid: c_int, semnum: c_int, cmd: c_int, ...) -> c_int;
4158     pub fn msgctl(msqid: c_int, cmd: c_int, buf: *mut msqid_ds) -> c_int;
4159     pub fn msgget(key: crate::key_t, msgflg: c_int) -> c_int;
4160     pub fn msgrcv(
4161         msqid: c_int,
4162         msgp: *mut c_void,
4163         msgsz: size_t,
4164         msgtyp: c_long,
4165         msgflg: c_int,
4166     ) -> ssize_t;
4167     pub fn msgsnd(msqid: c_int, msgp: *const c_void, msgsz: size_t, msgflg: c_int) -> c_int;
4168 
4169     pub fn mprotect(addr: *mut c_void, len: size_t, prot: c_int) -> c_int;
4170     pub fn __errno_location() -> *mut c_int;
4171 
4172     pub fn fallocate(fd: c_int, mode: c_int, offset: off_t, len: off_t) -> c_int;
4173     pub fn posix_fallocate(fd: c_int, offset: off_t, len: off_t) -> c_int;
4174     pub fn readahead(fd: c_int, offset: off64_t, count: size_t) -> ssize_t;
4175     pub fn signalfd(fd: c_int, mask: *const crate::sigset_t, flags: c_int) -> c_int;
4176     pub fn timerfd_create(clockid: c_int, flags: c_int) -> c_int;
4177     pub fn timerfd_gettime(fd: c_int, curr_value: *mut itimerspec) -> c_int;
4178     pub fn timerfd_settime(
4179         fd: c_int,
4180         flags: c_int,
4181         new_value: *const itimerspec,
4182         old_value: *mut itimerspec,
4183     ) -> c_int;
4184     pub fn pwritev(fd: c_int, iov: *const crate::iovec, iovcnt: c_int, offset: off_t) -> ssize_t;
4185     pub fn preadv(fd: c_int, iov: *const crate::iovec, iovcnt: c_int, offset: off_t) -> ssize_t;
4186     pub fn quotactl(cmd: c_int, special: *const c_char, id: c_int, data: *mut c_char) -> c_int;
4187     pub fn dup3(oldfd: c_int, newfd: c_int, flags: c_int) -> c_int;
4188     pub fn mkostemp(template: *mut c_char, flags: c_int) -> c_int;
4189     pub fn mkostemps(template: *mut c_char, suffixlen: c_int, flags: c_int) -> c_int;
4190     pub fn sigtimedwait(
4191         set: *const sigset_t,
4192         info: *mut siginfo_t,
4193         timeout: *const crate::timespec,
4194     ) -> c_int;
4195     pub fn sigwaitinfo(set: *const sigset_t, info: *mut siginfo_t) -> c_int;
4196     pub fn nl_langinfo_l(item: crate::nl_item, locale: crate::locale_t) -> *mut c_char;
4197     pub fn getnameinfo(
4198         sa: *const crate::sockaddr,
4199         salen: crate::socklen_t,
4200         host: *mut c_char,
4201         hostlen: crate::socklen_t,
4202         serv: *mut c_char,
4203         servlen: crate::socklen_t,
4204         flags: c_int,
4205     ) -> c_int;
4206     pub fn reboot(how_to: c_int) -> c_int;
4207     pub fn setfsgid(gid: crate::gid_t) -> c_int;
4208     pub fn setfsuid(uid: crate::uid_t) -> c_int;
4209 
4210     // Not available now on Android
4211     pub fn mkfifoat(dirfd: c_int, pathname: *const c_char, mode: mode_t) -> c_int;
4212     pub fn if_nameindex() -> *mut if_nameindex;
4213     pub fn if_freenameindex(ptr: *mut if_nameindex);
4214     pub fn sync_file_range(fd: c_int, offset: off64_t, nbytes: off64_t, flags: c_uint) -> c_int;
4215     pub fn getifaddrs(ifap: *mut *mut crate::ifaddrs) -> c_int;
4216     pub fn freeifaddrs(ifa: *mut crate::ifaddrs);
4217 
4218     pub fn glob(
4219         pattern: *const c_char,
4220         flags: c_int,
4221         errfunc: Option<extern "C" fn(epath: *const c_char, errno: c_int) -> c_int>,
4222         pglob: *mut crate::glob_t,
4223     ) -> c_int;
4224     pub fn globfree(pglob: *mut crate::glob_t);
4225 
4226     pub fn posix_madvise(addr: *mut c_void, len: size_t, advice: c_int) -> c_int;
4227 
4228     pub fn shm_unlink(name: *const c_char) -> c_int;
4229 
4230     pub fn seekdir(dirp: *mut crate::DIR, loc: c_long);
4231 
4232     pub fn telldir(dirp: *mut crate::DIR) -> c_long;
4233     pub fn madvise(addr: *mut c_void, len: size_t, advice: c_int) -> c_int;
4234 
4235     pub fn msync(addr: *mut c_void, len: size_t, flags: c_int) -> c_int;
4236 
4237     pub fn recvfrom(
4238         socket: c_int,
4239         buf: *mut c_void,
4240         len: size_t,
4241         flags: c_int,
4242         addr: *mut crate::sockaddr,
4243         addrlen: *mut crate::socklen_t,
4244     ) -> ssize_t;
4245     pub fn mkstemps(template: *mut c_char, suffixlen: c_int) -> c_int;
4246     pub fn futimes(fd: c_int, times: *const crate::timeval) -> c_int;
4247     pub fn nl_langinfo(item: crate::nl_item) -> *mut c_char;
4248 
4249     pub fn bind(
4250         socket: c_int,
4251         address: *const crate::sockaddr,
4252         address_len: crate::socklen_t,
4253     ) -> c_int;
4254 
4255     pub fn writev(fd: c_int, iov: *const crate::iovec, iovcnt: c_int) -> ssize_t;
4256     pub fn readv(fd: c_int, iov: *const crate::iovec, iovcnt: c_int) -> ssize_t;
4257 
4258     pub fn sendmsg(fd: c_int, msg: *const crate::msghdr, flags: c_int) -> ssize_t;
4259     pub fn recvmsg(fd: c_int, msg: *mut crate::msghdr, flags: c_int) -> ssize_t;
4260     pub fn getdomainname(name: *mut c_char, len: size_t) -> c_int;
4261     pub fn setdomainname(name: *const c_char, len: size_t) -> c_int;
4262     pub fn vhangup() -> c_int;
4263     pub fn sendmmsg(sockfd: c_int, msgvec: *mut mmsghdr, vlen: c_uint, flags: c_int) -> c_int;
4264     pub fn recvmmsg(
4265         sockfd: c_int,
4266         msgvec: *mut mmsghdr,
4267         vlen: c_uint,
4268         flags: c_int,
4269         timeout: *mut crate::timespec,
4270     ) -> c_int;
4271     pub fn sync();
4272     pub fn syscall(num: c_long, ...) -> c_long;
4273     pub fn sched_getaffinity(
4274         pid: crate::pid_t,
4275         cpusetsize: size_t,
4276         cpuset: *mut cpu_set_t,
4277     ) -> c_int;
4278     pub fn sched_setaffinity(
4279         pid: crate::pid_t,
4280         cpusetsize: size_t,
4281         cpuset: *const cpu_set_t,
4282     ) -> c_int;
4283     pub fn umount(target: *const c_char) -> c_int;
4284     pub fn sched_get_priority_max(policy: c_int) -> c_int;
4285     pub fn tee(fd_in: c_int, fd_out: c_int, len: size_t, flags: c_uint) -> ssize_t;
4286     pub fn settimeofday(tv: *const crate::timeval, tz: *const crate::timezone) -> c_int;
4287     pub fn splice(
4288         fd_in: c_int,
4289         off_in: *mut crate::loff_t,
4290         fd_out: c_int,
4291         off_out: *mut crate::loff_t,
4292         len: size_t,
4293         flags: c_uint,
4294     ) -> ssize_t;
4295     pub fn eventfd(init: c_uint, flags: c_int) -> c_int;
4296     pub fn sched_rr_get_interval(pid: crate::pid_t, tp: *mut crate::timespec) -> c_int;
4297     pub fn sem_timedwait(sem: *mut sem_t, abstime: *const crate::timespec) -> c_int;
4298     pub fn sem_getvalue(sem: *mut sem_t, sval: *mut c_int) -> c_int;
4299     pub fn sched_setparam(pid: crate::pid_t, param: *const crate::sched_param) -> c_int;
4300     pub fn swapoff(puath: *const c_char) -> c_int;
4301     pub fn vmsplice(fd: c_int, iov: *const crate::iovec, nr_segs: size_t, flags: c_uint)
4302         -> ssize_t;
4303     pub fn mount(
4304         src: *const c_char,
4305         target: *const c_char,
4306         fstype: *const c_char,
4307         flags: c_ulong,
4308         data: *const c_void,
4309     ) -> c_int;
4310     pub fn personality(persona: c_ulong) -> c_int;
4311     pub fn sched_getparam(pid: crate::pid_t, param: *mut crate::sched_param) -> c_int;
4312     pub fn ppoll(
4313         fds: *mut crate::pollfd,
4314         nfds: nfds_t,
4315         timeout: *const crate::timespec,
4316         sigmask: *const sigset_t,
4317     ) -> c_int;
4318     pub fn pthread_mutex_timedlock(
4319         lock: *mut pthread_mutex_t,
4320         abstime: *const crate::timespec,
4321     ) -> c_int;
4322     pub fn clone(
4323         cb: extern "C" fn(*mut c_void) -> c_int,
4324         child_stack: *mut c_void,
4325         flags: c_int,
4326         arg: *mut c_void,
4327         ...
4328     ) -> c_int;
4329     pub fn sched_getscheduler(pid: crate::pid_t) -> c_int;
4330     pub fn clock_nanosleep(
4331         clk_id: crate::clockid_t,
4332         flags: c_int,
4333         rqtp: *const crate::timespec,
4334         rmtp: *mut crate::timespec,
4335     ) -> c_int;
4336     pub fn pthread_attr_getguardsize(
4337         attr: *const crate::pthread_attr_t,
4338         guardsize: *mut size_t,
4339     ) -> c_int;
4340     pub fn pthread_attr_setguardsize(attr: *mut crate::pthread_attr_t, guardsize: size_t) -> c_int;
4341     pub fn sethostname(name: *const c_char, len: size_t) -> c_int;
4342     pub fn sched_get_priority_min(policy: c_int) -> c_int;
4343     pub fn umount2(target: *const c_char, flags: c_int) -> c_int;
4344     pub fn swapon(path: *const c_char, swapflags: c_int) -> c_int;
4345     pub fn sched_setscheduler(
4346         pid: crate::pid_t,
4347         policy: c_int,
4348         param: *const crate::sched_param,
4349     ) -> c_int;
4350     pub fn sigsuspend(mask: *const crate::sigset_t) -> c_int;
4351     pub fn getgrgid_r(
4352         gid: crate::gid_t,
4353         grp: *mut crate::group,
4354         buf: *mut c_char,
4355         buflen: size_t,
4356         result: *mut *mut crate::group,
4357     ) -> c_int;
4358     pub fn sigaltstack(ss: *const stack_t, oss: *mut stack_t) -> c_int;
4359     pub fn sem_close(sem: *mut sem_t) -> c_int;
4360     pub fn getdtablesize() -> c_int;
4361     pub fn getgrnam_r(
4362         name: *const c_char,
4363         grp: *mut crate::group,
4364         buf: *mut c_char,
4365         buflen: size_t,
4366         result: *mut *mut crate::group,
4367     ) -> c_int;
4368     pub fn initgroups(user: *const c_char, group: crate::gid_t) -> c_int;
4369     pub fn pthread_sigmask(how: c_int, set: *const sigset_t, oldset: *mut sigset_t) -> c_int;
4370     pub fn sem_open(name: *const c_char, oflag: c_int, ...) -> *mut sem_t;
4371     pub fn getgrnam(name: *const c_char) -> *mut crate::group;
4372     pub fn pthread_cancel(thread: crate::pthread_t) -> c_int;
4373     pub fn pthread_kill(thread: crate::pthread_t, sig: c_int) -> c_int;
4374     pub fn sem_unlink(name: *const c_char) -> c_int;
4375     pub fn daemon(nochdir: c_int, noclose: c_int) -> c_int;
4376     pub fn getpwnam_r(
4377         name: *const c_char,
4378         pwd: *mut passwd,
4379         buf: *mut c_char,
4380         buflen: size_t,
4381         result: *mut *mut passwd,
4382     ) -> c_int;
4383     pub fn getpwuid_r(
4384         uid: crate::uid_t,
4385         pwd: *mut passwd,
4386         buf: *mut c_char,
4387         buflen: size_t,
4388         result: *mut *mut passwd,
4389     ) -> c_int;
4390     pub fn sigwait(set: *const sigset_t, sig: *mut c_int) -> c_int;
4391     pub fn pthread_atfork(
4392         prepare: Option<unsafe extern "C" fn()>,
4393         parent: Option<unsafe extern "C" fn()>,
4394         child: Option<unsafe extern "C" fn()>,
4395     ) -> c_int;
4396     pub fn getgrgid(gid: crate::gid_t) -> *mut crate::group;
4397 
4398     pub fn setgrent();
4399     pub fn endgrent();
4400     pub fn getgrent() -> *mut crate::group;
4401 
4402     pub fn getgrouplist(
4403         user: *const c_char,
4404         group: crate::gid_t,
4405         groups: *mut crate::gid_t,
4406         ngroups: *mut c_int,
4407     ) -> c_int;
4408     pub fn popen(command: *const c_char, mode: *const c_char) -> *mut crate::FILE;
4409     pub fn faccessat(dirfd: c_int, pathname: *const c_char, mode: c_int, flags: c_int) -> c_int;
4410     pub fn pthread_create(
4411         native: *mut crate::pthread_t,
4412         attr: *const crate::pthread_attr_t,
4413         f: extern "C" fn(*mut c_void) -> *mut c_void,
4414         value: *mut c_void,
4415     ) -> c_int;
4416     pub fn dl_iterate_phdr(
4417         callback: Option<
4418             unsafe extern "C" fn(
4419                 info: *mut crate::dl_phdr_info,
4420                 size: size_t,
4421                 data: *mut c_void,
4422             ) -> c_int,
4423         >,
4424         data: *mut c_void,
4425     ) -> c_int;
4426 }
4427 
4428 cfg_if! {
4429     if #[cfg(target_arch = "aarch64")] {
4430         mod aarch64;
4431         pub use self::aarch64::*;
4432     } else if #[cfg(any(target_arch = "x86_64"))] {
4433         mod x86_64;
4434         pub use self::x86_64::*;
4435     } else if #[cfg(any(target_arch = "riscv64"))] {
4436         mod riscv64;
4437         pub use self::riscv64::*;
4438     } else {
4439         // Unknown target_arch
4440     }
4441 }
4442