1pub type c_char = i8;
2pub type c_long = i64;
3pub type c_ulong = u64;
4pub type caddr_t = *mut ::c_char;
5
6pub type clockid_t = ::c_int;
7pub type blkcnt_t = ::c_long;
8pub type clock_t = ::c_long;
9pub type daddr_t = ::c_long;
10pub type dev_t = ::c_ulong;
11pub type fsblkcnt_t = ::c_ulong;
12pub type fsfilcnt_t = ::c_ulong;
13pub type ino_t = ::c_ulong;
14pub type key_t = ::c_int;
15pub type major_t = ::c_uint;
16pub type minor_t = ::c_uint;
17pub type mode_t = ::c_uint;
18pub type nlink_t = ::c_uint;
19pub type rlim_t = ::c_ulong;
20pub type speed_t = ::c_uint;
21pub type tcflag_t = ::c_uint;
22pub type time_t = ::c_long;
23pub type timer_t = ::c_int;
24pub type wchar_t = ::c_int;
25pub type nfds_t = ::c_ulong;
26pub type projid_t = ::c_int;
27pub type zoneid_t = ::c_int;
28pub type psetid_t = ::c_int;
29pub type processorid_t = ::c_int;
30pub type chipid_t = ::c_int;
31pub type ctid_t = ::id_t;
32
33pub type suseconds_t = ::c_long;
34pub type off_t = ::c_long;
35pub type useconds_t = ::c_uint;
36pub type socklen_t = ::c_uint;
37pub type sa_family_t = u16;
38pub type pthread_t = ::c_uint;
39pub type pthread_key_t = ::c_uint;
40pub type thread_t = ::c_uint;
41pub type blksize_t = ::c_int;
42pub type nl_item = ::c_int;
43pub type mqd_t = *mut ::c_void;
44pub type id_t = ::c_int;
45pub type idtype_t = ::c_uint;
46pub type shmatt_t = ::c_ulong;
47
48pub type lgrp_rsrc_t = ::c_int;
49pub type lgrp_affinity_t = ::c_int;
50pub type lgrp_id_t = ::id_t;
51pub type lgrp_mem_size_t = ::c_longlong;
52pub type lgrp_cookie_t = ::uintptr_t;
53pub type lgrp_content_t = ::c_uint;
54pub type lgrp_lat_between_t = ::c_uint;
55pub type lgrp_mem_size_flag_t = ::c_uint;
56pub type lgrp_view_t = ::c_uint;
57
58#[cfg_attr(feature = "extra_traits", derive(Debug))]
59pub enum timezone {}
60impl ::Copy for timezone {}
61impl ::Clone for timezone {
62    fn clone(&self) -> timezone {
63        *self
64    }
65}
66
67#[cfg_attr(feature = "extra_traits", derive(Debug))]
68pub enum ucred_t {}
69impl ::Copy for ucred_t {}
70impl ::Clone for ucred_t {
71    fn clone(&self) -> ucred_t {
72        *self
73    }
74}
75
76s! {
77    pub struct in_addr {
78        pub s_addr: ::in_addr_t,
79    }
80
81    pub struct ip_mreq {
82        pub imr_multiaddr: in_addr,
83        pub imr_interface: in_addr,
84    }
85
86    pub struct ip_mreq_source {
87        pub imr_multiaddr: in_addr,
88        pub imr_sourceaddr: in_addr,
89        pub imr_interface: in_addr,
90    }
91
92    pub struct ipc_perm {
93        pub uid: ::uid_t,
94        pub gid: ::gid_t,
95        pub cuid: ::uid_t,
96        pub cgid: ::gid_t,
97        pub mode: ::mode_t,
98        pub seq: ::c_uint,
99        pub key: ::key_t,
100    }
101
102    pub struct sockaddr {
103        pub sa_family: sa_family_t,
104        pub sa_data: [::c_char; 14],
105    }
106
107    pub struct sockaddr_in {
108        pub sin_family: sa_family_t,
109        pub sin_port: ::in_port_t,
110        pub sin_addr: ::in_addr,
111        pub sin_zero: [::c_char; 8]
112    }
113
114    pub struct sockaddr_in6 {
115        pub sin6_family: sa_family_t,
116        pub sin6_port: ::in_port_t,
117        pub sin6_flowinfo: u32,
118        pub sin6_addr: ::in6_addr,
119        pub sin6_scope_id: u32,
120        pub __sin6_src_id: u32
121    }
122
123    pub struct passwd {
124        pub pw_name: *mut ::c_char,
125        pub pw_passwd: *mut ::c_char,
126        pub pw_uid: ::uid_t,
127        pub pw_gid: ::gid_t,
128        pub pw_age: *mut ::c_char,
129        pub pw_comment: *mut ::c_char,
130        pub pw_gecos: *mut ::c_char,
131        pub pw_dir: *mut ::c_char,
132        pub pw_shell: *mut ::c_char
133    }
134
135    pub struct ifaddrs {
136        pub ifa_next: *mut ifaddrs,
137        pub ifa_name: *mut ::c_char,
138        pub ifa_flags: ::c_ulong,
139        pub ifa_addr: *mut ::sockaddr,
140        pub ifa_netmask: *mut ::sockaddr,
141        pub ifa_dstaddr: *mut ::sockaddr,
142        pub ifa_data: *mut ::c_void
143    }
144
145    pub struct itimerspec {
146        pub it_interval: ::timespec,
147        pub it_value: ::timespec,
148    }
149
150    pub struct tm {
151        pub tm_sec: ::c_int,
152        pub tm_min: ::c_int,
153        pub tm_hour: ::c_int,
154        pub tm_mday: ::c_int,
155        pub tm_mon: ::c_int,
156        pub tm_year: ::c_int,
157        pub tm_wday: ::c_int,
158        pub tm_yday: ::c_int,
159        pub tm_isdst: ::c_int
160    }
161
162     pub struct msghdr {
163        pub msg_name: *mut ::c_void,
164        pub msg_namelen: ::socklen_t,
165        pub msg_iov: *mut ::iovec,
166        pub msg_iovlen: ::c_int,
167        pub msg_control: *mut ::c_void,
168        pub msg_controllen: ::socklen_t,
169        pub msg_flags: ::c_int,
170    }
171
172    pub struct cmsghdr {
173        pub cmsg_len: ::socklen_t,
174        pub cmsg_level: ::c_int,
175        pub cmsg_type: ::c_int,
176    }
177
178    pub struct pthread_attr_t {
179        __pthread_attrp: *mut ::c_void
180    }
181
182    pub struct pthread_mutex_t {
183        __pthread_mutex_flag1: u16,
184        __pthread_mutex_flag2: u8,
185        __pthread_mutex_ceiling: u8,
186        __pthread_mutex_type: u16,
187        __pthread_mutex_magic: u16,
188        __pthread_mutex_lock: u64,
189        __pthread_mutex_data: u64
190    }
191
192    pub struct pthread_mutexattr_t {
193        __pthread_mutexattrp: *mut ::c_void
194    }
195
196    pub struct pthread_cond_t {
197        __pthread_cond_flag: [u8; 4],
198        __pthread_cond_type: u16,
199        __pthread_cond_magic: u16,
200        __pthread_cond_data: u64
201    }
202
203    pub struct pthread_condattr_t {
204        __pthread_condattrp: *mut ::c_void,
205    }
206
207    pub struct pthread_rwlock_t {
208        __pthread_rwlock_readers: i32,
209        __pthread_rwlock_type: u16,
210        __pthread_rwlock_magic: u16,
211        __pthread_rwlock_mutex: ::pthread_mutex_t,
212        __pthread_rwlock_readercv: ::pthread_cond_t,
213        __pthread_rwlock_writercv: ::pthread_cond_t
214    }
215
216    pub struct pthread_rwlockattr_t {
217        __pthread_rwlockattrp: *mut ::c_void,
218    }
219
220    pub struct dirent {
221        pub d_ino: ::ino_t,
222        pub d_off: ::off_t,
223        pub d_reclen: u16,
224        pub d_name: [::c_char; 3]
225    }
226
227    pub struct glob_t {
228        pub gl_pathc: ::size_t,
229        pub gl_pathv:  *mut *mut ::c_char,
230        pub gl_offs: ::size_t,
231        __unused1: *mut ::c_void,
232        __unused2: ::c_int,
233        __unused3: ::c_int,
234        __unused4: ::c_int,
235        __unused5: *mut ::c_void,
236        __unused6: *mut ::c_void,
237        __unused7: *mut ::c_void,
238        __unused8: *mut ::c_void,
239        __unused9: *mut ::c_void,
240        __unused10: *mut ::c_void,
241    }
242
243    pub struct addrinfo {
244        pub ai_flags: ::c_int,
245        pub ai_family: ::c_int,
246        pub ai_socktype: ::c_int,
247        pub ai_protocol: ::c_int,
248        #[cfg(target_arch = "sparc64")]
249        __sparcv9_pad: ::c_int,
250        pub ai_addrlen: ::socklen_t,
251        pub ai_canonname: *mut ::c_char,
252        pub ai_addr: *mut ::sockaddr,
253        pub ai_next: *mut addrinfo,
254    }
255
256    pub struct sigset_t {
257        bits: [u32; 4],
258    }
259
260    pub struct sigaction {
261        pub sa_flags: ::c_int,
262        pub sa_sigaction: ::sighandler_t,
263        pub sa_mask: sigset_t,
264    }
265
266    pub struct stack_t {
267        pub ss_sp: *mut ::c_void,
268        pub ss_size: ::size_t,
269        pub ss_flags: ::c_int,
270    }
271
272    pub struct statvfs {
273        pub f_bsize: ::c_ulong,
274        pub f_frsize: ::c_ulong,
275        pub f_blocks: ::fsblkcnt_t,
276        pub f_bfree: ::fsblkcnt_t,
277        pub f_bavail: ::fsblkcnt_t,
278        pub f_files: ::fsfilcnt_t,
279        pub f_ffree: ::fsfilcnt_t,
280        pub f_favail: ::fsfilcnt_t,
281        pub f_fsid: ::c_ulong,
282        pub f_basetype: [::c_char; 16],
283        pub f_flag: ::c_ulong,
284        pub f_namemax: ::c_ulong,
285        pub f_fstr: [::c_char; 32]
286    }
287
288    pub struct sendfilevec_t {
289        pub sfv_fd: ::c_int,
290        pub sfv_flag: ::c_uint,
291        pub sfv_off: ::off_t,
292        pub sfv_len: ::size_t,
293    }
294
295    pub struct sched_param {
296        pub sched_priority: ::c_int,
297        sched_pad: [::c_int; 8]
298    }
299
300    pub struct Dl_info {
301        pub dli_fname: *const ::c_char,
302        pub dli_fbase: *mut ::c_void,
303        pub dli_sname: *const ::c_char,
304        pub dli_saddr: *mut ::c_void,
305    }
306
307    pub struct stat {
308        pub st_dev: ::dev_t,
309        pub st_ino: ::ino_t,
310        pub st_mode: ::mode_t,
311        pub st_nlink: ::nlink_t,
312        pub st_uid: ::uid_t,
313        pub st_gid: ::gid_t,
314        pub st_rdev: ::dev_t,
315        pub st_size: ::off_t,
316        pub st_atime: ::time_t,
317        pub st_atime_nsec: ::c_long,
318        pub st_mtime: ::time_t,
319        pub st_mtime_nsec: ::c_long,
320        pub st_ctime: ::time_t,
321        pub st_ctime_nsec: ::c_long,
322        pub st_blksize: ::blksize_t,
323        pub st_blocks: ::blkcnt_t,
324        __unused: [::c_char; 16]
325    }
326
327    pub struct termios {
328        pub c_iflag: ::tcflag_t,
329        pub c_oflag: ::tcflag_t,
330        pub c_cflag: ::tcflag_t,
331        pub c_lflag: ::tcflag_t,
332        pub c_cc: [::cc_t; ::NCCS]
333    }
334
335    pub struct lconv {
336        pub decimal_point: *mut ::c_char,
337        pub thousands_sep: *mut ::c_char,
338        pub grouping: *mut ::c_char,
339        pub int_curr_symbol: *mut ::c_char,
340        pub currency_symbol: *mut ::c_char,
341        pub mon_decimal_point: *mut ::c_char,
342        pub mon_thousands_sep: *mut ::c_char,
343        pub mon_grouping: *mut ::c_char,
344        pub positive_sign: *mut ::c_char,
345        pub negative_sign: *mut ::c_char,
346        pub int_frac_digits: ::c_char,
347        pub frac_digits: ::c_char,
348        pub p_cs_precedes: ::c_char,
349        pub p_sep_by_space: ::c_char,
350        pub n_cs_precedes: ::c_char,
351        pub n_sep_by_space: ::c_char,
352        pub p_sign_posn: ::c_char,
353        pub n_sign_posn: ::c_char,
354        pub int_p_cs_precedes: ::c_char,
355        pub int_p_sep_by_space: ::c_char,
356        pub int_n_cs_precedes: ::c_char,
357        pub int_n_sep_by_space: ::c_char,
358        pub int_p_sign_posn: ::c_char,
359        pub int_n_sign_posn: ::c_char,
360    }
361
362    pub struct sem_t {
363        pub sem_count: u32,
364        pub sem_type: u16,
365        pub sem_magic: u16,
366        pub sem_pad1: [u64; 3],
367        pub sem_pad2: [u64; 2]
368    }
369
370    pub struct flock {
371        pub l_type: ::c_short,
372        pub l_whence: ::c_short,
373        pub l_start: ::off_t,
374        pub l_len: ::off_t,
375        pub l_sysid: ::c_int,
376        pub l_pid: ::pid_t,
377        pub l_pad: [::c_long; 4]
378    }
379
380    pub struct if_nameindex {
381        pub if_index: ::c_uint,
382        pub if_name: *mut ::c_char,
383    }
384
385    pub struct mq_attr {
386        pub mq_flags: ::c_long,
387        pub mq_maxmsg: ::c_long,
388        pub mq_msgsize: ::c_long,
389        pub mq_curmsgs: ::c_long,
390        _pad: [::c_int; 12]
391    }
392
393    pub struct port_event {
394        pub portev_events: ::c_int,
395        pub portev_source: ::c_ushort,
396        pub portev_pad: ::c_ushort,
397        pub portev_object: ::uintptr_t,
398        pub portev_user: *mut ::c_void,
399    }
400
401    pub struct port_notify {
402        pub portnfy_port: ::c_int,
403        pub portnfy_user: *mut ::c_void,
404    }
405
406    pub struct exit_status {
407        e_termination: ::c_short,
408        e_exit: ::c_short,
409    }
410
411    pub struct utmp {
412        pub ut_user: [::c_char; 8],
413        pub ut_id: [::c_char; 4],
414        pub ut_line: [::c_char; 12],
415        pub ut_pid: ::c_short,
416        pub ut_type: ::c_short,
417        pub ut_exit: exit_status,
418        pub ut_time: ::time_t,
419    }
420
421    pub struct timex {
422        pub modes: u32,
423        pub offset: i32,
424        pub freq: i32,
425        pub maxerror: i32,
426        pub esterror: i32,
427        pub status: i32,
428        pub constant: i32,
429        pub precision: i32,
430        pub tolerance: i32,
431        pub ppsfreq: i32,
432        pub jitter: i32,
433        pub shift: i32,
434        pub stabil: i32,
435        pub jitcnt: i32,
436        pub calcnt: i32,
437        pub errcnt: i32,
438        pub stbcnt: i32,
439    }
440
441    pub struct ntptimeval {
442        pub time: ::timeval,
443        pub maxerror: i32,
444        pub esterror: i32,
445    }
446
447    pub struct mmapobj_result_t {
448        pub mr_addr: ::caddr_t,
449        pub mr_msize: ::size_t,
450        pub mr_fsize: ::size_t,
451        pub mr_offset: ::size_t,
452        pub mr_prot: ::c_uint,
453        pub mr_flags: ::c_uint,
454    }
455
456    pub struct lgrp_affinity_args {
457        pub idtype: ::idtype_t,
458        pub id: ::id_t,
459        pub lgrp: ::lgrp_id_t,
460        pub aff: ::lgrp_affinity_t,
461    }
462
463    pub struct processor_info_t {
464        pub pi_state: ::c_int,
465        pub pi_processor_type: [::c_char; PI_TYPELEN as usize],
466        pub pi_fputypes: [::c_char; PI_FPUTYPE as usize],
467        pub pi_clock: ::c_int,
468    }
469
470    pub struct option {
471        pub name: *const ::c_char,
472        pub has_arg: ::c_int,
473        pub flag: *mut ::c_int,
474        pub val: ::c_int,
475    }
476}
477
478s_no_extra_traits! {
479    #[cfg_attr(all(
480            any(target_arch = "x86", target_arch = "x86_64"),
481            libc_packedN
482        ), repr(packed(4)))]
483    #[cfg_attr(all(
484            any(target_arch = "x86", target_arch = "x86_64"),
485            not(libc_packedN)
486        ), repr(packed))]
487    pub struct epoll_event {
488        pub events: u32,
489        pub u64: u64,
490    }
491
492    pub struct utmpx {
493        pub ut_user: [::c_char; _UTX_USERSIZE],
494        pub ut_id: [::c_char; _UTX_IDSIZE],
495        pub ut_line: [::c_char; _UTX_LINESIZE],
496        pub ut_pid: ::pid_t,
497        pub ut_type: ::c_short,
498        pub ut_exit: exit_status,
499        pub ut_tv: ::timeval,
500        pub ut_session: ::c_int,
501        pub ut_pad: [::c_int; _UTX_PADSIZE],
502        pub ut_syslen: ::c_short,
503        pub ut_host: [::c_char; _UTX_HOSTSIZE],
504    }
505
506    pub struct sockaddr_un {
507        pub sun_family: sa_family_t,
508        pub sun_path: [c_char; 108]
509    }
510
511    pub struct utsname {
512        pub sysname: [::c_char; 257],
513        pub nodename: [::c_char; 257],
514        pub release: [::c_char; 257],
515        pub version: [::c_char; 257],
516        pub machine: [::c_char; 257],
517    }
518
519    pub struct fd_set {
520        #[cfg(target_pointer_width = "64")]
521        fds_bits: [i64; FD_SETSIZE / 64],
522        #[cfg(target_pointer_width = "32")]
523        fds_bits: [i32; FD_SETSIZE / 32],
524    }
525
526    pub struct sockaddr_storage {
527        pub ss_family: ::sa_family_t,
528        __ss_pad1: [u8; 6],
529        __ss_align: i64,
530        __ss_pad2: [u8; 240],
531    }
532
533    #[cfg_attr(all(target_pointer_width = "64", libc_align), repr(align(8)))]
534    pub struct siginfo_t {
535        pub si_signo: ::c_int,
536        pub si_code: ::c_int,
537        pub si_errno: ::c_int,
538        #[cfg(target_pointer_width = "64")]
539        pub si_pad: ::c_int,
540
541        __data_pad: [::c_int; SIGINFO_DATA_SIZE],
542    }
543
544    pub struct sockaddr_dl {
545        pub sdl_family: ::c_ushort,
546        pub sdl_index: ::c_ushort,
547        pub sdl_type: ::c_uchar,
548        pub sdl_nlen: ::c_uchar,
549        pub sdl_alen: ::c_uchar,
550        pub sdl_slen: ::c_uchar,
551        pub sdl_data: [::c_char; 244],
552    }
553
554    pub struct sigevent {
555        pub sigev_notify: ::c_int,
556        pub sigev_signo: ::c_int,
557        pub sigev_value: ::sigval,
558        pub ss_sp: *mut ::c_void,
559        pub sigev_notify_attributes: *const ::pthread_attr_t,
560        __sigev_pad2: ::c_int,
561    }
562
563    #[cfg(libc_union)]
564    #[cfg_attr(libc_align, repr(align(16)))]
565    pub union pad128_t {
566        // pub _q in this structure would be a "long double", of 16 bytes
567        pub _l: [i32; 4],
568    }
569
570    #[cfg(libc_union)]
571    #[cfg_attr(libc_align, repr(align(16)))]
572    pub union upad128_t {
573        // pub _q in this structure would be a "long double", of 16 bytes
574        pub _l: [u32; 4],
575    }
576}
577
578cfg_if! {
579    if #[cfg(feature = "extra_traits")] {
580        impl PartialEq for utmpx {
581            fn eq(&self, other: &utmpx) -> bool {
582                self.ut_type == other.ut_type
583                    && self.ut_pid == other.ut_pid
584                    && self.ut_user == other.ut_user
585                    && self.ut_line == other.ut_line
586                    && self.ut_id == other.ut_id
587                    && self.ut_exit == other.ut_exit
588                    && self.ut_session == other.ut_session
589                    && self.ut_tv == other.ut_tv
590                    && self.ut_syslen == other.ut_syslen
591                    && self.ut_pad == other.ut_pad
592                    && self
593                    .ut_host
594                    .iter()
595                    .zip(other.ut_host.iter())
596                    .all(|(a,b)| a == b)
597            }
598        }
599
600        impl Eq for utmpx {}
601
602        impl ::fmt::Debug for utmpx {
603            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
604                f.debug_struct("utmpx")
605                    .field("ut_user", &self.ut_user)
606                    .field("ut_id", &self.ut_id)
607                    .field("ut_line", &self.ut_line)
608                    .field("ut_pid", &self.ut_pid)
609                    .field("ut_type", &self.ut_type)
610                    .field("ut_exit", &self.ut_exit)
611                    .field("ut_tv", &self.ut_tv)
612                    .field("ut_session", &self.ut_session)
613                    .field("ut_pad", &self.ut_pad)
614                    .field("ut_syslen", &self.ut_syslen)
615                    .field("ut_host", &&self.ut_host[..])
616                    .finish()
617            }
618        }
619
620        impl ::hash::Hash for utmpx {
621            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
622                self.ut_user.hash(state);
623                self.ut_type.hash(state);
624                self.ut_pid.hash(state);
625                self.ut_line.hash(state);
626                self.ut_id.hash(state);
627                self.ut_host.hash(state);
628                self.ut_exit.hash(state);
629                self.ut_session.hash(state);
630                self.ut_tv.hash(state);
631                self.ut_syslen.hash(state);
632                self.ut_pad.hash(state);
633            }
634        }
635
636        impl PartialEq for epoll_event {
637            fn eq(&self, other: &epoll_event) -> bool {
638                self.events == other.events
639                    && self.u64 == other.u64
640            }
641        }
642        impl Eq for epoll_event {}
643        impl ::fmt::Debug for epoll_event {
644            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
645                let events = self.events;
646                let u64 = self.u64;
647                f.debug_struct("epoll_event")
648                    .field("events", &events)
649                    .field("u64", &u64)
650                    .finish()
651            }
652        }
653        impl ::hash::Hash for epoll_event {
654            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
655                let events = self.events;
656                let u64 = self.u64;
657                events.hash(state);
658                u64.hash(state);
659            }
660        }
661
662        impl PartialEq for sockaddr_un {
663            fn eq(&self, other: &sockaddr_un) -> bool {
664                self.sun_family == other.sun_family
665                    && self
666                    .sun_path
667                    .iter()
668                    .zip(other.sun_path.iter())
669                    .all(|(a, b)| a == b)
670            }
671        }
672        impl Eq for sockaddr_un {}
673        impl ::fmt::Debug for sockaddr_un {
674            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
675                f.debug_struct("sockaddr_un")
676                    .field("sun_family", &self.sun_family)
677                    // FIXME: .field("sun_path", &self.sun_path)
678                    .finish()
679            }
680        }
681        impl ::hash::Hash for sockaddr_un {
682            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
683                self.sun_family.hash(state);
684                self.sun_path.hash(state);
685            }
686        }
687
688        impl PartialEq for utsname {
689            fn eq(&self, other: &utsname) -> bool {
690                self.sysname
691                    .iter()
692                    .zip(other.sysname.iter())
693                    .all(|(a, b)| a == b)
694                    && self
695                    .nodename
696                    .iter()
697                    .zip(other.nodename.iter())
698                    .all(|(a, b)| a == b)
699                    && self
700                    .release
701                    .iter()
702                    .zip(other.release.iter())
703                    .all(|(a, b)| a == b)
704                    && self
705                    .version
706                    .iter()
707                    .zip(other.version.iter())
708                    .all(|(a, b)| a == b)
709                    && self
710                    .machine
711                    .iter()
712                    .zip(other.machine.iter())
713                    .all(|(a, b)| a == b)
714            }
715        }
716        impl Eq for utsname {}
717        impl ::fmt::Debug for utsname {
718            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
719                f.debug_struct("utsname")
720                    // FIXME: .field("sysname", &self.sysname)
721                    // FIXME: .field("nodename", &self.nodename)
722                    // FIXME: .field("release", &self.release)
723                    // FIXME: .field("version", &self.version)
724                    // FIXME: .field("machine", &self.machine)
725                    .finish()
726            }
727        }
728        impl ::hash::Hash for utsname {
729            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
730                self.sysname.hash(state);
731                self.nodename.hash(state);
732                self.release.hash(state);
733                self.version.hash(state);
734                self.machine.hash(state);
735            }
736        }
737
738        impl PartialEq for fd_set {
739            fn eq(&self, other: &fd_set) -> bool {
740                self.fds_bits
741                    .iter()
742                    .zip(other.fds_bits.iter())
743                    .all(|(a, b)| a == b)
744            }
745        }
746        impl Eq for fd_set {}
747        impl ::fmt::Debug for fd_set {
748            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
749                f.debug_struct("fd_set")
750                    // FIXME: .field("fds_bits", &self.fds_bits)
751                    .finish()
752            }
753        }
754        impl ::hash::Hash for fd_set {
755            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
756                self.fds_bits.hash(state);
757            }
758        }
759
760        impl PartialEq for sockaddr_storage {
761            fn eq(&self, other: &sockaddr_storage) -> bool {
762                self.ss_family == other.ss_family
763                    && self.__ss_pad1 == other.__ss_pad1
764                    && self.__ss_align == other.__ss_align
765                    && self
766                    .__ss_pad2
767                    .iter()
768                    .zip(other.__ss_pad2.iter())
769                    .all(|(a, b)| a == b)
770            }
771        }
772        impl Eq for sockaddr_storage {}
773        impl ::fmt::Debug for sockaddr_storage {
774            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
775                f.debug_struct("sockaddr_storage")
776                    .field("ss_family", &self.ss_family)
777                    .field("__ss_pad1", &self.__ss_pad1)
778                    .field("__ss_align", &self.__ss_align)
779                    // FIXME: .field("__ss_pad2", &self.__ss_pad2)
780                    .finish()
781            }
782        }
783        impl ::hash::Hash for sockaddr_storage {
784            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
785                self.ss_family.hash(state);
786                self.__ss_pad1.hash(state);
787                self.__ss_align.hash(state);
788                self.__ss_pad2.hash(state);
789            }
790        }
791
792        impl siginfo_t {
793            /// The siginfo_t will have differing contents based on the delivered signal.  Based on
794            /// `si_signo`, this determines how many of the `c_int` pad fields contain valid data
795            /// exposed by the C unions.
796            ///
797            /// It is not yet exhausitive for the OS-defined types, and defaults to assuming the
798            /// entire data pad area is "valid" for otherwise unrecognized signal numbers.
799            fn data_field_count(&self) -> usize {
800                match self.si_signo {
801                    ::SIGSEGV | ::SIGBUS | ::SIGILL | ::SIGTRAP | ::SIGFPE => {
802                        ::mem::size_of::<siginfo_fault>() / ::mem::size_of::<::c_int>()
803                    }
804                    ::SIGCLD => ::mem::size_of::<siginfo_sigcld>() / ::mem::size_of::<::c_int>(),
805                    ::SIGHUP
806                    | ::SIGINT
807                    | ::SIGQUIT
808                    | ::SIGABRT
809                    | ::SIGSYS
810                    | ::SIGPIPE
811                    | ::SIGALRM
812                    | ::SIGTERM
813                    | ::SIGUSR1
814                    | ::SIGUSR2
815                    | ::SIGPWR
816                    | ::SIGWINCH
817                    | ::SIGURG => ::mem::size_of::<siginfo_kill>() / ::mem::size_of::<::c_int>(),
818                    _ => SIGINFO_DATA_SIZE,
819                }
820            }
821        }
822        impl PartialEq for siginfo_t {
823            fn eq(&self, other: &siginfo_t) -> bool {
824                if self.si_signo == other.si_signo
825                    && self.si_code == other.si_code
826                    && self.si_errno == other.si_errno {
827                        // FIXME: The `si_pad` field in the 64-bit version of the struct is ignored
828                        // (for now) when doing comparisons.
829
830                        let field_count = self.data_field_count();
831                        self.__data_pad[..field_count]
832                            .iter()
833                            .zip(other.__data_pad[..field_count].iter())
834                            .all(|(a, b)| a == b)
835                } else {
836                    false
837                }
838            }
839        }
840        impl Eq for siginfo_t {}
841        impl ::fmt::Debug for siginfo_t {
842            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
843                f.debug_struct("siginfo_t")
844                    .field("si_signo", &self.si_signo)
845                    .field("si_code", &self.si_code)
846                    .field("si_errno", &self.si_errno)
847                    // FIXME: .field("__pad", &self.__pad)
848                    .finish()
849            }
850        }
851        impl ::hash::Hash for siginfo_t {
852            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
853                self.si_signo.hash(state);
854                self.si_code.hash(state);
855                self.si_errno.hash(state);
856
857                // FIXME: The `si_pad` field in the 64-bit version of the struct is ignored
858                // (for now) when doing hashing.
859
860                let field_count = self.data_field_count();
861                self.__data_pad[..field_count].hash(state)
862            }
863        }
864
865        impl PartialEq for sockaddr_dl {
866            fn eq(&self, other: &sockaddr_dl) -> bool {
867                self.sdl_family == other.sdl_family
868                    && self.sdl_index == other.sdl_index
869                    && self.sdl_type == other.sdl_type
870                    && self.sdl_nlen == other.sdl_nlen
871                    && self.sdl_alen == other.sdl_alen
872                    && self.sdl_slen == other.sdl_slen
873                    && self
874                    .sdl_data
875                    .iter()
876                    .zip(other.sdl_data.iter())
877                    .all(|(a,b)| a == b)
878            }
879        }
880        impl Eq for sockaddr_dl {}
881        impl ::fmt::Debug for sockaddr_dl {
882            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
883                f.debug_struct("sockaddr_dl")
884                    .field("sdl_family", &self.sdl_family)
885                    .field("sdl_index", &self.sdl_index)
886                    .field("sdl_type", &self.sdl_type)
887                    .field("sdl_nlen", &self.sdl_nlen)
888                    .field("sdl_alen", &self.sdl_alen)
889                    .field("sdl_slen", &self.sdl_slen)
890                    // FIXME: .field("sdl_data", &self.sdl_data)
891                    .finish()
892            }
893        }
894        impl ::hash::Hash for sockaddr_dl {
895            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
896                self.sdl_family.hash(state);
897                self.sdl_index.hash(state);
898                self.sdl_type.hash(state);
899                self.sdl_nlen.hash(state);
900                self.sdl_alen.hash(state);
901                self.sdl_slen.hash(state);
902                self.sdl_data.hash(state);
903            }
904        }
905
906        impl PartialEq for sigevent {
907            fn eq(&self, other: &sigevent) -> bool {
908                self.sigev_notify == other.sigev_notify
909                    && self.sigev_signo == other.sigev_signo
910                    && self.sigev_value == other.sigev_value
911                    && self.ss_sp == other.ss_sp
912                    && self.sigev_notify_attributes
913                        == other.sigev_notify_attributes
914            }
915        }
916        impl Eq for sigevent {}
917        impl ::fmt::Debug for sigevent {
918            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
919                f.debug_struct("sigevent")
920                    .field("sigev_notify", &self.sigev_notify)
921                    .field("sigev_signo", &self.sigev_signo)
922                    .field("sigev_value", &self.sigev_value)
923                    .field("ss_sp", &self.ss_sp)
924                    .field("sigev_notify_attributes",
925                           &self.sigev_notify_attributes)
926                    .finish()
927            }
928        }
929        impl ::hash::Hash for sigevent {
930            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
931                self.sigev_notify.hash(state);
932                self.sigev_signo.hash(state);
933                self.sigev_value.hash(state);
934                self.ss_sp.hash(state);
935                self.sigev_notify_attributes.hash(state);
936            }
937        }
938
939        #[cfg(libc_union)]
940        impl PartialEq for pad128_t {
941            fn eq(&self, other: &pad128_t) -> bool {
942                unsafe {
943                // FIXME: self._q == other._q ||
944                    self._l == other._l
945                }
946            }
947        }
948        #[cfg(libc_union)]
949        impl Eq for pad128_t {}
950        #[cfg(libc_union)]
951        impl ::fmt::Debug for pad128_t {
952            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
953                unsafe {
954                f.debug_struct("pad128_t")
955                    // FIXME: .field("_q", &{self._q})
956                    .field("_l", &{self._l})
957                    .finish()
958                }
959            }
960        }
961        #[cfg(libc_union)]
962        impl ::hash::Hash for pad128_t {
963            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
964                unsafe {
965                // FIXME: state.write_i64(self._q as i64);
966                self._l.hash(state);
967                }
968            }
969        }
970        #[cfg(libc_union)]
971        impl PartialEq for upad128_t {
972            fn eq(&self, other: &upad128_t) -> bool {
973                unsafe {
974                // FIXME: self._q == other._q ||
975                    self._l == other._l
976                }
977            }
978        }
979        #[cfg(libc_union)]
980        impl Eq for upad128_t {}
981        #[cfg(libc_union)]
982        impl ::fmt::Debug for upad128_t {
983            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
984                unsafe {
985                f.debug_struct("upad128_t")
986                    // FIXME: .field("_q", &{self._q})
987                    .field("_l", &{self._l})
988                    .finish()
989                }
990            }
991        }
992        #[cfg(libc_union)]
993        impl ::hash::Hash for upad128_t {
994            fn hash<H: ::hash::Hasher>(&self, state: &mut H) {
995                unsafe {
996                // FIXME: state.write_i64(self._q as i64);
997                self._l.hash(state);
998                }
999            }
1000        }
1001    }
1002}
1003
1004cfg_if! {
1005    if #[cfg(target_pointer_width = "64")] {
1006        const SIGINFO_DATA_SIZE: usize = 60;
1007    } else {
1008        const SIGINFO_DATA_SIZE: usize = 29;
1009    }
1010}
1011
1012#[repr(C)]
1013struct siginfo_fault {
1014    addr: *mut ::c_void,
1015    trapno: ::c_int,
1016    pc: *mut ::caddr_t,
1017}
1018impl ::Copy for siginfo_fault {}
1019impl ::Clone for siginfo_fault {
1020    fn clone(&self) -> Self {
1021        *self
1022    }
1023}
1024
1025#[repr(C)]
1026struct siginfo_cldval {
1027    utime: ::clock_t,
1028    status: ::c_int,
1029    stime: ::clock_t,
1030}
1031impl ::Copy for siginfo_cldval {}
1032impl ::Clone for siginfo_cldval {
1033    fn clone(&self) -> Self {
1034        *self
1035    }
1036}
1037
1038#[repr(C)]
1039struct siginfo_killval {
1040    uid: ::uid_t,
1041    value: ::sigval,
1042    // Pad out to match the SIGCLD value size
1043    _pad: *mut ::c_void,
1044}
1045impl ::Copy for siginfo_killval {}
1046impl ::Clone for siginfo_killval {
1047    fn clone(&self) -> Self {
1048        *self
1049    }
1050}
1051
1052#[repr(C)]
1053struct siginfo_sigcld {
1054    pid: ::pid_t,
1055    val: siginfo_cldval,
1056    ctid: ::ctid_t,
1057    zoneid: ::zoneid_t,
1058}
1059impl ::Copy for siginfo_sigcld {}
1060impl ::Clone for siginfo_sigcld {
1061    fn clone(&self) -> Self {
1062        *self
1063    }
1064}
1065
1066#[repr(C)]
1067struct siginfo_kill {
1068    pid: ::pid_t,
1069    val: siginfo_killval,
1070    ctid: ::ctid_t,
1071    zoneid: ::zoneid_t,
1072}
1073impl ::Copy for siginfo_kill {}
1074impl ::Clone for siginfo_kill {
1075    fn clone(&self) -> Self {
1076        *self
1077    }
1078}
1079
1080impl siginfo_t {
1081    unsafe fn sidata<T: ::Copy>(&self) -> T {
1082        *((&self.__data_pad) as *const ::c_int as *const T)
1083    }
1084    pub unsafe fn si_addr(&self) -> *mut ::c_void {
1085        let sifault: siginfo_fault = self.sidata();
1086        sifault.addr
1087    }
1088    pub unsafe fn si_uid(&self) -> ::uid_t {
1089        let kill: siginfo_kill = self.sidata();
1090        kill.val.uid
1091    }
1092    pub unsafe fn si_value(&self) -> ::sigval {
1093        let kill: siginfo_kill = self.sidata();
1094        kill.val.value
1095    }
1096    pub unsafe fn si_pid(&self) -> ::pid_t {
1097        let sigcld: siginfo_sigcld = self.sidata();
1098        sigcld.pid
1099    }
1100    pub unsafe fn si_status(&self) -> ::c_int {
1101        let sigcld: siginfo_sigcld = self.sidata();
1102        sigcld.val.status
1103    }
1104    pub unsafe fn si_utime(&self) -> ::c_long {
1105        let sigcld: siginfo_sigcld = self.sidata();
1106        sigcld.val.utime
1107    }
1108    pub unsafe fn si_stime(&self) -> ::c_long {
1109        let sigcld: siginfo_sigcld = self.sidata();
1110        sigcld.val.stime
1111    }
1112}
1113
1114pub const LC_CTYPE: ::c_int = 0;
1115pub const LC_NUMERIC: ::c_int = 1;
1116pub const LC_TIME: ::c_int = 2;
1117pub const LC_COLLATE: ::c_int = 3;
1118pub const LC_MONETARY: ::c_int = 4;
1119pub const LC_MESSAGES: ::c_int = 5;
1120pub const LC_ALL: ::c_int = 6;
1121pub const LC_CTYPE_MASK: ::c_int = 1 << LC_CTYPE;
1122pub const LC_NUMERIC_MASK: ::c_int = 1 << LC_NUMERIC;
1123pub const LC_TIME_MASK: ::c_int = 1 << LC_TIME;
1124pub const LC_COLLATE_MASK: ::c_int = 1 << LC_COLLATE;
1125pub const LC_MONETARY_MASK: ::c_int = 1 << LC_MONETARY;
1126pub const LC_MESSAGES_MASK: ::c_int = 1 << LC_MESSAGES;
1127pub const LC_ALL_MASK: ::c_int = LC_CTYPE_MASK
1128    | LC_NUMERIC_MASK
1129    | LC_TIME_MASK
1130    | LC_COLLATE_MASK
1131    | LC_MONETARY_MASK
1132    | LC_MESSAGES_MASK;
1133
1134pub const DAY_1: ::nl_item = 1;
1135pub const DAY_2: ::nl_item = 2;
1136pub const DAY_3: ::nl_item = 3;
1137pub const DAY_4: ::nl_item = 4;
1138pub const DAY_5: ::nl_item = 5;
1139pub const DAY_6: ::nl_item = 6;
1140pub const DAY_7: ::nl_item = 7;
1141
1142pub const ABDAY_1: ::nl_item = 8;
1143pub const ABDAY_2: ::nl_item = 9;
1144pub const ABDAY_3: ::nl_item = 10;
1145pub const ABDAY_4: ::nl_item = 11;
1146pub const ABDAY_5: ::nl_item = 12;
1147pub const ABDAY_6: ::nl_item = 13;
1148pub const ABDAY_7: ::nl_item = 14;
1149
1150pub const MON_1: ::nl_item = 15;
1151pub const MON_2: ::nl_item = 16;
1152pub const MON_3: ::nl_item = 17;
1153pub const MON_4: ::nl_item = 18;
1154pub const MON_5: ::nl_item = 19;
1155pub const MON_6: ::nl_item = 20;
1156pub const MON_7: ::nl_item = 21;
1157pub const MON_8: ::nl_item = 22;
1158pub const MON_9: ::nl_item = 23;
1159pub const MON_10: ::nl_item = 24;
1160pub const MON_11: ::nl_item = 25;
1161pub const MON_12: ::nl_item = 26;
1162
1163pub const ABMON_1: ::nl_item = 27;
1164pub const ABMON_2: ::nl_item = 28;
1165pub const ABMON_3: ::nl_item = 29;
1166pub const ABMON_4: ::nl_item = 30;
1167pub const ABMON_5: ::nl_item = 31;
1168pub const ABMON_6: ::nl_item = 32;
1169pub const ABMON_7: ::nl_item = 33;
1170pub const ABMON_8: ::nl_item = 34;
1171pub const ABMON_9: ::nl_item = 35;
1172pub const ABMON_10: ::nl_item = 36;
1173pub const ABMON_11: ::nl_item = 37;
1174pub const ABMON_12: ::nl_item = 38;
1175
1176pub const RADIXCHAR: ::nl_item = 39;
1177pub const THOUSEP: ::nl_item = 40;
1178pub const YESSTR: ::nl_item = 41;
1179pub const NOSTR: ::nl_item = 42;
1180pub const CRNCYSTR: ::nl_item = 43;
1181
1182pub const D_T_FMT: ::nl_item = 44;
1183pub const D_FMT: ::nl_item = 45;
1184pub const T_FMT: ::nl_item = 46;
1185pub const AM_STR: ::nl_item = 47;
1186pub const PM_STR: ::nl_item = 48;
1187
1188pub const CODESET: ::nl_item = 49;
1189pub const T_FMT_AMPM: ::nl_item = 50;
1190pub const ERA: ::nl_item = 51;
1191pub const ERA_D_FMT: ::nl_item = 52;
1192pub const ERA_D_T_FMT: ::nl_item = 53;
1193pub const ERA_T_FMT: ::nl_item = 54;
1194pub const ALT_DIGITS: ::nl_item = 55;
1195pub const YESEXPR: ::nl_item = 56;
1196pub const NOEXPR: ::nl_item = 57;
1197pub const _DATE_FMT: ::nl_item = 58;
1198pub const MAXSTRMSG: ::nl_item = 58;
1199
1200pub const PATH_MAX: ::c_int = 1024;
1201
1202pub const SA_ONSTACK: ::c_int = 0x00000001;
1203pub const SA_RESETHAND: ::c_int = 0x00000002;
1204pub const SA_RESTART: ::c_int = 0x00000004;
1205pub const SA_SIGINFO: ::c_int = 0x00000008;
1206pub const SA_NODEFER: ::c_int = 0x00000010;
1207pub const SA_NOCLDWAIT: ::c_int = 0x00010000;
1208pub const SA_NOCLDSTOP: ::c_int = 0x00020000;
1209
1210pub const SS_ONSTACK: ::c_int = 1;
1211pub const SS_DISABLE: ::c_int = 2;
1212
1213pub const FIOCLEX: ::c_int = 0x20006601;
1214pub const FIONCLEX: ::c_int = 0x20006602;
1215pub const FIONREAD: ::c_int = 0x4004667f;
1216pub const FIONBIO: ::c_int = 0x8004667e;
1217pub const FIOASYNC: ::c_int = 0x8004667d;
1218pub const FIOSETOWN: ::c_int = 0x8004667c;
1219pub const FIOGETOWN: ::c_int = 0x4004667b;
1220
1221pub const SIGCHLD: ::c_int = 18;
1222pub const SIGCLD: ::c_int = ::SIGCHLD;
1223pub const SIGBUS: ::c_int = 10;
1224pub const SIGINFO: ::c_int = 41;
1225pub const SIG_BLOCK: ::c_int = 1;
1226pub const SIG_UNBLOCK: ::c_int = 2;
1227pub const SIG_SETMASK: ::c_int = 3;
1228
1229pub const SIGEV_NONE: ::c_int = 1;
1230pub const SIGEV_SIGNAL: ::c_int = 2;
1231pub const SIGEV_THREAD: ::c_int = 3;
1232
1233pub const CLD_EXITED: ::c_int = 1;
1234pub const CLD_KILLED: ::c_int = 2;
1235pub const CLD_DUMPED: ::c_int = 3;
1236pub const CLD_TRAPPED: ::c_int = 4;
1237pub const CLD_STOPPED: ::c_int = 5;
1238pub const CLD_CONTINUED: ::c_int = 6;
1239
1240pub const IP_RECVDSTADDR: ::c_int = 0x7;
1241pub const IP_SEC_OPT: ::c_int = 0x22;
1242
1243pub const IPV6_UNICAST_HOPS: ::c_int = 0x5;
1244pub const IPV6_MULTICAST_IF: ::c_int = 0x6;
1245pub const IPV6_MULTICAST_HOPS: ::c_int = 0x7;
1246pub const IPV6_MULTICAST_LOOP: ::c_int = 0x8;
1247pub const IPV6_RECVPKTINFO: ::c_int = 0x12;
1248pub const IPV6_SEC_OPT: ::c_int = 0x22;
1249pub const IPV6_V6ONLY: ::c_int = 0x27;
1250
1251cfg_if! {
1252    if #[cfg(target_pointer_width = "64")] {
1253        pub const FD_SETSIZE: usize = 65536;
1254    } else {
1255        pub const FD_SETSIZE: usize = 1024;
1256    }
1257}
1258
1259pub const ST_RDONLY: ::c_ulong = 1;
1260pub const ST_NOSUID: ::c_ulong = 2;
1261
1262pub const NI_MAXHOST: ::socklen_t = 1025;
1263pub const NI_MAXSERV: ::socklen_t = 32;
1264
1265pub const EXIT_FAILURE: ::c_int = 1;
1266pub const EXIT_SUCCESS: ::c_int = 0;
1267pub const RAND_MAX: ::c_int = 32767;
1268pub const EOF: ::c_int = -1;
1269pub const SEEK_SET: ::c_int = 0;
1270pub const SEEK_CUR: ::c_int = 1;
1271pub const SEEK_END: ::c_int = 2;
1272pub const SEEK_DATA: ::c_int = 3;
1273pub const SEEK_HOLE: ::c_int = 4;
1274pub const _IOFBF: ::c_int = 0;
1275pub const _IONBF: ::c_int = 4;
1276pub const _IOLBF: ::c_int = 64;
1277pub const BUFSIZ: ::c_uint = 1024;
1278pub const FOPEN_MAX: ::c_uint = 20;
1279pub const FILENAME_MAX: ::c_uint = 1024;
1280pub const L_tmpnam: ::c_uint = 25;
1281pub const TMP_MAX: ::c_uint = 17576;
1282
1283pub const GRND_NONBLOCK: ::c_int = 0x0001;
1284pub const GRND_RANDOM: ::c_int = 0x0002;
1285
1286pub const O_RDONLY: ::c_int = 0;
1287pub const O_WRONLY: ::c_int = 1;
1288pub const O_RDWR: ::c_int = 2;
1289pub const O_NDELAY: ::c_int = 0x04;
1290pub const O_APPEND: ::c_int = 8;
1291pub const O_DSYNC: ::c_int = 0x40;
1292pub const O_CREAT: ::c_int = 256;
1293pub const O_EXCL: ::c_int = 1024;
1294pub const O_NOCTTY: ::c_int = 2048;
1295pub const O_TRUNC: ::c_int = 512;
1296pub const O_NOFOLLOW: ::c_int = 0x20000;
1297pub const O_DIRECTORY: ::c_int = 0x1000000;
1298pub const O_SEARCH: ::c_int = 0x200000;
1299pub const O_EXEC: ::c_int = 0x400000;
1300pub const O_CLOEXEC: ::c_int = 0x800000;
1301pub const O_ACCMODE: ::c_int = 0x600003;
1302pub const O_XATTR: ::c_int = 0x4000;
1303pub const S_IFIFO: mode_t = 4096;
1304pub const S_IFCHR: mode_t = 8192;
1305pub const S_IFBLK: mode_t = 24576;
1306pub const S_IFDIR: mode_t = 16384;
1307pub const S_IFREG: mode_t = 32768;
1308pub const S_IFLNK: mode_t = 40960;
1309pub const S_IFSOCK: mode_t = 49152;
1310pub const S_IFMT: mode_t = 61440;
1311pub const S_IEXEC: mode_t = 64;
1312pub const S_IWRITE: mode_t = 128;
1313pub const S_IREAD: mode_t = 256;
1314pub const S_IRWXU: mode_t = 448;
1315pub const S_IXUSR: mode_t = 64;
1316pub const S_IWUSR: mode_t = 128;
1317pub const S_IRUSR: mode_t = 256;
1318pub const S_IRWXG: mode_t = 56;
1319pub const S_IXGRP: mode_t = 8;
1320pub const S_IWGRP: mode_t = 16;
1321pub const S_IRGRP: mode_t = 32;
1322pub const S_IRWXO: mode_t = 7;
1323pub const S_IXOTH: mode_t = 1;
1324pub const S_IWOTH: mode_t = 2;
1325pub const S_IROTH: mode_t = 4;
1326pub const F_OK: ::c_int = 0;
1327pub const R_OK: ::c_int = 4;
1328pub const W_OK: ::c_int = 2;
1329pub const X_OK: ::c_int = 1;
1330pub const STDIN_FILENO: ::c_int = 0;
1331pub const STDOUT_FILENO: ::c_int = 1;
1332pub const STDERR_FILENO: ::c_int = 2;
1333pub const F_LOCK: ::c_int = 1;
1334pub const F_TEST: ::c_int = 3;
1335pub const F_TLOCK: ::c_int = 2;
1336pub const F_ULOCK: ::c_int = 0;
1337pub const F_SETLK: ::c_int = 6;
1338pub const F_SETLKW: ::c_int = 7;
1339pub const F_GETLK: ::c_int = 14;
1340pub const F_ALLOCSP: ::c_int = 10;
1341pub const F_FREESP: ::c_int = 11;
1342pub const F_BLOCKS: ::c_int = 18;
1343pub const F_BLKSIZE: ::c_int = 19;
1344pub const F_SHARE: ::c_int = 40;
1345pub const F_UNSHARE: ::c_int = 41;
1346pub const F_ISSTREAM: ::c_int = 13;
1347pub const F_PRIV: ::c_int = 15;
1348pub const F_NPRIV: ::c_int = 16;
1349pub const F_QUOTACTL: ::c_int = 17;
1350pub const F_GETOWN: ::c_int = 23;
1351pub const F_SETOWN: ::c_int = 24;
1352pub const F_REVOKE: ::c_int = 25;
1353pub const F_HASREMOTELOCKS: ::c_int = 26;
1354pub const SIGHUP: ::c_int = 1;
1355pub const SIGINT: ::c_int = 2;
1356pub const SIGQUIT: ::c_int = 3;
1357pub const SIGILL: ::c_int = 4;
1358pub const SIGABRT: ::c_int = 6;
1359pub const SIGEMT: ::c_int = 7;
1360pub const SIGFPE: ::c_int = 8;
1361pub const SIGKILL: ::c_int = 9;
1362pub const SIGSEGV: ::c_int = 11;
1363pub const SIGSYS: ::c_int = 12;
1364pub const SIGPIPE: ::c_int = 13;
1365pub const SIGALRM: ::c_int = 14;
1366pub const SIGTERM: ::c_int = 15;
1367pub const SIGUSR1: ::c_int = 16;
1368pub const SIGUSR2: ::c_int = 17;
1369pub const SIGPWR: ::c_int = 19;
1370pub const SIGWINCH: ::c_int = 20;
1371pub const SIGURG: ::c_int = 21;
1372pub const SIGPOLL: ::c_int = 22;
1373pub const SIGIO: ::c_int = SIGPOLL;
1374pub const SIGSTOP: ::c_int = 23;
1375pub const SIGTSTP: ::c_int = 24;
1376pub const SIGCONT: ::c_int = 25;
1377pub const SIGTTIN: ::c_int = 26;
1378pub const SIGTTOU: ::c_int = 27;
1379pub const SIGVTALRM: ::c_int = 28;
1380pub const SIGPROF: ::c_int = 29;
1381pub const SIGXCPU: ::c_int = 30;
1382pub const SIGXFSZ: ::c_int = 31;
1383
1384pub const WNOHANG: ::c_int = 0x40;
1385pub const WUNTRACED: ::c_int = 0x04;
1386
1387pub const WEXITED: ::c_int = 0x01;
1388pub const WTRAPPED: ::c_int = 0x02;
1389pub const WSTOPPED: ::c_int = WUNTRACED;
1390pub const WCONTINUED: ::c_int = 0x08;
1391pub const WNOWAIT: ::c_int = 0x80;
1392
1393pub const AT_FDCWD: ::c_int = 0xffd19553;
1394pub const AT_SYMLINK_NOFOLLOW: ::c_int = 0x1000;
1395pub const AT_SYMLINK_FOLLOW: ::c_int = 0x2000;
1396pub const AT_REMOVEDIR: ::c_int = 0x1;
1397pub const _AT_TRIGGER: ::c_int = 0x2;
1398pub const AT_EACCESS: ::c_int = 0x4;
1399
1400pub const P_PID: idtype_t = 0;
1401pub const P_PPID: idtype_t = 1;
1402pub const P_PGID: idtype_t = 2;
1403pub const P_SID: idtype_t = 3;
1404pub const P_CID: idtype_t = 4;
1405pub const P_UID: idtype_t = 5;
1406pub const P_GID: idtype_t = 6;
1407pub const P_ALL: idtype_t = 7;
1408pub const P_LWPID: idtype_t = 8;
1409pub const P_TASKID: idtype_t = 9;
1410pub const P_PROJID: idtype_t = 10;
1411pub const P_POOLID: idtype_t = 11;
1412pub const P_ZONEID: idtype_t = 12;
1413pub const P_CTID: idtype_t = 13;
1414pub const P_CPUID: idtype_t = 14;
1415pub const P_PSETID: idtype_t = 15;
1416
1417pub const PBIND_NONE: ::processorid_t = -1;
1418pub const PBIND_QUERY: ::processorid_t = -2;
1419pub const PBIND_HARD: ::processorid_t = -3;
1420pub const PBIND_SOFT: ::processorid_t = -4;
1421
1422pub const PS_NONE: ::c_int = -1;
1423pub const PS_QUERY: ::c_int = -2;
1424pub const PS_MYID: ::c_int = -3;
1425pub const PS_SOFT: ::c_int = -4;
1426pub const PS_HARD: ::c_int = -5;
1427pub const PS_QUERY_TYPE: ::c_int = -6;
1428pub const PS_SYSTEM: ::c_int = 1;
1429pub const PS_PRIVATE: ::c_int = 2;
1430
1431pub const UTIME_OMIT: c_long = -2;
1432pub const UTIME_NOW: c_long = -1;
1433
1434pub const PROT_NONE: ::c_int = 0;
1435pub const PROT_READ: ::c_int = 1;
1436pub const PROT_WRITE: ::c_int = 2;
1437pub const PROT_EXEC: ::c_int = 4;
1438
1439pub const MAP_FILE: ::c_int = 0;
1440pub const MAP_SHARED: ::c_int = 0x0001;
1441pub const MAP_PRIVATE: ::c_int = 0x0002;
1442pub const MAP_FIXED: ::c_int = 0x0010;
1443pub const MAP_NORESERVE: ::c_int = 0x40;
1444pub const MAP_ANON: ::c_int = 0x0100;
1445pub const MAP_ANONYMOUS: ::c_int = 0x0100;
1446pub const MAP_RENAME: ::c_int = 0x20;
1447pub const MAP_ALIGN: ::c_int = 0x200;
1448pub const MAP_TEXT: ::c_int = 0x400;
1449pub const MAP_INITDATA: ::c_int = 0x800;
1450pub const MAP_32BIT: ::c_int = 0x80;
1451pub const MAP_FAILED: *mut ::c_void = !0 as *mut ::c_void;
1452
1453pub const MCL_CURRENT: ::c_int = 0x0001;
1454pub const MCL_FUTURE: ::c_int = 0x0002;
1455
1456pub const MS_SYNC: ::c_int = 0x0004;
1457pub const MS_ASYNC: ::c_int = 0x0001;
1458pub const MS_INVALIDATE: ::c_int = 0x0002;
1459
1460pub const MMOBJ_PADDING: ::c_uint = 0x10000;
1461pub const MMOBJ_INTERPRET: ::c_uint = 0x20000;
1462pub const MR_PADDING: ::c_uint = 0x1;
1463pub const MR_HDR_ELF: ::c_uint = 0x2;
1464
1465pub const EPERM: ::c_int = 1;
1466pub const ENOENT: ::c_int = 2;
1467pub const ESRCH: ::c_int = 3;
1468pub const EINTR: ::c_int = 4;
1469pub const EIO: ::c_int = 5;
1470pub const ENXIO: ::c_int = 6;
1471pub const E2BIG: ::c_int = 7;
1472pub const ENOEXEC: ::c_int = 8;
1473pub const EBADF: ::c_int = 9;
1474pub const ECHILD: ::c_int = 10;
1475pub const EAGAIN: ::c_int = 11;
1476pub const ENOMEM: ::c_int = 12;
1477pub const EACCES: ::c_int = 13;
1478pub const EFAULT: ::c_int = 14;
1479pub const ENOTBLK: ::c_int = 15;
1480pub const EBUSY: ::c_int = 16;
1481pub const EEXIST: ::c_int = 17;
1482pub const EXDEV: ::c_int = 18;
1483pub const ENODEV: ::c_int = 19;
1484pub const ENOTDIR: ::c_int = 20;
1485pub const EISDIR: ::c_int = 21;
1486pub const EINVAL: ::c_int = 22;
1487pub const ENFILE: ::c_int = 23;
1488pub const EMFILE: ::c_int = 24;
1489pub const ENOTTY: ::c_int = 25;
1490pub const ETXTBSY: ::c_int = 26;
1491pub const EFBIG: ::c_int = 27;
1492pub const ENOSPC: ::c_int = 28;
1493pub const ESPIPE: ::c_int = 29;
1494pub const EROFS: ::c_int = 30;
1495pub const EMLINK: ::c_int = 31;
1496pub const EPIPE: ::c_int = 32;
1497pub const EDOM: ::c_int = 33;
1498pub const ERANGE: ::c_int = 34;
1499pub const ENOMSG: ::c_int = 35;
1500pub const EIDRM: ::c_int = 36;
1501pub const ECHRNG: ::c_int = 37;
1502pub const EL2NSYNC: ::c_int = 38;
1503pub const EL3HLT: ::c_int = 39;
1504pub const EL3RST: ::c_int = 40;
1505pub const ELNRNG: ::c_int = 41;
1506pub const EUNATCH: ::c_int = 42;
1507pub const ENOCSI: ::c_int = 43;
1508pub const EL2HLT: ::c_int = 44;
1509pub const EDEADLK: ::c_int = 45;
1510pub const ENOLCK: ::c_int = 46;
1511pub const ECANCELED: ::c_int = 47;
1512pub const ENOTSUP: ::c_int = 48;
1513pub const EDQUOT: ::c_int = 49;
1514pub const EBADE: ::c_int = 50;
1515pub const EBADR: ::c_int = 51;
1516pub const EXFULL: ::c_int = 52;
1517pub const ENOANO: ::c_int = 53;
1518pub const EBADRQC: ::c_int = 54;
1519pub const EBADSLT: ::c_int = 55;
1520pub const EDEADLOCK: ::c_int = 56;
1521pub const EBFONT: ::c_int = 57;
1522pub const EOWNERDEAD: ::c_int = 58;
1523pub const ENOTRECOVERABLE: ::c_int = 59;
1524pub const ENOSTR: ::c_int = 60;
1525pub const ENODATA: ::c_int = 61;
1526pub const ETIME: ::c_int = 62;
1527pub const ENOSR: ::c_int = 63;
1528pub const ENONET: ::c_int = 64;
1529pub const ENOPKG: ::c_int = 65;
1530pub const EREMOTE: ::c_int = 66;
1531pub const ENOLINK: ::c_int = 67;
1532pub const EADV: ::c_int = 68;
1533pub const ESRMNT: ::c_int = 69;
1534pub const ECOMM: ::c_int = 70;
1535pub const EPROTO: ::c_int = 71;
1536pub const ELOCKUNMAPPED: ::c_int = 72;
1537pub const ENOTACTIVE: ::c_int = 73;
1538pub const EMULTIHOP: ::c_int = 74;
1539pub const EADI: ::c_int = 75;
1540pub const EBADMSG: ::c_int = 77;
1541pub const ENAMETOOLONG: ::c_int = 78;
1542pub const EOVERFLOW: ::c_int = 79;
1543pub const ENOTUNIQ: ::c_int = 80;
1544pub const EBADFD: ::c_int = 81;
1545pub const EREMCHG: ::c_int = 82;
1546pub const ELIBACC: ::c_int = 83;
1547pub const ELIBBAD: ::c_int = 84;
1548pub const ELIBSCN: ::c_int = 85;
1549pub const ELIBMAX: ::c_int = 86;
1550pub const ELIBEXEC: ::c_int = 87;
1551pub const EILSEQ: ::c_int = 88;
1552pub const ENOSYS: ::c_int = 89;
1553pub const ELOOP: ::c_int = 90;
1554pub const ERESTART: ::c_int = 91;
1555pub const ESTRPIPE: ::c_int = 92;
1556pub const ENOTEMPTY: ::c_int = 93;
1557pub const EUSERS: ::c_int = 94;
1558pub const ENOTSOCK: ::c_int = 95;
1559pub const EDESTADDRREQ: ::c_int = 96;
1560pub const EMSGSIZE: ::c_int = 97;
1561pub const EPROTOTYPE: ::c_int = 98;
1562pub const ENOPROTOOPT: ::c_int = 99;
1563pub const EPROTONOSUPPORT: ::c_int = 120;
1564pub const ESOCKTNOSUPPORT: ::c_int = 121;
1565pub const EOPNOTSUPP: ::c_int = 122;
1566pub const EPFNOSUPPORT: ::c_int = 123;
1567pub const EAFNOSUPPORT: ::c_int = 124;
1568pub const EADDRINUSE: ::c_int = 125;
1569pub const EADDRNOTAVAIL: ::c_int = 126;
1570pub const ENETDOWN: ::c_int = 127;
1571pub const ENETUNREACH: ::c_int = 128;
1572pub const ENETRESET: ::c_int = 129;
1573pub const ECONNABORTED: ::c_int = 130;
1574pub const ECONNRESET: ::c_int = 131;
1575pub const ENOBUFS: ::c_int = 132;
1576pub const EISCONN: ::c_int = 133;
1577pub const ENOTCONN: ::c_int = 134;
1578pub const ESHUTDOWN: ::c_int = 143;
1579pub const ETOOMANYREFS: ::c_int = 144;
1580pub const ETIMEDOUT: ::c_int = 145;
1581pub const ECONNREFUSED: ::c_int = 146;
1582pub const EHOSTDOWN: ::c_int = 147;
1583pub const EHOSTUNREACH: ::c_int = 148;
1584pub const EWOULDBLOCK: ::c_int = EAGAIN;
1585pub const EALREADY: ::c_int = 149;
1586pub const EINPROGRESS: ::c_int = 150;
1587pub const ESTALE: ::c_int = 151;
1588
1589pub const EAI_AGAIN: ::c_int = 2;
1590pub const EAI_BADFLAGS: ::c_int = 3;
1591pub const EAI_FAIL: ::c_int = 4;
1592pub const EAI_FAMILY: ::c_int = 5;
1593pub const EAI_MEMORY: ::c_int = 6;
1594pub const EAI_NODATA: ::c_int = 7;
1595pub const EAI_NONAME: ::c_int = 8;
1596pub const EAI_SERVICE: ::c_int = 9;
1597pub const EAI_SOCKTYPE: ::c_int = 10;
1598pub const EAI_SYSTEM: ::c_int = 11;
1599pub const EAI_OVERFLOW: ::c_int = 12;
1600
1601pub const NI_NOFQDN: ::c_uint = 0x0001;
1602pub const NI_NUMERICHOST: ::c_uint = 0x0002;
1603pub const NI_NAMEREQD: ::c_uint = 0x0004;
1604pub const NI_NUMERICSERV: ::c_uint = 0x0008;
1605pub const NI_DGRAM: ::c_uint = 0x0010;
1606pub const NI_WITHSCOPEID: ::c_uint = 0x0020;
1607pub const NI_NUMERICSCOPE: ::c_uint = 0x0040;
1608
1609pub const F_DUPFD: ::c_int = 0;
1610pub const F_DUP2FD: ::c_int = 9;
1611pub const F_GETFD: ::c_int = 1;
1612pub const F_SETFD: ::c_int = 2;
1613pub const F_GETFL: ::c_int = 3;
1614pub const F_SETFL: ::c_int = 4;
1615pub const F_GETXFL: ::c_int = 45;
1616
1617pub const SIGTRAP: ::c_int = 5;
1618
1619pub const GLOB_APPEND: ::c_int = 32;
1620pub const GLOB_DOOFFS: ::c_int = 16;
1621pub const GLOB_ERR: ::c_int = 1;
1622pub const GLOB_MARK: ::c_int = 2;
1623pub const GLOB_NOCHECK: ::c_int = 8;
1624pub const GLOB_NOSORT: ::c_int = 4;
1625pub const GLOB_NOESCAPE: ::c_int = 64;
1626
1627pub const GLOB_NOSPACE: ::c_int = -2;
1628pub const GLOB_ABORTED: ::c_int = -1;
1629pub const GLOB_NOMATCH: ::c_int = -3;
1630
1631pub const POLLIN: ::c_short = 0x1;
1632pub const POLLPRI: ::c_short = 0x2;
1633pub const POLLOUT: ::c_short = 0x4;
1634pub const POLLERR: ::c_short = 0x8;
1635pub const POLLHUP: ::c_short = 0x10;
1636pub const POLLNVAL: ::c_short = 0x20;
1637pub const POLLNORM: ::c_short = 0x0040;
1638pub const POLLRDNORM: ::c_short = 0x0040;
1639pub const POLLWRNORM: ::c_short = 0x4; /* POLLOUT */
1640pub const POLLRDBAND: ::c_short = 0x0080;
1641pub const POLLWRBAND: ::c_short = 0x0100;
1642
1643pub const POSIX_MADV_NORMAL: ::c_int = 0;
1644pub const POSIX_MADV_RANDOM: ::c_int = 1;
1645pub const POSIX_MADV_SEQUENTIAL: ::c_int = 2;
1646pub const POSIX_MADV_WILLNEED: ::c_int = 3;
1647pub const POSIX_MADV_DONTNEED: ::c_int = 4;
1648
1649pub const PTHREAD_CREATE_JOINABLE: ::c_int = 0;
1650pub const PTHREAD_CREATE_DETACHED: ::c_int = 0x40;
1651pub const PTHREAD_PROCESS_SHARED: ::c_int = 1;
1652pub const PTHREAD_PROCESS_PRIVATE: ::c_ushort = 0;
1653pub const PTHREAD_STACK_MIN: ::size_t = 4096;
1654
1655pub const SIGSTKSZ: ::size_t = 8192;
1656
1657// https://illumos.org/man/3c/clock_gettime
1658// https://github.com/illumos/illumos-gate/
1659//   blob/HEAD/usr/src/lib/libc/amd64/sys/__clock_gettime.s
1660// clock_gettime(3c) doesn't seem to accept anything other than CLOCK_REALTIME
1661// or __CLOCK_REALTIME0
1662//
1663// https://github.com/illumos/illumos-gate/
1664//   blob/HEAD/usr/src/uts/common/sys/time_impl.h
1665// Confusing! CLOCK_HIGHRES==CLOCK_MONOTONIC==4
1666// __CLOCK_REALTIME0==0 is an obsoleted version of CLOCK_REALTIME==3
1667pub const CLOCK_REALTIME: ::clockid_t = 3;
1668pub const CLOCK_MONOTONIC: ::clockid_t = 4;
1669pub const TIMER_RELTIME: ::c_int = 0;
1670pub const TIMER_ABSTIME: ::c_int = 1;
1671
1672pub const RLIMIT_CPU: ::c_int = 0;
1673pub const RLIMIT_FSIZE: ::c_int = 1;
1674pub const RLIMIT_DATA: ::c_int = 2;
1675pub const RLIMIT_STACK: ::c_int = 3;
1676pub const RLIMIT_CORE: ::c_int = 4;
1677pub const RLIMIT_NOFILE: ::c_int = 5;
1678pub const RLIMIT_VMEM: ::c_int = 6;
1679pub const RLIMIT_AS: ::c_int = RLIMIT_VMEM;
1680
1681#[deprecated(since = "0.2.64", note = "Not stable across OS versions")]
1682pub const RLIM_NLIMITS: rlim_t = 7;
1683pub const RLIM_INFINITY: rlim_t = 0xfffffffffffffffd;
1684
1685pub const RUSAGE_SELF: ::c_int = 0;
1686pub const RUSAGE_CHILDREN: ::c_int = -1;
1687
1688pub const MADV_NORMAL: ::c_int = 0;
1689pub const MADV_RANDOM: ::c_int = 1;
1690pub const MADV_SEQUENTIAL: ::c_int = 2;
1691pub const MADV_WILLNEED: ::c_int = 3;
1692pub const MADV_DONTNEED: ::c_int = 4;
1693pub const MADV_FREE: ::c_int = 5;
1694pub const MADV_ACCESS_DEFAULT: ::c_int = 6;
1695pub const MADV_ACCESS_LWP: ::c_int = 7;
1696pub const MADV_ACCESS_MANY: ::c_int = 8;
1697
1698pub const AF_UNSPEC: ::c_int = 0;
1699pub const AF_UNIX: ::c_int = 1;
1700pub const AF_INET: ::c_int = 2;
1701pub const AF_IMPLINK: ::c_int = 3;
1702pub const AF_PUP: ::c_int = 4;
1703pub const AF_CHAOS: ::c_int = 5;
1704pub const AF_NS: ::c_int = 6;
1705pub const AF_NBS: ::c_int = 7;
1706pub const AF_ECMA: ::c_int = 8;
1707pub const AF_DATAKIT: ::c_int = 9;
1708pub const AF_CCITT: ::c_int = 10;
1709pub const AF_SNA: ::c_int = 11;
1710pub const AF_DECnet: ::c_int = 12;
1711pub const AF_DLI: ::c_int = 13;
1712pub const AF_LAT: ::c_int = 14;
1713pub const AF_HYLINK: ::c_int = 15;
1714pub const AF_APPLETALK: ::c_int = 16;
1715pub const AF_NIT: ::c_int = 17;
1716pub const AF_802: ::c_int = 18;
1717pub const AF_OSI: ::c_int = 19;
1718pub const AF_X25: ::c_int = 20;
1719pub const AF_OSINET: ::c_int = 21;
1720pub const AF_GOSIP: ::c_int = 22;
1721pub const AF_IPX: ::c_int = 23;
1722pub const AF_ROUTE: ::c_int = 24;
1723pub const AF_LINK: ::c_int = 25;
1724pub const AF_INET6: ::c_int = 26;
1725pub const AF_KEY: ::c_int = 27;
1726pub const AF_NCA: ::c_int = 28;
1727pub const AF_POLICY: ::c_int = 29;
1728pub const AF_INET_OFFLOAD: ::c_int = 30;
1729pub const AF_TRILL: ::c_int = 31;
1730pub const AF_PACKET: ::c_int = 32;
1731
1732pub const PF_UNSPEC: ::c_int = AF_UNSPEC;
1733pub const PF_UNIX: ::c_int = AF_UNIX;
1734pub const PF_LOCAL: ::c_int = PF_UNIX;
1735pub const PF_FILE: ::c_int = PF_UNIX;
1736pub const PF_INET: ::c_int = AF_INET;
1737pub const PF_IMPLINK: ::c_int = AF_IMPLINK;
1738pub const PF_PUP: ::c_int = AF_PUP;
1739pub const PF_CHAOS: ::c_int = AF_CHAOS;
1740pub const PF_NS: ::c_int = AF_NS;
1741pub const PF_NBS: ::c_int = AF_NBS;
1742pub const PF_ECMA: ::c_int = AF_ECMA;
1743pub const PF_DATAKIT: ::c_int = AF_DATAKIT;
1744pub const PF_CCITT: ::c_int = AF_CCITT;
1745pub const PF_SNA: ::c_int = AF_SNA;
1746pub const PF_DECnet: ::c_int = AF_DECnet;
1747pub const PF_DLI: ::c_int = AF_DLI;
1748pub const PF_LAT: ::c_int = AF_LAT;
1749pub const PF_HYLINK: ::c_int = AF_HYLINK;
1750pub const PF_APPLETALK: ::c_int = AF_APPLETALK;
1751pub const PF_NIT: ::c_int = AF_NIT;
1752pub const PF_802: ::c_int = AF_802;
1753pub const PF_OSI: ::c_int = AF_OSI;
1754pub const PF_X25: ::c_int = AF_X25;
1755pub const PF_OSINET: ::c_int = AF_OSINET;
1756pub const PF_GOSIP: ::c_int = AF_GOSIP;
1757pub const PF_IPX: ::c_int = AF_IPX;
1758pub const PF_ROUTE: ::c_int = AF_ROUTE;
1759pub const PF_LINK: ::c_int = AF_LINK;
1760pub const PF_INET6: ::c_int = AF_INET6;
1761pub const PF_KEY: ::c_int = AF_KEY;
1762pub const PF_NCA: ::c_int = AF_NCA;
1763pub const PF_POLICY: ::c_int = AF_POLICY;
1764pub const PF_INET_OFFLOAD: ::c_int = AF_INET_OFFLOAD;
1765pub const PF_TRILL: ::c_int = AF_TRILL;
1766pub const PF_PACKET: ::c_int = AF_PACKET;
1767
1768pub const SOCK_DGRAM: ::c_int = 1;
1769pub const SOCK_STREAM: ::c_int = 2;
1770pub const SOCK_RAW: ::c_int = 4;
1771pub const SOCK_RDM: ::c_int = 5;
1772pub const SOCK_SEQPACKET: ::c_int = 6;
1773pub const IP_MULTICAST_IF: ::c_int = 16;
1774pub const IP_MULTICAST_TTL: ::c_int = 17;
1775pub const IP_MULTICAST_LOOP: ::c_int = 18;
1776pub const IP_TTL: ::c_int = 4;
1777pub const IP_HDRINCL: ::c_int = 2;
1778pub const IP_ADD_MEMBERSHIP: ::c_int = 19;
1779pub const IP_DROP_MEMBERSHIP: ::c_int = 20;
1780pub const IPV6_JOIN_GROUP: ::c_int = 9;
1781pub const IPV6_LEAVE_GROUP: ::c_int = 10;
1782pub const IP_ADD_SOURCE_MEMBERSHIP: ::c_int = 23;
1783pub const IP_DROP_SOURCE_MEMBERSHIP: ::c_int = 24;
1784pub const IP_BLOCK_SOURCE: ::c_int = 21;
1785pub const IP_UNBLOCK_SOURCE: ::c_int = 22;
1786
1787// These TCP socket options are common between illumos and Solaris, while higher
1788// numbers have generally diverged:
1789pub const TCP_NODELAY: ::c_int = 0x1;
1790pub const TCP_MAXSEG: ::c_int = 0x2;
1791pub const TCP_KEEPALIVE: ::c_int = 0x8;
1792pub const TCP_NOTIFY_THRESHOLD: ::c_int = 0x10;
1793pub const TCP_ABORT_THRESHOLD: ::c_int = 0x11;
1794pub const TCP_CONN_NOTIFY_THRESHOLD: ::c_int = 0x12;
1795pub const TCP_CONN_ABORT_THRESHOLD: ::c_int = 0x13;
1796pub const TCP_RECVDSTADDR: ::c_int = 0x14;
1797pub const TCP_INIT_CWND: ::c_int = 0x15;
1798pub const TCP_KEEPALIVE_THRESHOLD: ::c_int = 0x16;
1799pub const TCP_KEEPALIVE_ABORT_THRESHOLD: ::c_int = 0x17;
1800pub const TCP_CORK: ::c_int = 0x18;
1801pub const TCP_RTO_INITIAL: ::c_int = 0x19;
1802pub const TCP_RTO_MIN: ::c_int = 0x1a;
1803pub const TCP_RTO_MAX: ::c_int = 0x1b;
1804pub const TCP_LINGER2: ::c_int = 0x1c;
1805
1806pub const UDP_NAT_T_ENDPOINT: ::c_int = 0x0103;
1807
1808pub const SOMAXCONN: ::c_int = 128;
1809
1810pub const SOL_SOCKET: ::c_int = 0xffff;
1811pub const SO_DEBUG: ::c_int = 0x01;
1812pub const SO_ACCEPTCONN: ::c_int = 0x0002;
1813pub const SO_REUSEADDR: ::c_int = 0x0004;
1814pub const SO_KEEPALIVE: ::c_int = 0x0008;
1815pub const SO_DONTROUTE: ::c_int = 0x0010;
1816pub const SO_BROADCAST: ::c_int = 0x0020;
1817pub const SO_USELOOPBACK: ::c_int = 0x0040;
1818pub const SO_LINGER: ::c_int = 0x0080;
1819pub const SO_OOBINLINE: ::c_int = 0x0100;
1820pub const SO_SNDBUF: ::c_int = 0x1001;
1821pub const SO_RCVBUF: ::c_int = 0x1002;
1822pub const SO_SNDLOWAT: ::c_int = 0x1003;
1823pub const SO_RCVLOWAT: ::c_int = 0x1004;
1824pub const SO_SNDTIMEO: ::c_int = 0x1005;
1825pub const SO_RCVTIMEO: ::c_int = 0x1006;
1826pub const SO_ERROR: ::c_int = 0x1007;
1827pub const SO_TYPE: ::c_int = 0x1008;
1828pub const SO_TIMESTAMP: ::c_int = 0x1013;
1829
1830pub const SCM_RIGHTS: ::c_int = 0x1010;
1831pub const SCM_UCRED: ::c_int = 0x1012;
1832pub const SCM_TIMESTAMP: ::c_int = SO_TIMESTAMP;
1833
1834pub const MSG_OOB: ::c_int = 0x1;
1835pub const MSG_PEEK: ::c_int = 0x2;
1836pub const MSG_DONTROUTE: ::c_int = 0x4;
1837pub const MSG_EOR: ::c_int = 0x8;
1838pub const MSG_CTRUNC: ::c_int = 0x10;
1839pub const MSG_TRUNC: ::c_int = 0x20;
1840pub const MSG_WAITALL: ::c_int = 0x40;
1841pub const MSG_DONTWAIT: ::c_int = 0x80;
1842pub const MSG_NOTIFICATION: ::c_int = 0x100;
1843pub const MSG_NOSIGNAL: ::c_int = 0x200;
1844pub const MSG_DUPCTRL: ::c_int = 0x800;
1845pub const MSG_XPG4_2: ::c_int = 0x8000;
1846pub const MSG_MAXIOVLEN: ::c_int = 16;
1847
1848pub const IF_NAMESIZE: ::size_t = 32;
1849pub const IFNAMSIZ: ::size_t = 16;
1850
1851// https://docs.oracle.com/cd/E23824_01/html/821-1475/if-7p.html
1852pub const IFF_UP: ::c_int = 0x0000000001; // Address is up
1853pub const IFF_BROADCAST: ::c_int = 0x0000000002; // Broadcast address valid
1854pub const IFF_DEBUG: ::c_int = 0x0000000004; // Turn on debugging
1855pub const IFF_LOOPBACK: ::c_int = 0x0000000008; // Loopback net
1856pub const IFF_POINTOPOINT: ::c_int = 0x0000000010; // Interface is p-to-p
1857pub const IFF_NOTRAILERS: ::c_int = 0x0000000020; // Avoid use of trailers
1858pub const IFF_RUNNING: ::c_int = 0x0000000040; // Resources allocated
1859pub const IFF_NOARP: ::c_int = 0x0000000080; // No address res. protocol
1860pub const IFF_PROMISC: ::c_int = 0x0000000100; // Receive all packets
1861pub const IFF_ALLMULTI: ::c_int = 0x0000000200; // Receive all multicast pkts
1862pub const IFF_INTELLIGENT: ::c_int = 0x0000000400; // Protocol code on board
1863pub const IFF_MULTICAST: ::c_int = 0x0000000800; // Supports multicast
1864
1865// Multicast using broadcst. add.
1866pub const IFF_MULTI_BCAST: ::c_int = 0x0000001000;
1867pub const IFF_UNNUMBERED: ::c_int = 0x0000002000; // Non-unique address
1868pub const IFF_DHCPRUNNING: ::c_int = 0x0000004000; // DHCP controls interface
1869pub const IFF_PRIVATE: ::c_int = 0x0000008000; // Do not advertise
1870pub const IFF_NOXMIT: ::c_int = 0x0000010000; // Do not transmit pkts
1871
1872// No address - just on-link subnet
1873pub const IFF_NOLOCAL: ::c_int = 0x0000020000;
1874pub const IFF_DEPRECATED: ::c_int = 0x0000040000; // Address is deprecated
1875pub const IFF_ADDRCONF: ::c_int = 0x0000080000; // Addr. from stateless addrconf
1876pub const IFF_ROUTER: ::c_int = 0x0000100000; // Router on interface
1877pub const IFF_NONUD: ::c_int = 0x0000200000; // No NUD on interface
1878pub const IFF_ANYCAST: ::c_int = 0x0000400000; // Anycast address
1879pub const IFF_NORTEXCH: ::c_int = 0x0000800000; // Don't xchange rout. info
1880pub const IFF_IPV4: ::c_int = 0x0001000000; // IPv4 interface
1881pub const IFF_IPV6: ::c_int = 0x0002000000; // IPv6 interface
1882pub const IFF_NOFAILOVER: ::c_int = 0x0008000000; // in.mpathd test address
1883pub const IFF_FAILED: ::c_int = 0x0010000000; // Interface has failed
1884pub const IFF_STANDBY: ::c_int = 0x0020000000; // Interface is a hot-spare
1885pub const IFF_INACTIVE: ::c_int = 0x0040000000; // Functioning but not used
1886pub const IFF_OFFLINE: ::c_int = 0x0080000000; // Interface is offline
1887                                               // If CoS marking is supported
1888pub const IFF_COS_ENABLED: ::c_longlong = 0x0200000000;
1889pub const IFF_PREFERRED: ::c_longlong = 0x0400000000; // Prefer as source addr.
1890pub const IFF_TEMPORARY: ::c_longlong = 0x0800000000; // RFC3041
1891pub const IFF_FIXEDMTU: ::c_longlong = 0x1000000000; // MTU set with SIOCSLIFMTU
1892pub const IFF_VIRTUAL: ::c_longlong = 0x2000000000; // Cannot send/receive pkts
1893pub const IFF_DUPLICATE: ::c_longlong = 0x4000000000; // Local address in use
1894pub const IFF_IPMP: ::c_longlong = 0x8000000000; // IPMP IP interface
1895
1896// sys/ipc.h:
1897pub const IPC_ALLOC: ::c_int = 0x8000;
1898pub const IPC_CREAT: ::c_int = 0x200;
1899pub const IPC_EXCL: ::c_int = 0x400;
1900pub const IPC_NOWAIT: ::c_int = 0x800;
1901pub const IPC_PRIVATE: key_t = 0;
1902pub const IPC_RMID: ::c_int = 10;
1903pub const IPC_SET: ::c_int = 11;
1904pub const IPC_SEAT: ::c_int = 12;
1905
1906// sys/shm.h
1907pub const SHM_R: ::c_int = 0o400;
1908pub const SHM_W: ::c_int = 0o200;
1909pub const SHM_RDONLY: ::c_int = 0o10000;
1910pub const SHM_RND: ::c_int = 0o20000;
1911pub const SHM_SHARE_MMU: ::c_int = 0o40000;
1912pub const SHM_PAGEABLE: ::c_int = 0o100000;
1913
1914pub const SHUT_RD: ::c_int = 0;
1915pub const SHUT_WR: ::c_int = 1;
1916pub const SHUT_RDWR: ::c_int = 2;
1917
1918pub const LOCK_SH: ::c_int = 1;
1919pub const LOCK_EX: ::c_int = 2;
1920pub const LOCK_NB: ::c_int = 4;
1921pub const LOCK_UN: ::c_int = 8;
1922
1923pub const F_RDLCK: ::c_short = 1;
1924pub const F_WRLCK: ::c_short = 2;
1925pub const F_UNLCK: ::c_short = 3;
1926
1927pub const O_SYNC: ::c_int = 16;
1928pub const O_NONBLOCK: ::c_int = 128;
1929
1930pub const IPPROTO_RAW: ::c_int = 255;
1931
1932pub const _PC_LINK_MAX: ::c_int = 1;
1933pub const _PC_MAX_CANON: ::c_int = 2;
1934pub const _PC_MAX_INPUT: ::c_int = 3;
1935pub const _PC_NAME_MAX: ::c_int = 4;
1936pub const _PC_PATH_MAX: ::c_int = 5;
1937pub const _PC_PIPE_BUF: ::c_int = 6;
1938pub const _PC_NO_TRUNC: ::c_int = 7;
1939pub const _PC_VDISABLE: ::c_int = 8;
1940pub const _PC_CHOWN_RESTRICTED: ::c_int = 9;
1941pub const _PC_ASYNC_IO: ::c_int = 10;
1942pub const _PC_PRIO_IO: ::c_int = 11;
1943pub const _PC_SYNC_IO: ::c_int = 12;
1944pub const _PC_ALLOC_SIZE_MIN: ::c_int = 13;
1945pub const _PC_REC_INCR_XFER_SIZE: ::c_int = 14;
1946pub const _PC_REC_MAX_XFER_SIZE: ::c_int = 15;
1947pub const _PC_REC_MIN_XFER_SIZE: ::c_int = 16;
1948pub const _PC_REC_XFER_ALIGN: ::c_int = 17;
1949pub const _PC_SYMLINK_MAX: ::c_int = 18;
1950pub const _PC_2_SYMLINKS: ::c_int = 19;
1951pub const _PC_ACL_ENABLED: ::c_int = 20;
1952pub const _PC_MIN_HOLE_SIZE: ::c_int = 21;
1953pub const _PC_CASE_BEHAVIOR: ::c_int = 22;
1954pub const _PC_SATTR_ENABLED: ::c_int = 23;
1955pub const _PC_SATTR_EXISTS: ::c_int = 24;
1956pub const _PC_ACCESS_FILTERING: ::c_int = 25;
1957pub const _PC_TIMESTAMP_RESOLUTION: ::c_int = 26;
1958pub const _PC_FILESIZEBITS: ::c_int = 67;
1959pub const _PC_XATTR_ENABLED: ::c_int = 100;
1960pub const _PC_LAST: ::c_int = 101;
1961pub const _PC_XATTR_EXISTS: ::c_int = 101;
1962
1963pub const _SC_ARG_MAX: ::c_int = 1;
1964pub const _SC_CHILD_MAX: ::c_int = 2;
1965pub const _SC_CLK_TCK: ::c_int = 3;
1966pub const _SC_NGROUPS_MAX: ::c_int = 4;
1967pub const _SC_OPEN_MAX: ::c_int = 5;
1968pub const _SC_JOB_CONTROL: ::c_int = 6;
1969pub const _SC_SAVED_IDS: ::c_int = 7;
1970pub const _SC_VERSION: ::c_int = 8;
1971pub const _SC_PASS_MAX: ::c_int = 9;
1972pub const _SC_LOGNAME_MAX: ::c_int = 10;
1973pub const _SC_PAGESIZE: ::c_int = 11;
1974pub const _SC_PAGE_SIZE: ::c_int = _SC_PAGESIZE;
1975pub const _SC_XOPEN_VERSION: ::c_int = 12;
1976pub const _SC_NPROCESSORS_CONF: ::c_int = 14;
1977pub const _SC_NPROCESSORS_ONLN: ::c_int = 15;
1978pub const _SC_STREAM_MAX: ::c_int = 16;
1979pub const _SC_TZNAME_MAX: ::c_int = 17;
1980pub const _SC_AIO_LISTIO_MAX: ::c_int = 18;
1981pub const _SC_AIO_MAX: ::c_int = 19;
1982pub const _SC_AIO_PRIO_DELTA_MAX: ::c_int = 20;
1983pub const _SC_ASYNCHRONOUS_IO: ::c_int = 21;
1984pub const _SC_DELAYTIMER_MAX: ::c_int = 22;
1985pub const _SC_FSYNC: ::c_int = 23;
1986pub const _SC_MAPPED_FILES: ::c_int = 24;
1987pub const _SC_MEMLOCK: ::c_int = 25;
1988pub const _SC_MEMLOCK_RANGE: ::c_int = 26;
1989pub const _SC_MEMORY_PROTECTION: ::c_int = 27;
1990pub const _SC_MESSAGE_PASSING: ::c_int = 28;
1991pub const _SC_MQ_OPEN_MAX: ::c_int = 29;
1992pub const _SC_MQ_PRIO_MAX: ::c_int = 30;
1993pub const _SC_PRIORITIZED_IO: ::c_int = 31;
1994pub const _SC_PRIORITY_SCHEDULING: ::c_int = 32;
1995pub const _SC_REALTIME_SIGNALS: ::c_int = 33;
1996pub const _SC_RTSIG_MAX: ::c_int = 34;
1997pub const _SC_SEMAPHORES: ::c_int = 35;
1998pub const _SC_SEM_NSEMS_MAX: ::c_int = 36;
1999pub const _SC_SEM_VALUE_MAX: ::c_int = 37;
2000pub const _SC_SHARED_MEMORY_OBJECTS: ::c_int = 38;
2001pub const _SC_SIGQUEUE_MAX: ::c_int = 39;
2002pub const _SC_SIGRT_MIN: ::c_int = 40;
2003pub const _SC_SIGRT_MAX: ::c_int = 41;
2004pub const _SC_SYNCHRONIZED_IO: ::c_int = 42;
2005pub const _SC_TIMERS: ::c_int = 43;
2006pub const _SC_TIMER_MAX: ::c_int = 44;
2007pub const _SC_2_C_BIND: ::c_int = 45;
2008pub const _SC_2_C_DEV: ::c_int = 46;
2009pub const _SC_2_C_VERSION: ::c_int = 47;
2010pub const _SC_2_FORT_DEV: ::c_int = 48;
2011pub const _SC_2_FORT_RUN: ::c_int = 49;
2012pub const _SC_2_LOCALEDEF: ::c_int = 50;
2013pub const _SC_2_SW_DEV: ::c_int = 51;
2014pub const _SC_2_UPE: ::c_int = 52;
2015pub const _SC_2_VERSION: ::c_int = 53;
2016pub const _SC_BC_BASE_MAX: ::c_int = 54;
2017pub const _SC_BC_DIM_MAX: ::c_int = 55;
2018pub const _SC_BC_SCALE_MAX: ::c_int = 56;
2019pub const _SC_BC_STRING_MAX: ::c_int = 57;
2020pub const _SC_COLL_WEIGHTS_MAX: ::c_int = 58;
2021pub const _SC_EXPR_NEST_MAX: ::c_int = 59;
2022pub const _SC_LINE_MAX: ::c_int = 60;
2023pub const _SC_RE_DUP_MAX: ::c_int = 61;
2024pub const _SC_XOPEN_CRYPT: ::c_int = 62;
2025pub const _SC_XOPEN_ENH_I18N: ::c_int = 63;
2026pub const _SC_XOPEN_SHM: ::c_int = 64;
2027pub const _SC_2_CHAR_TERM: ::c_int = 66;
2028pub const _SC_XOPEN_XCU_VERSION: ::c_int = 67;
2029pub const _SC_ATEXIT_MAX: ::c_int = 76;
2030pub const _SC_IOV_MAX: ::c_int = 77;
2031pub const _SC_XOPEN_UNIX: ::c_int = 78;
2032pub const _SC_T_IOV_MAX: ::c_int = 79;
2033pub const _SC_PHYS_PAGES: ::c_int = 500;
2034pub const _SC_AVPHYS_PAGES: ::c_int = 501;
2035pub const _SC_COHER_BLKSZ: ::c_int = 503;
2036pub const _SC_SPLIT_CACHE: ::c_int = 504;
2037pub const _SC_ICACHE_SZ: ::c_int = 505;
2038pub const _SC_DCACHE_SZ: ::c_int = 506;
2039pub const _SC_ICACHE_LINESZ: ::c_int = 507;
2040pub const _SC_DCACHE_LINESZ: ::c_int = 508;
2041pub const _SC_ICACHE_BLKSZ: ::c_int = 509;
2042pub const _SC_DCACHE_BLKSZ: ::c_int = 510;
2043pub const _SC_DCACHE_TBLKSZ: ::c_int = 511;
2044pub const _SC_ICACHE_ASSOC: ::c_int = 512;
2045pub const _SC_DCACHE_ASSOC: ::c_int = 513;
2046pub const _SC_MAXPID: ::c_int = 514;
2047pub const _SC_STACK_PROT: ::c_int = 515;
2048pub const _SC_NPROCESSORS_MAX: ::c_int = 516;
2049pub const _SC_CPUID_MAX: ::c_int = 517;
2050pub const _SC_EPHID_MAX: ::c_int = 518;
2051pub const _SC_THREAD_DESTRUCTOR_ITERATIONS: ::c_int = 568;
2052pub const _SC_GETGR_R_SIZE_MAX: ::c_int = 569;
2053pub const _SC_GETPW_R_SIZE_MAX: ::c_int = 570;
2054pub const _SC_LOGIN_NAME_MAX: ::c_int = 571;
2055pub const _SC_THREAD_KEYS_MAX: ::c_int = 572;
2056pub const _SC_THREAD_STACK_MIN: ::c_int = 573;
2057pub const _SC_THREAD_THREADS_MAX: ::c_int = 574;
2058pub const _SC_TTY_NAME_MAX: ::c_int = 575;
2059pub const _SC_THREADS: ::c_int = 576;
2060pub const _SC_THREAD_ATTR_STACKADDR: ::c_int = 577;
2061pub const _SC_THREAD_ATTR_STACKSIZE: ::c_int = 578;
2062pub const _SC_THREAD_PRIORITY_SCHEDULING: ::c_int = 579;
2063pub const _SC_THREAD_PRIO_INHERIT: ::c_int = 580;
2064pub const _SC_THREAD_PRIO_PROTECT: ::c_int = 581;
2065pub const _SC_THREAD_PROCESS_SHARED: ::c_int = 582;
2066pub const _SC_THREAD_SAFE_FUNCTIONS: ::c_int = 583;
2067pub const _SC_XOPEN_LEGACY: ::c_int = 717;
2068pub const _SC_XOPEN_REALTIME: ::c_int = 718;
2069pub const _SC_XOPEN_REALTIME_THREADS: ::c_int = 719;
2070pub const _SC_XBS5_ILP32_OFF32: ::c_int = 720;
2071pub const _SC_XBS5_ILP32_OFFBIG: ::c_int = 721;
2072pub const _SC_XBS5_LP64_OFF64: ::c_int = 722;
2073pub const _SC_XBS5_LPBIG_OFFBIG: ::c_int = 723;
2074pub const _SC_2_PBS: ::c_int = 724;
2075pub const _SC_2_PBS_ACCOUNTING: ::c_int = 725;
2076pub const _SC_2_PBS_CHECKPOINT: ::c_int = 726;
2077pub const _SC_2_PBS_LOCATE: ::c_int = 728;
2078pub const _SC_2_PBS_MESSAGE: ::c_int = 729;
2079pub const _SC_2_PBS_TRACK: ::c_int = 730;
2080pub const _SC_ADVISORY_INFO: ::c_int = 731;
2081pub const _SC_BARRIERS: ::c_int = 732;
2082pub const _SC_CLOCK_SELECTION: ::c_int = 733;
2083pub const _SC_CPUTIME: ::c_int = 734;
2084pub const _SC_HOST_NAME_MAX: ::c_int = 735;
2085pub const _SC_MONOTONIC_CLOCK: ::c_int = 736;
2086pub const _SC_READER_WRITER_LOCKS: ::c_int = 737;
2087pub const _SC_REGEXP: ::c_int = 738;
2088pub const _SC_SHELL: ::c_int = 739;
2089pub const _SC_SPAWN: ::c_int = 740;
2090pub const _SC_SPIN_LOCKS: ::c_int = 741;
2091pub const _SC_SPORADIC_SERVER: ::c_int = 742;
2092pub const _SC_SS_REPL_MAX: ::c_int = 743;
2093pub const _SC_SYMLOOP_MAX: ::c_int = 744;
2094pub const _SC_THREAD_CPUTIME: ::c_int = 745;
2095pub const _SC_THREAD_SPORADIC_SERVER: ::c_int = 746;
2096pub const _SC_TIMEOUTS: ::c_int = 747;
2097pub const _SC_TRACE: ::c_int = 748;
2098pub const _SC_TRACE_EVENT_FILTER: ::c_int = 749;
2099pub const _SC_TRACE_EVENT_NAME_MAX: ::c_int = 750;
2100pub const _SC_TRACE_INHERIT: ::c_int = 751;
2101pub const _SC_TRACE_LOG: ::c_int = 752;
2102pub const _SC_TRACE_NAME_MAX: ::c_int = 753;
2103pub const _SC_TRACE_SYS_MAX: ::c_int = 754;
2104pub const _SC_TRACE_USER_EVENT_MAX: ::c_int = 755;
2105pub const _SC_TYPED_MEMORY_OBJECTS: ::c_int = 756;
2106pub const _SC_V6_ILP32_OFF32: ::c_int = 757;
2107pub const _SC_V6_ILP32_OFFBIG: ::c_int = 758;
2108pub const _SC_V6_LP64_OFF64: ::c_int = 759;
2109pub const _SC_V6_LPBIG_OFFBIG: ::c_int = 760;
2110pub const _SC_XOPEN_STREAMS: ::c_int = 761;
2111pub const _SC_IPV6: ::c_int = 762;
2112pub const _SC_RAW_SOCKETS: ::c_int = 763;
2113
2114pub const _MUTEX_MAGIC: u16 = 0x4d58; // MX
2115pub const _COND_MAGIC: u16 = 0x4356; // CV
2116pub const _RWL_MAGIC: u16 = 0x5257; // RW
2117
2118pub const NCCS: usize = 19;
2119
2120pub const LOG_CRON: ::c_int = 15 << 3;
2121
2122pub const PTHREAD_MUTEX_INITIALIZER: pthread_mutex_t = pthread_mutex_t {
2123    __pthread_mutex_flag1: 0,
2124    __pthread_mutex_flag2: 0,
2125    __pthread_mutex_ceiling: 0,
2126    __pthread_mutex_type: PTHREAD_PROCESS_PRIVATE,
2127    __pthread_mutex_magic: _MUTEX_MAGIC,
2128    __pthread_mutex_lock: 0,
2129    __pthread_mutex_data: 0,
2130};
2131pub const PTHREAD_COND_INITIALIZER: pthread_cond_t = pthread_cond_t {
2132    __pthread_cond_flag: [0; 4],
2133    __pthread_cond_type: PTHREAD_PROCESS_PRIVATE,
2134    __pthread_cond_magic: _COND_MAGIC,
2135    __pthread_cond_data: 0,
2136};
2137pub const PTHREAD_RWLOCK_INITIALIZER: pthread_rwlock_t = pthread_rwlock_t {
2138    __pthread_rwlock_readers: 0,
2139    __pthread_rwlock_type: PTHREAD_PROCESS_PRIVATE,
2140    __pthread_rwlock_magic: _RWL_MAGIC,
2141    __pthread_rwlock_mutex: PTHREAD_MUTEX_INITIALIZER,
2142    __pthread_rwlock_readercv: PTHREAD_COND_INITIALIZER,
2143    __pthread_rwlock_writercv: PTHREAD_COND_INITIALIZER,
2144};
2145pub const PTHREAD_MUTEX_NORMAL: ::c_int = 0;
2146pub const PTHREAD_MUTEX_ERRORCHECK: ::c_int = 2;
2147pub const PTHREAD_MUTEX_RECURSIVE: ::c_int = 4;
2148pub const PTHREAD_MUTEX_DEFAULT: ::c_int = PTHREAD_MUTEX_NORMAL;
2149
2150pub const RTLD_NEXT: *mut ::c_void = -1isize as *mut ::c_void;
2151pub const RTLD_DEFAULT: *mut ::c_void = -2isize as *mut ::c_void;
2152pub const RTLD_SELF: *mut ::c_void = -3isize as *mut ::c_void;
2153pub const RTLD_PROBE: *mut ::c_void = -4isize as *mut ::c_void;
2154
2155pub const RTLD_LAZY: ::c_int = 0x1;
2156pub const RTLD_NOW: ::c_int = 0x2;
2157pub const RTLD_NOLOAD: ::c_int = 0x4;
2158pub const RTLD_GLOBAL: ::c_int = 0x100;
2159pub const RTLD_LOCAL: ::c_int = 0x0;
2160pub const RTLD_PARENT: ::c_int = 0x200;
2161pub const RTLD_GROUP: ::c_int = 0x400;
2162pub const RTLD_WORLD: ::c_int = 0x800;
2163pub const RTLD_NODELETE: ::c_int = 0x1000;
2164pub const RTLD_FIRST: ::c_int = 0x2000;
2165pub const RTLD_CONFGEN: ::c_int = 0x10000;
2166
2167pub const PORT_SOURCE_AIO: ::c_int = 1;
2168pub const PORT_SOURCE_TIMER: ::c_int = 2;
2169pub const PORT_SOURCE_USER: ::c_int = 3;
2170pub const PORT_SOURCE_FD: ::c_int = 4;
2171pub const PORT_SOURCE_ALERT: ::c_int = 5;
2172pub const PORT_SOURCE_MQ: ::c_int = 6;
2173pub const PORT_SOURCE_FILE: ::c_int = 7;
2174
2175pub const NONROOT_USR: ::c_short = 2;
2176pub const _UTX_USERSIZE: usize = 32;
2177pub const _UTX_LINESIZE: usize = 32;
2178pub const _UTX_PADSIZE: usize = 5;
2179pub const _UTX_IDSIZE: usize = 4;
2180pub const _UTX_HOSTSIZE: usize = 257;
2181pub const EMPTY: ::c_short = 0;
2182pub const RUN_LVL: ::c_short = 1;
2183pub const BOOT_TIME: ::c_short = 2;
2184pub const OLD_TIME: ::c_short = 3;
2185pub const NEW_TIME: ::c_short = 4;
2186pub const INIT_PROCESS: ::c_short = 5;
2187pub const LOGIN_PROCESS: ::c_short = 6;
2188pub const USER_PROCESS: ::c_short = 7;
2189pub const DEAD_PROCESS: ::c_short = 8;
2190pub const ACCOUNTING: ::c_short = 9;
2191pub const DOWN_TIME: ::c_short = 10;
2192
2193const _TIOC: ::c_int = ('T' as i32) << 8;
2194const tIOC: ::c_int = ('t' as i32) << 8;
2195pub const TCGETA: ::c_int = _TIOC | 1;
2196pub const TCSETA: ::c_int = _TIOC | 2;
2197pub const TCSETAW: ::c_int = _TIOC | 3;
2198pub const TCSETAF: ::c_int = _TIOC | 4;
2199pub const TCSBRK: ::c_int = _TIOC | 5;
2200pub const TCXONC: ::c_int = _TIOC | 6;
2201pub const TCFLSH: ::c_int = _TIOC | 7;
2202pub const TCDSET: ::c_int = _TIOC | 32;
2203pub const TCGETS: ::c_int = _TIOC | 13;
2204pub const TCSETS: ::c_int = _TIOC | 14;
2205pub const TCSANOW: ::c_int = _TIOC | 14;
2206pub const TCSETSW: ::c_int = _TIOC | 15;
2207pub const TCSADRAIN: ::c_int = _TIOC | 15;
2208pub const TCSETSF: ::c_int = _TIOC | 16;
2209pub const TCSAFLUSH: ::c_int = _TIOC | 16;
2210pub const TCIFLUSH: ::c_int = 0;
2211pub const TCOFLUSH: ::c_int = 1;
2212pub const TCIOFLUSH: ::c_int = 2;
2213pub const TCOOFF: ::c_int = 0;
2214pub const TCOON: ::c_int = 1;
2215pub const TCIOFF: ::c_int = 2;
2216pub const TCION: ::c_int = 3;
2217pub const TIOC: ::c_int = _TIOC;
2218pub const TIOCKBON: ::c_int = _TIOC | 8;
2219pub const TIOCKBOF: ::c_int = _TIOC | 9;
2220pub const TIOCGWINSZ: ::c_int = _TIOC | 104;
2221pub const TIOCSWINSZ: ::c_int = _TIOC | 103;
2222pub const TIOCGSOFTCAR: ::c_int = _TIOC | 105;
2223pub const TIOCSSOFTCAR: ::c_int = _TIOC | 106;
2224pub const TIOCGPPS: ::c_int = _TIOC | 125;
2225pub const TIOCSPPS: ::c_int = _TIOC | 126;
2226pub const TIOCGPPSEV: ::c_int = _TIOC | 127;
2227pub const TIOCGETD: ::c_int = tIOC | 0;
2228pub const TIOCSETD: ::c_int = tIOC | 1;
2229pub const TIOCHPCL: ::c_int = tIOC | 2;
2230pub const TIOCGETP: ::c_int = tIOC | 8;
2231pub const TIOCSETP: ::c_int = tIOC | 9;
2232pub const TIOCSETN: ::c_int = tIOC | 10;
2233pub const TIOCEXCL: ::c_int = tIOC | 13;
2234pub const TIOCNXCL: ::c_int = tIOC | 14;
2235pub const TIOCFLUSH: ::c_int = tIOC | 16;
2236pub const TIOCSETC: ::c_int = tIOC | 17;
2237pub const TIOCGETC: ::c_int = tIOC | 18;
2238pub const TIOCLBIS: ::c_int = tIOC | 127;
2239pub const TIOCLBIC: ::c_int = tIOC | 126;
2240pub const TIOCLSET: ::c_int = tIOC | 125;
2241pub const TIOCLGET: ::c_int = tIOC | 124;
2242pub const TIOCSBRK: ::c_int = tIOC | 123;
2243pub const TIOCCBRK: ::c_int = tIOC | 122;
2244pub const TIOCSDTR: ::c_int = tIOC | 121;
2245pub const TIOCCDTR: ::c_int = tIOC | 120;
2246pub const TIOCSLTC: ::c_int = tIOC | 117;
2247pub const TIOCGLTC: ::c_int = tIOC | 116;
2248pub const TIOCOUTQ: ::c_int = tIOC | 115;
2249pub const TIOCNOTTY: ::c_int = tIOC | 113;
2250pub const TIOCSCTTY: ::c_int = tIOC | 132;
2251pub const TIOCSTOP: ::c_int = tIOC | 111;
2252pub const TIOCSTART: ::c_int = tIOC | 110;
2253pub const TIOCSILOOP: ::c_int = tIOC | 109;
2254pub const TIOCCILOOP: ::c_int = tIOC | 108;
2255pub const TIOCGPGRP: ::c_int = tIOC | 20;
2256pub const TIOCSPGRP: ::c_int = tIOC | 21;
2257pub const TIOCGSID: ::c_int = tIOC | 22;
2258pub const TIOCSTI: ::c_int = tIOC | 23;
2259pub const TIOCMSET: ::c_int = tIOC | 26;
2260pub const TIOCMBIS: ::c_int = tIOC | 27;
2261pub const TIOCMBIC: ::c_int = tIOC | 28;
2262pub const TIOCMGET: ::c_int = tIOC | 29;
2263pub const TIOCREMOTE: ::c_int = tIOC | 30;
2264pub const TIOCSIGNAL: ::c_int = tIOC | 31;
2265
2266pub const TIOCM_LE: ::c_int = 0o0001;
2267pub const TIOCM_DTR: ::c_int = 0o0002;
2268pub const TIOCM_RTS: ::c_int = 0o0004;
2269pub const TIOCM_ST: ::c_int = 0o0010;
2270pub const TIOCM_SR: ::c_int = 0o0020;
2271pub const TIOCM_CTS: ::c_int = 0o0040;
2272pub const TIOCM_CAR: ::c_int = 0o0100;
2273pub const TIOCM_CD: ::c_int = TIOCM_CAR;
2274pub const TIOCM_RNG: ::c_int = 0o0200;
2275pub const TIOCM_RI: ::c_int = TIOCM_RNG;
2276pub const TIOCM_DSR: ::c_int = 0o0400;
2277
2278pub const EPOLLIN: ::c_int = 0x1;
2279pub const EPOLLPRI: ::c_int = 0x2;
2280pub const EPOLLOUT: ::c_int = 0x4;
2281pub const EPOLLRDNORM: ::c_int = 0x40;
2282pub const EPOLLRDBAND: ::c_int = 0x80;
2283pub const EPOLLWRNORM: ::c_int = 0x100;
2284pub const EPOLLWRBAND: ::c_int = 0x200;
2285pub const EPOLLMSG: ::c_int = 0x400;
2286pub const EPOLLERR: ::c_int = 0x8;
2287pub const EPOLLHUP: ::c_int = 0x10;
2288pub const EPOLLET: ::c_int = 0x80000000;
2289pub const EPOLLRDHUP: ::c_int = 0x2000;
2290pub const EPOLLONESHOT: ::c_int = 0x40000000;
2291pub const EPOLLWAKEUP: ::c_int = 0x20000000;
2292pub const EPOLLEXCLUSIVE: ::c_int = 0x10000000;
2293pub const EPOLL_CLOEXEC: ::c_int = 0x80000;
2294pub const EPOLL_CTL_ADD: ::c_int = 1;
2295pub const EPOLL_CTL_MOD: ::c_int = 3;
2296pub const EPOLL_CTL_DEL: ::c_int = 2;
2297
2298/* termios */
2299pub const B0: speed_t = 0;
2300pub const B50: speed_t = 1;
2301pub const B75: speed_t = 2;
2302pub const B110: speed_t = 3;
2303pub const B134: speed_t = 4;
2304pub const B150: speed_t = 5;
2305pub const B200: speed_t = 6;
2306pub const B300: speed_t = 7;
2307pub const B600: speed_t = 8;
2308pub const B1200: speed_t = 9;
2309pub const B1800: speed_t = 10;
2310pub const B2400: speed_t = 11;
2311pub const B4800: speed_t = 12;
2312pub const B9600: speed_t = 13;
2313pub const B19200: speed_t = 14;
2314pub const B38400: speed_t = 15;
2315pub const B57600: speed_t = 16;
2316pub const B76800: speed_t = 17;
2317pub const B115200: speed_t = 18;
2318pub const B153600: speed_t = 19;
2319pub const B230400: speed_t = 20;
2320pub const B307200: speed_t = 21;
2321pub const B460800: speed_t = 22;
2322pub const B921600: speed_t = 23;
2323pub const CSTART: ::tcflag_t = 0o21;
2324pub const CSTOP: ::tcflag_t = 0o23;
2325pub const CSWTCH: ::tcflag_t = 0o32;
2326pub const CBAUD: ::tcflag_t = 0o17;
2327pub const CIBAUD: ::tcflag_t = 0o3600000;
2328pub const CBAUDEXT: ::tcflag_t = 0o10000000;
2329pub const CIBAUDEXT: ::tcflag_t = 0o20000000;
2330pub const CSIZE: ::tcflag_t = 0o000060;
2331pub const CS5: ::tcflag_t = 0;
2332pub const CS6: ::tcflag_t = 0o000020;
2333pub const CS7: ::tcflag_t = 0o000040;
2334pub const CS8: ::tcflag_t = 0o000060;
2335pub const CSTOPB: ::tcflag_t = 0o000100;
2336pub const ECHO: ::tcflag_t = 0o000010;
2337pub const ECHOE: ::tcflag_t = 0o000020;
2338pub const ECHOK: ::tcflag_t = 0o000040;
2339pub const ECHONL: ::tcflag_t = 0o000100;
2340pub const ECHOCTL: ::tcflag_t = 0o001000;
2341pub const ECHOPRT: ::tcflag_t = 0o002000;
2342pub const ECHOKE: ::tcflag_t = 0o004000;
2343pub const EXTPROC: ::tcflag_t = 0o200000;
2344pub const IGNBRK: ::tcflag_t = 0o000001;
2345pub const BRKINT: ::tcflag_t = 0o000002;
2346pub const IGNPAR: ::tcflag_t = 0o000004;
2347pub const PARMRK: ::tcflag_t = 0o000010;
2348pub const INPCK: ::tcflag_t = 0o000020;
2349pub const ISTRIP: ::tcflag_t = 0o000040;
2350pub const INLCR: ::tcflag_t = 0o000100;
2351pub const IGNCR: ::tcflag_t = 0o000200;
2352pub const ICRNL: ::tcflag_t = 0o000400;
2353pub const IUCLC: ::tcflag_t = 0o001000;
2354pub const IXON: ::tcflag_t = 0o002000;
2355pub const IXOFF: ::tcflag_t = 0o010000;
2356pub const IXANY: ::tcflag_t = 0o004000;
2357pub const IMAXBEL: ::tcflag_t = 0o020000;
2358pub const DOSMODE: ::tcflag_t = 0o100000;
2359pub const OPOST: ::tcflag_t = 0o000001;
2360pub const OLCUC: ::tcflag_t = 0o000002;
2361pub const ONLCR: ::tcflag_t = 0o000004;
2362pub const OCRNL: ::tcflag_t = 0o000010;
2363pub const ONOCR: ::tcflag_t = 0o000020;
2364pub const ONLRET: ::tcflag_t = 0o000040;
2365pub const OFILL: ::tcflag_t = 0o0000100;
2366pub const OFDEL: ::tcflag_t = 0o0000200;
2367pub const CREAD: ::tcflag_t = 0o000200;
2368pub const PARENB: ::tcflag_t = 0o000400;
2369pub const PARODD: ::tcflag_t = 0o001000;
2370pub const HUPCL: ::tcflag_t = 0o002000;
2371pub const CLOCAL: ::tcflag_t = 0o004000;
2372pub const CRTSXOFF: ::tcflag_t = 0o10000000000;
2373pub const CRTSCTS: ::tcflag_t = 0o20000000000;
2374pub const ISIG: ::tcflag_t = 0o000001;
2375pub const ICANON: ::tcflag_t = 0o000002;
2376pub const IEXTEN: ::tcflag_t = 0o100000;
2377pub const TOSTOP: ::tcflag_t = 0o000400;
2378pub const FLUSHO: ::tcflag_t = 0o020000;
2379pub const PENDIN: ::tcflag_t = 0o040000;
2380pub const NOFLSH: ::tcflag_t = 0o000200;
2381pub const VINTR: usize = 0;
2382pub const VQUIT: usize = 1;
2383pub const VERASE: usize = 2;
2384pub const VKILL: usize = 3;
2385pub const VEOF: usize = 4;
2386pub const VEOL: usize = 5;
2387pub const VEOL2: usize = 6;
2388pub const VMIN: usize = 4;
2389pub const VTIME: usize = 5;
2390pub const VSWTCH: usize = 7;
2391pub const VSTART: usize = 8;
2392pub const VSTOP: usize = 9;
2393pub const VSUSP: usize = 10;
2394pub const VDSUSP: usize = 11;
2395pub const VREPRINT: usize = 12;
2396pub const VDISCARD: usize = 13;
2397pub const VWERASE: usize = 14;
2398pub const VLNEXT: usize = 15;
2399pub const VSTATUS: usize = 16;
2400pub const VERASE2: usize = 17;
2401
2402// <sys/stropts.h>
2403const STR: ::c_int = (b'S' as ::c_int) << 8;
2404pub const I_NREAD: ::c_int = STR | 0o1;
2405pub const I_PUSH: ::c_int = STR | 0o2;
2406pub const I_POP: ::c_int = STR | 0o3;
2407pub const I_LOOK: ::c_int = STR | 0o4;
2408pub const I_FLUSH: ::c_int = STR | 0o5;
2409pub const I_SRDOPT: ::c_int = STR | 0o6;
2410pub const I_GRDOPT: ::c_int = STR | 0o7;
2411pub const I_STR: ::c_int = STR | 0o10;
2412pub const I_SETSIG: ::c_int = STR | 0o11;
2413pub const I_GETSIG: ::c_int = STR | 0o12;
2414pub const I_FIND: ::c_int = STR | 0o13;
2415pub const I_LINK: ::c_int = STR | 0o14;
2416pub const I_UNLINK: ::c_int = STR | 0o15;
2417pub const I_PEEK: ::c_int = STR | 0o17;
2418pub const I_FDINSERT: ::c_int = STR | 0o20;
2419pub const I_SENDFD: ::c_int = STR | 0o21;
2420pub const I_RECVFD: ::c_int = STR | 0o16;
2421pub const I_SWROPT: ::c_int = STR | 0o23;
2422pub const I_GWROPT: ::c_int = STR | 0o24;
2423pub const I_LIST: ::c_int = STR | 0o25;
2424pub const I_PLINK: ::c_int = STR | 0o26;
2425pub const I_PUNLINK: ::c_int = STR | 0o27;
2426pub const I_ANCHOR: ::c_int = STR | 0o30;
2427pub const I_FLUSHBAND: ::c_int = STR | 0o34;
2428pub const I_CKBAND: ::c_int = STR | 0o35;
2429pub const I_GETBAND: ::c_int = STR | 0o36;
2430pub const I_ATMARK: ::c_int = STR | 0o37;
2431pub const I_SETCLTIME: ::c_int = STR | 0o40;
2432pub const I_GETCLTIME: ::c_int = STR | 0o41;
2433pub const I_CANPUT: ::c_int = STR | 0o42;
2434pub const I_SERROPT: ::c_int = STR | 0o43;
2435pub const I_GERROPT: ::c_int = STR | 0o44;
2436pub const I_ESETSIG: ::c_int = STR | 0o45;
2437pub const I_EGETSIG: ::c_int = STR | 0o46;
2438pub const __I_PUSH_NOCTTY: ::c_int = STR | 0o47;
2439
2440// 3SOCKET flags
2441pub const SOCK_CLOEXEC: ::c_int = 0x080000;
2442pub const SOCK_NONBLOCK: ::c_int = 0x100000;
2443pub const SOCK_NDELAY: ::c_int = 0x200000;
2444
2445//<sys/timex.h>
2446pub const SCALE_KG: ::c_int = 1 << 6;
2447pub const SCALE_KF: ::c_int = 1 << 16;
2448pub const SCALE_KH: ::c_int = 1 << 2;
2449pub const MAXTC: ::c_int = 1 << 6;
2450pub const SCALE_PHASE: ::c_int = 1 << 22;
2451pub const SCALE_USEC: ::c_int = 1 << 16;
2452pub const SCALE_UPDATE: ::c_int = SCALE_KG * MAXTC;
2453pub const FINEUSEC: ::c_int = 1 << 22;
2454pub const MAXPHASE: ::c_int = 512000;
2455pub const MAXFREQ: ::c_int = 512 * SCALE_USEC;
2456pub const MAXTIME: ::c_int = 200 << PPS_AVG;
2457pub const MINSEC: ::c_int = 16;
2458pub const MAXSEC: ::c_int = 1200;
2459pub const PPS_AVG: ::c_int = 2;
2460pub const PPS_SHIFT: ::c_int = 2;
2461pub const PPS_SHIFTMAX: ::c_int = 8;
2462pub const PPS_VALID: ::c_int = 120;
2463pub const MAXGLITCH: ::c_int = 30;
2464pub const MOD_OFFSET: u32 = 0x0001;
2465pub const MOD_FREQUENCY: u32 = 0x0002;
2466pub const MOD_MAXERROR: u32 = 0x0004;
2467pub const MOD_ESTERROR: u32 = 0x0008;
2468pub const MOD_STATUS: u32 = 0x0010;
2469pub const MOD_TIMECONST: u32 = 0x0020;
2470pub const MOD_CLKB: u32 = 0x4000;
2471pub const MOD_CLKA: u32 = 0x8000;
2472pub const STA_PLL: u32 = 0x0001;
2473pub const STA_PPSFREQ: i32 = 0x0002;
2474pub const STA_PPSTIME: i32 = 0x0004;
2475pub const STA_FLL: i32 = 0x0008;
2476pub const STA_INS: i32 = 0x0010;
2477pub const STA_DEL: i32 = 0x0020;
2478pub const STA_UNSYNC: i32 = 0x0040;
2479pub const STA_FREQHOLD: i32 = 0x0080;
2480pub const STA_PPSSIGNAL: i32 = 0x0100;
2481pub const STA_PPSJITTER: i32 = 0x0200;
2482pub const STA_PPSWANDER: i32 = 0x0400;
2483pub const STA_PPSERROR: i32 = 0x0800;
2484pub const STA_CLOCKERR: i32 = 0x1000;
2485pub const STA_RONLY: i32 =
2486    STA_PPSSIGNAL | STA_PPSJITTER | STA_PPSWANDER | STA_PPSERROR | STA_CLOCKERR;
2487pub const TIME_OK: i32 = 0;
2488pub const TIME_INS: i32 = 1;
2489pub const TIME_DEL: i32 = 2;
2490pub const TIME_OOP: i32 = 3;
2491pub const TIME_WAIT: i32 = 4;
2492pub const TIME_ERROR: i32 = 5;
2493
2494pub const PRIO_PROCESS: ::c_int = 0;
2495pub const PRIO_PGRP: ::c_int = 1;
2496pub const PRIO_USER: ::c_int = 2;
2497
2498pub const SCHED_OTHER: ::c_int = 0;
2499pub const SCHED_FIFO: ::c_int = 1;
2500pub const SCHED_RR: ::c_int = 2;
2501pub const SCHED_SYS: ::c_int = 3;
2502pub const SCHED_IA: ::c_int = 4;
2503pub const SCHED_FSS: ::c_int = 5;
2504pub const SCHED_FX: ::c_int = 6;
2505
2506// sys/priv.h
2507pub const PRIV_DEBUG: ::c_uint = 0x0001;
2508pub const PRIV_AWARE: ::c_uint = 0x0002;
2509pub const PRIV_AWARE_INHERIT: ::c_uint = 0x0004;
2510pub const __PROC_PROTECT: ::c_uint = 0x0008;
2511pub const NET_MAC_AWARE: ::c_uint = 0x0010;
2512pub const NET_MAC_AWARE_INHERIT: ::c_uint = 0x0020;
2513pub const PRIV_AWARE_RESET: ::c_uint = 0x0040;
2514pub const PRIV_XPOLICY: ::c_uint = 0x0080;
2515pub const PRIV_PFEXEC: ::c_uint = 0x0100;
2516pub const PRIV_USER: ::c_uint = PRIV_DEBUG
2517    | NET_MAC_AWARE
2518    | NET_MAC_AWARE_INHERIT
2519    | PRIV_XPOLICY
2520    | PRIV_AWARE_RESET
2521    | PRIV_PFEXEC;
2522
2523// sys/systeminfo.h
2524pub const SI_SYSNAME: ::c_int = 1;
2525pub const SI_HOSTNAME: ::c_int = 2;
2526pub const SI_RELEASE: ::c_int = 3;
2527pub const SI_VERSION: ::c_int = 4;
2528pub const SI_MACHINE: ::c_int = 5;
2529pub const SI_ARCHITECTURE: ::c_int = 6;
2530pub const SI_HW_SERIAL: ::c_int = 7;
2531pub const SI_HW_PROVIDER: ::c_int = 8;
2532pub const SI_SET_HOSTNAME: ::c_int = 258;
2533pub const SI_SET_SRPC_DOMAIN: ::c_int = 265;
2534pub const SI_PLATFORM: ::c_int = 513;
2535pub const SI_ISALIST: ::c_int = 514;
2536pub const SI_DHCP_CACHE: ::c_int = 515;
2537pub const SI_ARCHITECTURE_32: ::c_int = 516;
2538pub const SI_ARCHITECTURE_64: ::c_int = 517;
2539pub const SI_ARCHITECTURE_K: ::c_int = 518;
2540pub const SI_ARCHITECTURE_NATIVE: ::c_int = 519;
2541
2542// sys/lgrp_user.h
2543pub const LGRP_COOKIE_NONE: ::lgrp_cookie_t = 0;
2544pub const LGRP_AFF_NONE: ::lgrp_affinity_t = 0x0;
2545pub const LGRP_AFF_WEAK: ::lgrp_affinity_t = 0x10;
2546pub const LGRP_AFF_STRONG: ::lgrp_affinity_t = 0x100;
2547pub const LGRP_RSRC_COUNT: ::lgrp_rsrc_t = 2;
2548pub const LGRP_RSRC_CPU: ::lgrp_rsrc_t = 0;
2549pub const LGRP_RSRC_MEM: ::lgrp_rsrc_t = 1;
2550pub const LGRP_CONTENT_ALL: ::lgrp_content_t = 0;
2551pub const LGRP_CONTENT_HIERARCHY: ::lgrp_content_t = LGRP_CONTENT_ALL;
2552pub const LGRP_CONTENT_DIRECT: ::lgrp_content_t = 1;
2553pub const LGRP_LAT_CPU_TO_MEM: ::lgrp_lat_between_t = 0;
2554pub const LGRP_MEM_SZ_FREE: ::lgrp_mem_size_flag_t = 0;
2555pub const LGRP_MEM_SZ_INSTALLED: ::lgrp_mem_size_flag_t = 1;
2556pub const LGRP_VIEW_CALLER: ::lgrp_view_t = 0;
2557pub const LGRP_VIEW_OS: ::lgrp_view_t = 1;
2558
2559// sys/processor.h
2560
2561pub const P_OFFLINE: ::c_int = 0x001;
2562pub const P_ONLINE: ::c_int = 0x002;
2563pub const P_STATUS: ::c_int = 0x003;
2564pub const P_FAULTED: ::c_int = 0x004;
2565pub const P_POWEROFF: ::c_int = 0x005;
2566pub const P_NOINTR: ::c_int = 0x006;
2567pub const P_SPARE: ::c_int = 0x007;
2568pub const P_DISABLED: ::c_int = 0x008;
2569pub const P_FORCED: ::c_int = 0x10000000;
2570pub const PI_TYPELEN: ::c_int = 16;
2571pub const PI_FPUTYPE: ::c_int = 32;
2572
2573// sys/auxv.h
2574pub const AT_SUN_HWCAP: ::c_uint = 2009;
2575pub const AT_SUN_HWCAP2: ::c_uint = 2023;
2576pub const AT_SUN_FPTYPE: ::c_uint = 2027;
2577
2578// As per sys/socket.h, header alignment must be 8 bytes on SPARC
2579// and 4 bytes everywhere else:
2580#[cfg(target_arch = "sparc64")]
2581const _CMSG_HDR_ALIGNMENT: usize = 8;
2582#[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
2583const _CMSG_HDR_ALIGNMENT: usize = 4;
2584
2585const _CMSG_DATA_ALIGNMENT: usize = ::mem::size_of::<::c_int>();
2586
2587const_fn! {
2588    {const} fn _CMSG_HDR_ALIGN(p: usize) -> usize {
2589        (p + _CMSG_HDR_ALIGNMENT - 1) & !(_CMSG_HDR_ALIGNMENT - 1)
2590    }
2591
2592    {const} fn _CMSG_DATA_ALIGN(p: usize) -> usize {
2593        (p + _CMSG_DATA_ALIGNMENT - 1) & !(_CMSG_DATA_ALIGNMENT - 1)
2594    }
2595}
2596
2597f! {
2598    pub fn CMSG_DATA(cmsg: *const ::cmsghdr) -> *mut ::c_uchar {
2599        _CMSG_DATA_ALIGN(cmsg.offset(1) as usize) as *mut ::c_uchar
2600    }
2601
2602    pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint {
2603        _CMSG_DATA_ALIGN(::mem::size_of::<::cmsghdr>()) as ::c_uint + length
2604    }
2605
2606    pub fn CMSG_FIRSTHDR(mhdr: *const ::msghdr) -> *mut ::cmsghdr {
2607        if ((*mhdr).msg_controllen as usize) < ::mem::size_of::<::cmsghdr>() {
2608            0 as *mut ::cmsghdr
2609        } else {
2610            (*mhdr).msg_control as *mut ::cmsghdr
2611        }
2612    }
2613
2614    pub fn CMSG_NXTHDR(mhdr: *const ::msghdr, cmsg: *const ::cmsghdr)
2615        -> *mut ::cmsghdr
2616    {
2617        if cmsg.is_null() {
2618            return ::CMSG_FIRSTHDR(mhdr);
2619        };
2620        let next = _CMSG_HDR_ALIGN(cmsg as usize + (*cmsg).cmsg_len as usize
2621            + ::mem::size_of::<::cmsghdr>());
2622        let max = (*mhdr).msg_control as usize
2623            + (*mhdr).msg_controllen as usize;
2624        if next > max {
2625            0 as *mut ::cmsghdr
2626        } else {
2627            _CMSG_HDR_ALIGN(cmsg as usize + (*cmsg).cmsg_len as usize)
2628                as *mut ::cmsghdr
2629        }
2630    }
2631
2632    pub {const} fn CMSG_SPACE(length: ::c_uint) -> ::c_uint {
2633        _CMSG_HDR_ALIGN(::mem::size_of::<::cmsghdr>() as usize
2634            + length as usize) as ::c_uint
2635    }
2636
2637    pub fn FD_CLR(fd: ::c_int, set: *mut fd_set) -> () {
2638        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;
2639        let fd = fd as usize;
2640        (*set).fds_bits[fd / bits] &= !(1 << (fd % bits));
2641        return
2642    }
2643
2644    pub fn FD_ISSET(fd: ::c_int, set: *const fd_set) -> bool {
2645        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;
2646        let fd = fd as usize;
2647        return ((*set).fds_bits[fd / bits] & (1 << (fd % bits))) != 0
2648    }
2649
2650    pub fn FD_SET(fd: ::c_int, set: *mut fd_set) -> () {
2651        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;
2652        let fd = fd as usize;
2653        (*set).fds_bits[fd / bits] |= 1 << (fd % bits);
2654        return
2655    }
2656
2657    pub fn FD_ZERO(set: *mut fd_set) -> () {
2658        for slot in (*set).fds_bits.iter_mut() {
2659            *slot = 0;
2660        }
2661    }
2662}
2663
2664safe_f! {
2665    pub {const} fn WIFEXITED(status: ::c_int) -> bool {
2666        (status & 0xFF) == 0
2667    }
2668
2669    pub {const} fn WEXITSTATUS(status: ::c_int) -> ::c_int {
2670        (status >> 8) & 0xFF
2671    }
2672
2673    pub {const} fn WTERMSIG(status: ::c_int) -> ::c_int {
2674        status & 0x7F
2675    }
2676
2677    pub {const} fn WIFCONTINUED(status: ::c_int) -> bool {
2678        (status & 0xffff) == 0xffff
2679    }
2680
2681    pub {const} fn WSTOPSIG(status: ::c_int) -> ::c_int {
2682        (status & 0xff00) >> 8
2683    }
2684
2685    pub {const} fn WIFSIGNALED(status: ::c_int) -> bool {
2686        ((status & 0xff) > 0) && (status & 0xff00 == 0)
2687    }
2688
2689    pub {const} fn WIFSTOPPED(status: ::c_int) -> bool {
2690        ((status & 0xff) == 0x7f) && ((status & 0xff00) != 0)
2691    }
2692
2693    pub {const} fn WCOREDUMP(status: ::c_int) -> bool {
2694        (status & 0x80) != 0
2695    }
2696
2697    pub {const} fn MR_GET_TYPE(flags: ::c_uint) -> ::c_uint {
2698        flags & 0x0000ffff
2699    }
2700}
2701
2702extern "C" {
2703    pub fn getrlimit(resource: ::c_int, rlim: *mut ::rlimit) -> ::c_int;
2704    pub fn setrlimit(resource: ::c_int, rlim: *const ::rlimit) -> ::c_int;
2705
2706    pub fn strerror_r(errnum: ::c_int, buf: *mut c_char, buflen: ::size_t) -> ::c_int;
2707
2708    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int;
2709    pub fn sem_init(sem: *mut sem_t, pshared: ::c_int, value: ::c_uint) -> ::c_int;
2710
2711    pub fn abs(i: ::c_int) -> ::c_int;
2712    pub fn acct(filename: *const ::c_char) -> ::c_int;
2713    pub fn dirfd(dirp: *mut ::DIR) -> ::c_int;
2714    pub fn labs(i: ::c_long) -> ::c_long;
2715    pub fn rand() -> ::c_int;
2716    pub fn srand(seed: ::c_uint);
2717    pub fn getentropy(buf: *mut ::c_void, buflen: ::size_t) -> ::c_int;
2718    pub fn getrandom(bbuf: *mut ::c_void, buflen: ::size_t, flags: ::c_uint) -> ::ssize_t;
2719
2720    pub fn gettimeofday(tp: *mut ::timeval, tz: *mut ::c_void) -> ::c_int;
2721    pub fn settimeofday(tp: *const ::timeval, tz: *const ::c_void) -> ::c_int;
2722    pub fn getifaddrs(ifap: *mut *mut ::ifaddrs) -> ::c_int;
2723    pub fn freeifaddrs(ifa: *mut ::ifaddrs);
2724
2725    pub fn stack_getbounds(sp: *mut ::stack_t) -> ::c_int;
2726    pub fn getgrouplist(
2727        name: *const ::c_char,
2728        basegid: ::gid_t,
2729        groups: *mut ::gid_t,
2730        ngroups: *mut ::c_int,
2731    ) -> ::c_int;
2732    pub fn initgroups(name: *const ::c_char, basegid: ::gid_t) -> ::c_int;
2733    pub fn setgroups(ngroups: ::c_int, ptr: *const ::gid_t) -> ::c_int;
2734    pub fn ioctl(fildes: ::c_int, request: ::c_int, ...) -> ::c_int;
2735    pub fn mprotect(addr: *const ::c_void, len: ::size_t, prot: ::c_int) -> ::c_int;
2736    pub fn ___errno() -> *mut ::c_int;
2737    pub fn clock_getres(clk_id: ::clockid_t, tp: *mut ::timespec) -> ::c_int;
2738    pub fn clock_gettime(clk_id: ::clockid_t, tp: *mut ::timespec) -> ::c_int;
2739    pub fn clock_nanosleep(
2740        clk_id: ::clockid_t,
2741        flags: ::c_int,
2742        rqtp: *const ::timespec,
2743        rmtp: *mut ::timespec,
2744    ) -> ::c_int;
2745    pub fn clock_settime(clk_id: ::clockid_t, tp: *const ::timespec) -> ::c_int;
2746    pub fn getnameinfo(
2747        sa: *const ::sockaddr,
2748        salen: ::socklen_t,
2749        host: *mut ::c_char,
2750        hostlen: ::socklen_t,
2751        serv: *mut ::c_char,
2752        sevlen: ::socklen_t,
2753        flags: ::c_int,
2754    ) -> ::c_int;
2755    pub fn setpwent();
2756    pub fn endpwent();
2757    pub fn getpwent() -> *mut passwd;
2758    pub fn fdatasync(fd: ::c_int) -> ::c_int;
2759    pub fn nl_langinfo_l(item: ::nl_item, locale: ::locale_t) -> *mut ::c_char;
2760    pub fn duplocale(base: ::locale_t) -> ::locale_t;
2761    pub fn freelocale(loc: ::locale_t);
2762    pub fn newlocale(mask: ::c_int, locale: *const ::c_char, base: ::locale_t) -> ::locale_t;
2763    pub fn uselocale(loc: ::locale_t) -> ::locale_t;
2764    pub fn getprogname() -> *const ::c_char;
2765    pub fn setprogname(name: *const ::c_char);
2766    pub fn getloadavg(loadavg: *mut ::c_double, nelem: ::c_int) -> ::c_int;
2767    pub fn getpriority(which: ::c_int, who: ::c_int) -> ::c_int;
2768    pub fn setpriority(which: ::c_int, who: ::c_int, prio: ::c_int) -> ::c_int;
2769
2770    pub fn mknodat(
2771        dirfd: ::c_int,
2772        pathname: *const ::c_char,
2773        mode: ::mode_t,
2774        dev: dev_t,
2775    ) -> ::c_int;
2776    pub fn mkfifoat(dirfd: ::c_int, pathname: *const ::c_char, mode: ::mode_t) -> ::c_int;
2777    pub fn sethostname(name: *const ::c_char, len: ::c_int) -> ::c_int;
2778    pub fn if_nameindex() -> *mut if_nameindex;
2779    pub fn if_freenameindex(ptr: *mut if_nameindex);
2780    pub fn pthread_create(
2781        native: *mut ::pthread_t,
2782        attr: *const ::pthread_attr_t,
2783        f: extern "C" fn(*mut ::c_void) -> *mut ::c_void,
2784        value: *mut ::c_void,
2785    ) -> ::c_int;
2786    pub fn pthread_attr_getstack(
2787        attr: *const ::pthread_attr_t,
2788        stackaddr: *mut *mut ::c_void,
2789        stacksize: *mut ::size_t,
2790    ) -> ::c_int;
2791    pub fn pthread_condattr_getclock(
2792        attr: *const pthread_condattr_t,
2793        clock_id: *mut clockid_t,
2794    ) -> ::c_int;
2795    pub fn pthread_condattr_setclock(
2796        attr: *mut pthread_condattr_t,
2797        clock_id: ::clockid_t,
2798    ) -> ::c_int;
2799    pub fn sem_timedwait(sem: *mut sem_t, abstime: *const ::timespec) -> ::c_int;
2800    pub fn sem_getvalue(sem: *mut sem_t, sval: *mut ::c_int) -> ::c_int;
2801    pub fn pthread_mutex_timedlock(
2802        lock: *mut pthread_mutex_t,
2803        abstime: *const ::timespec,
2804    ) -> ::c_int;
2805    pub fn pthread_getname_np(tid: ::pthread_t, name: *mut ::c_char, len: ::size_t) -> ::c_int;
2806    pub fn pthread_setname_np(tid: ::pthread_t, name: *const ::c_char) -> ::c_int;
2807    pub fn waitid(idtype: idtype_t, id: id_t, infop: *mut ::siginfo_t, options: ::c_int)
2808        -> ::c_int;
2809
2810    #[cfg_attr(target_os = "illumos", link_name = "_glob_ext")]
2811    pub fn glob(
2812        pattern: *const ::c_char,
2813        flags: ::c_int,
2814        errfunc: ::Option<extern "C" fn(epath: *const ::c_char, errno: ::c_int) -> ::c_int>,
2815        pglob: *mut ::glob_t,
2816    ) -> ::c_int;
2817
2818    #[cfg_attr(target_os = "illumos", link_name = "_globfree_ext")]
2819    pub fn globfree(pglob: *mut ::glob_t);
2820
2821    pub fn posix_madvise(addr: *mut ::c_void, len: ::size_t, advice: ::c_int) -> ::c_int;
2822
2823    pub fn shmat(shmid: ::c_int, shmaddr: *const ::c_void, shmflg: ::c_int) -> *mut ::c_void;
2824
2825    pub fn shmctl(shmid: ::c_int, cmd: ::c_int, buf: *mut ::shmid_ds) -> ::c_int;
2826
2827    pub fn shmdt(shmaddr: *const ::c_void) -> ::c_int;
2828
2829    pub fn shmget(key: key_t, size: ::size_t, shmflg: ::c_int) -> ::c_int;
2830
2831    pub fn shm_open(name: *const ::c_char, oflag: ::c_int, mode: ::mode_t) -> ::c_int;
2832    pub fn shm_unlink(name: *const ::c_char) -> ::c_int;
2833
2834    pub fn seekdir(dirp: *mut ::DIR, loc: ::c_long);
2835
2836    pub fn telldir(dirp: *mut ::DIR) -> ::c_long;
2837    pub fn madvise(addr: *mut ::c_void, len: ::size_t, advice: ::c_int) -> ::c_int;
2838
2839    pub fn msync(addr: *mut ::c_void, len: ::size_t, flags: ::c_int) -> ::c_int;
2840
2841    pub fn memalign(align: ::size_t, size: ::size_t) -> *mut ::c_void;
2842
2843    pub fn recvfrom(
2844        socket: ::c_int,
2845        buf: *mut ::c_void,
2846        len: ::size_t,
2847        flags: ::c_int,
2848        addr: *mut ::sockaddr,
2849        addrlen: *mut ::socklen_t,
2850    ) -> ::ssize_t;
2851    pub fn mkstemps(template: *mut ::c_char, suffixlen: ::c_int) -> ::c_int;
2852    pub fn futimesat(fd: ::c_int, path: *const ::c_char, times: *const ::timeval) -> ::c_int;
2853    pub fn futimens(dirfd: ::c_int, times: *const ::timespec) -> ::c_int;
2854    pub fn utimensat(
2855        dirfd: ::c_int,
2856        path: *const ::c_char,
2857        times: *const ::timespec,
2858        flag: ::c_int,
2859    ) -> ::c_int;
2860    pub fn nl_langinfo(item: ::nl_item) -> *mut ::c_char;
2861
2862    #[cfg_attr(target_os = "illumos", link_name = "__xnet_bind")]
2863    pub fn bind(socket: ::c_int, address: *const ::sockaddr, address_len: ::socklen_t) -> ::c_int;
2864
2865    pub fn writev(fd: ::c_int, iov: *const ::iovec, iovcnt: ::c_int) -> ::ssize_t;
2866    pub fn readv(fd: ::c_int, iov: *const ::iovec, iovcnt: ::c_int) -> ::ssize_t;
2867
2868    #[cfg_attr(target_os = "illumos", link_name = "__xnet_sendmsg")]
2869    pub fn sendmsg(fd: ::c_int, msg: *const ::msghdr, flags: ::c_int) -> ::ssize_t;
2870    #[cfg_attr(target_os = "illumos", link_name = "__xnet_recvmsg")]
2871    pub fn recvmsg(fd: ::c_int, msg: *mut ::msghdr, flags: ::c_int) -> ::ssize_t;
2872    pub fn accept4(
2873        fd: ::c_int,
2874        address: *mut sockaddr,
2875        address_len: *mut socklen_t,
2876        flags: ::c_int,
2877    ) -> ::c_int;
2878
2879    pub fn mq_open(name: *const ::c_char, oflag: ::c_int, ...) -> ::mqd_t;
2880    pub fn mq_close(mqd: ::mqd_t) -> ::c_int;
2881    pub fn mq_unlink(name: *const ::c_char) -> ::c_int;
2882    pub fn mq_receive(
2883        mqd: ::mqd_t,
2884        msg_ptr: *mut ::c_char,
2885        msg_len: ::size_t,
2886        msg_prio: *mut ::c_uint,
2887    ) -> ::ssize_t;
2888    pub fn mq_timedreceive(
2889        mqd: ::mqd_t,
2890        msg_ptr: *mut ::c_char,
2891        msg_len: ::size_t,
2892        msg_prio: *mut ::c_uint,
2893        abs_timeout: *const ::timespec,
2894    ) -> ::ssize_t;
2895    pub fn mq_send(
2896        mqd: ::mqd_t,
2897        msg_ptr: *const ::c_char,
2898        msg_len: ::size_t,
2899        msg_prio: ::c_uint,
2900    ) -> ::c_int;
2901    pub fn mq_timedsend(
2902        mqd: ::mqd_t,
2903        msg_ptr: *const ::c_char,
2904        msg_len: ::size_t,
2905        msg_prio: ::c_uint,
2906        abs_timeout: *const ::timespec,
2907    ) -> ::c_int;
2908    pub fn mq_getattr(mqd: ::mqd_t, attr: *mut ::mq_attr) -> ::c_int;
2909    pub fn mq_setattr(mqd: ::mqd_t, newattr: *const ::mq_attr, oldattr: *mut ::mq_attr) -> ::c_int;
2910    pub fn port_create() -> ::c_int;
2911    pub fn port_associate(
2912        port: ::c_int,
2913        source: ::c_int,
2914        object: ::uintptr_t,
2915        events: ::c_int,
2916        user: *mut ::c_void,
2917    ) -> ::c_int;
2918    pub fn port_dissociate(port: ::c_int, source: ::c_int, object: ::uintptr_t) -> ::c_int;
2919    pub fn port_get(port: ::c_int, pe: *mut port_event, timeout: *mut ::timespec) -> ::c_int;
2920    pub fn port_getn(
2921        port: ::c_int,
2922        pe_list: *mut port_event,
2923        max: ::c_uint,
2924        nget: *mut ::c_uint,
2925        timeout: *mut ::timespec,
2926    ) -> ::c_int;
2927    pub fn port_send(port: ::c_int, events: ::c_int, user: *mut ::c_void) -> ::c_int;
2928    pub fn port_sendn(
2929        port_list: *mut ::c_int,
2930        error_list: *mut ::c_int,
2931        nent: ::c_uint,
2932        events: ::c_int,
2933        user: *mut ::c_void,
2934    ) -> ::c_int;
2935    #[cfg_attr(
2936        any(target_os = "solaris", target_os = "illumos"),
2937        link_name = "__posix_getgrgid_r"
2938    )]
2939    pub fn getgrgid_r(
2940        gid: ::gid_t,
2941        grp: *mut ::group,
2942        buf: *mut ::c_char,
2943        buflen: ::size_t,
2944        result: *mut *mut ::group,
2945    ) -> ::c_int;
2946    pub fn sigaltstack(ss: *const stack_t, oss: *mut stack_t) -> ::c_int;
2947    pub fn sem_close(sem: *mut sem_t) -> ::c_int;
2948    pub fn getdtablesize() -> ::c_int;
2949
2950    // The epoll functions are actually only present on illumos.  However,
2951    // there are things using epoll on illumos (built using the
2952    // x86_64-pc-solaris target) which would break until the illumos target is
2953    // present in rustc.
2954    pub fn epoll_pwait(
2955        epfd: ::c_int,
2956        events: *mut ::epoll_event,
2957        maxevents: ::c_int,
2958        timeout: ::c_int,
2959        sigmask: *const ::sigset_t,
2960    ) -> ::c_int;
2961
2962    pub fn epoll_create(size: ::c_int) -> ::c_int;
2963    pub fn epoll_create1(flags: ::c_int) -> ::c_int;
2964    pub fn epoll_wait(
2965        epfd: ::c_int,
2966        events: *mut ::epoll_event,
2967        maxevents: ::c_int,
2968        timeout: ::c_int,
2969    ) -> ::c_int;
2970    pub fn epoll_ctl(epfd: ::c_int, op: ::c_int, fd: ::c_int, event: *mut ::epoll_event)
2971        -> ::c_int;
2972
2973    #[cfg_attr(
2974        any(target_os = "solaris", target_os = "illumos"),
2975        link_name = "__posix_getgrnam_r"
2976    )]
2977    pub fn getgrnam_r(
2978        name: *const ::c_char,
2979        grp: *mut ::group,
2980        buf: *mut ::c_char,
2981        buflen: ::size_t,
2982        result: *mut *mut ::group,
2983    ) -> ::c_int;
2984    pub fn thr_self() -> ::thread_t;
2985    pub fn pthread_sigmask(how: ::c_int, set: *const sigset_t, oldset: *mut sigset_t) -> ::c_int;
2986    pub fn sem_open(name: *const ::c_char, oflag: ::c_int, ...) -> *mut sem_t;
2987    pub fn getgrnam(name: *const ::c_char) -> *mut ::group;
2988    pub fn pthread_kill(thread: ::pthread_t, sig: ::c_int) -> ::c_int;
2989    pub fn sched_get_priority_min(policy: ::c_int) -> ::c_int;
2990    pub fn sched_get_priority_max(policy: ::c_int) -> ::c_int;
2991    pub fn sched_getparam(pid: ::pid_t, param: *mut sched_param) -> ::c_int;
2992    pub fn sched_setparam(pid: ::pid_t, param: *const sched_param) -> ::c_int;
2993    pub fn sched_getscheduler(pid: ::pid_t) -> ::c_int;
2994    pub fn sched_setscheduler(
2995        pid: ::pid_t,
2996        policy: ::c_int,
2997        param: *const ::sched_param,
2998    ) -> ::c_int;
2999    pub fn sem_unlink(name: *const ::c_char) -> ::c_int;
3000    pub fn daemon(nochdir: ::c_int, noclose: ::c_int) -> ::c_int;
3001    #[cfg_attr(
3002        any(target_os = "solaris", target_os = "illumos"),
3003        link_name = "__posix_getpwnam_r"
3004    )]
3005    pub fn getpwnam_r(
3006        name: *const ::c_char,
3007        pwd: *mut passwd,
3008        buf: *mut ::c_char,
3009        buflen: ::size_t,
3010        result: *mut *mut passwd,
3011    ) -> ::c_int;
3012    #[cfg_attr(
3013        any(target_os = "solaris", target_os = "illumos"),
3014        link_name = "__posix_getpwuid_r"
3015    )]
3016    pub fn getpwuid_r(
3017        uid: ::uid_t,
3018        pwd: *mut passwd,
3019        buf: *mut ::c_char,
3020        buflen: ::size_t,
3021        result: *mut *mut passwd,
3022    ) -> ::c_int;
3023    #[cfg_attr(
3024        any(target_os = "solaris", target_os = "illumos"),
3025        link_name = "getpwent_r"
3026    )]
3027    fn native_getpwent_r(pwd: *mut passwd, buf: *mut ::c_char, buflen: ::c_int) -> *mut passwd;
3028    #[cfg_attr(
3029        any(target_os = "solaris", target_os = "illumos"),
3030        link_name = "getgrent_r"
3031    )]
3032    fn native_getgrent_r(grp: *mut ::group, buf: *mut ::c_char, buflen: ::c_int) -> *mut ::group;
3033    #[cfg_attr(
3034        any(target_os = "solaris", target_os = "illumos"),
3035        link_name = "__posix_sigwait"
3036    )]
3037    pub fn sigwait(set: *const sigset_t, sig: *mut ::c_int) -> ::c_int;
3038    pub fn pthread_atfork(
3039        prepare: ::Option<unsafe extern "C" fn()>,
3040        parent: ::Option<unsafe extern "C" fn()>,
3041        child: ::Option<unsafe extern "C" fn()>,
3042    ) -> ::c_int;
3043    pub fn getgrgid(gid: ::gid_t) -> *mut ::group;
3044    pub fn setgrent();
3045    pub fn endgrent();
3046    pub fn getgrent() -> *mut ::group;
3047    pub fn popen(command: *const c_char, mode: *const c_char) -> *mut ::FILE;
3048
3049    pub fn dup3(src: ::c_int, dst: ::c_int, flags: ::c_int) -> ::c_int;
3050    pub fn uname(buf: *mut ::utsname) -> ::c_int;
3051    pub fn pipe2(fds: *mut ::c_int, flags: ::c_int) -> ::c_int;
3052
3053    pub fn makeutx(ux: *const utmpx) -> *mut utmpx;
3054    pub fn modutx(ux: *const utmpx) -> *mut utmpx;
3055    pub fn updwtmpx(file: *const ::c_char, ut: *const utmpx) -> ::c_int;
3056    pub fn utmpxname(file: *const ::c_char) -> ::c_int;
3057    pub fn getutxent() -> *mut utmpx;
3058    pub fn getutxid(ut: *const utmpx) -> *mut utmpx;
3059    pub fn getutxline(ut: *const utmpx) -> *mut utmpx;
3060    pub fn pututxline(ut: *const utmpx) -> *mut utmpx;
3061    pub fn setutxent();
3062    pub fn endutxent();
3063
3064    pub fn endutent();
3065    pub fn getutent() -> *mut utmp;
3066    pub fn getutid(u: *const utmp) -> *mut utmp;
3067    pub fn getutline(u: *const utmp) -> *mut utmp;
3068    pub fn pututline(u: *const utmp) -> *mut utmp;
3069    pub fn setutent();
3070    pub fn utmpname(file: *const ::c_char) -> ::c_int;
3071
3072    pub fn getutmp(ux: *const utmpx, u: *mut utmp);
3073    pub fn getutmpx(u: *const utmp, ux: *mut utmpx);
3074    pub fn updwtmp(file: *const ::c_char, u: *mut utmp);
3075
3076    pub fn ntp_adjtime(buf: *mut timex) -> ::c_int;
3077    pub fn ntp_gettime(buf: *mut ntptimeval) -> ::c_int;
3078
3079    pub fn timer_create(clock_id: clockid_t, evp: *mut sigevent, timerid: *mut timer_t) -> ::c_int;
3080    pub fn timer_delete(timerid: timer_t) -> ::c_int;
3081    pub fn timer_getoverrun(timerid: timer_t) -> ::c_int;
3082    pub fn timer_gettime(timerid: timer_t, value: *mut itimerspec) -> ::c_int;
3083    pub fn timer_settime(
3084        timerid: timer_t,
3085        flags: ::c_int,
3086        value: *const itimerspec,
3087        ovalue: *mut itimerspec,
3088    ) -> ::c_int;
3089
3090    pub fn ucred_get(pid: ::pid_t) -> *mut ucred_t;
3091    pub fn getpeerucred(fd: ::c_int, ucred: *mut *mut ucred_t) -> ::c_int;
3092
3093    pub fn ucred_free(ucred: *mut ucred_t);
3094
3095    pub fn ucred_geteuid(ucred: *const ucred_t) -> ::uid_t;
3096    pub fn ucred_getruid(ucred: *const ucred_t) -> ::uid_t;
3097    pub fn ucred_getsuid(ucred: *const ucred_t) -> ::uid_t;
3098    pub fn ucred_getegid(ucred: *const ucred_t) -> ::gid_t;
3099    pub fn ucred_getrgid(ucred: *const ucred_t) -> ::gid_t;
3100    pub fn ucred_getsgid(ucred: *const ucred_t) -> ::gid_t;
3101    pub fn ucred_getgroups(ucred: *const ucred_t, groups: *mut *const ::gid_t) -> ::c_int;
3102    pub fn ucred_getpid(ucred: *const ucred_t) -> ::pid_t;
3103    pub fn ucred_getprojid(ucred: *const ucred_t) -> projid_t;
3104    pub fn ucred_getzoneid(ucred: *const ucred_t) -> zoneid_t;
3105    pub fn ucred_getpflags(ucred: *const ucred_t, flags: ::c_uint) -> ::c_uint;
3106
3107    pub fn ucred_size() -> ::size_t;
3108
3109    pub fn pset_create(newpset: *mut ::psetid_t) -> ::c_int;
3110    pub fn pset_destroy(pset: ::psetid_t) -> ::c_int;
3111    pub fn pset_assign(pset: ::psetid_t, cpu: ::processorid_t, opset: *mut psetid_t) -> ::c_int;
3112    pub fn pset_info(
3113        pset: ::psetid_t,
3114        tpe: *mut ::c_int,
3115        numcpus: *mut ::c_uint,
3116        cpulist: *mut processorid_t,
3117    ) -> ::c_int;
3118    pub fn pset_bind(
3119        pset: ::psetid_t,
3120        idtype: ::idtype_t,
3121        id: ::id_t,
3122        opset: *mut psetid_t,
3123    ) -> ::c_int;
3124    pub fn pset_list(pset: *mut psetid_t, numpsets: *mut ::c_uint) -> ::c_int;
3125    pub fn pset_setattr(pset: psetid_t, attr: ::c_uint) -> ::c_int;
3126    pub fn pset_getattr(pset: psetid_t, attr: *mut ::c_uint) -> ::c_int;
3127    pub fn processor_bind(
3128        idtype: ::idtype_t,
3129        id: ::id_t,
3130        new_binding: ::processorid_t,
3131        old_binding: *mut processorid_t,
3132    ) -> ::c_int;
3133    pub fn p_online(processorid: ::processorid_t, flag: ::c_int) -> ::c_int;
3134    pub fn processor_info(processorid: ::processorid_t, infop: *mut processor_info_t) -> ::c_int;
3135
3136    pub fn getexecname() -> *const ::c_char;
3137
3138    pub fn gethostid() -> ::c_long;
3139
3140    pub fn getpflags(flags: ::c_uint) -> ::c_uint;
3141    pub fn setpflags(flags: ::c_uint, value: ::c_uint) -> ::c_int;
3142
3143    pub fn sysinfo(command: ::c_int, buf: *mut ::c_char, count: ::c_long) -> ::c_int;
3144
3145    pub fn faccessat(fd: ::c_int, path: *const ::c_char, amode: ::c_int, flag: ::c_int) -> ::c_int;
3146
3147    // #include <link.h>
3148    #[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
3149    pub fn dl_iterate_phdr(
3150        callback: ::Option<
3151            unsafe extern "C" fn(
3152                info: *mut dl_phdr_info,
3153                size: usize,
3154                data: *mut ::c_void,
3155            ) -> ::c_int,
3156        >,
3157        data: *mut ::c_void,
3158    ) -> ::c_int;
3159    pub fn getpagesize() -> ::c_int;
3160    pub fn getpagesizes(pagesize: *mut ::size_t, nelem: ::c_int) -> ::c_int;
3161    pub fn mmapobj(
3162        fd: ::c_int,
3163        flags: ::c_uint,
3164        storage: *mut mmapobj_result_t,
3165        elements: *mut ::c_uint,
3166        arg: *mut ::c_void,
3167    ) -> ::c_int;
3168    pub fn meminfo(
3169        inaddr: *const u64,
3170        addr_count: ::c_int,
3171        info_req: *const ::c_uint,
3172        info_count: ::c_int,
3173        outdata: *mut u64,
3174        validity: *mut ::c_uint,
3175    ) -> ::c_int;
3176
3177    pub fn strcasecmp_l(s1: *const ::c_char, s2: *const ::c_char, loc: ::locale_t) -> ::c_int;
3178    pub fn strncasecmp_l(
3179        s1: *const ::c_char,
3180        s2: *const ::c_char,
3181        n: ::size_t,
3182        loc: ::locale_t,
3183    ) -> ::c_int;
3184    pub fn strsep(string: *mut *mut ::c_char, delim: *const ::c_char) -> *mut ::c_char;
3185
3186    pub fn getisax(array: *mut u32, n: ::c_uint) -> ::c_uint;
3187
3188    pub fn backtrace(buffer: *mut *mut ::c_void, size: ::c_int) -> ::c_int;
3189    pub fn backtrace_symbols(buffer: *const *mut ::c_void, size: ::c_int) -> *mut *mut ::c_char;
3190    pub fn backtrace_symbols_fd(buffer: *const *mut ::c_void, size: ::c_int, fd: ::c_int);
3191
3192    pub fn getopt_long(
3193        argc: ::c_int,
3194        argv: *const *mut c_char,
3195        optstring: *const c_char,
3196        longopts: *const option,
3197        longindex: *mut ::c_int,
3198    ) -> ::c_int;
3199}
3200
3201#[link(name = "sendfile")]
3202extern "C" {
3203    pub fn sendfile(out_fd: ::c_int, in_fd: ::c_int, off: *mut ::off_t, len: ::size_t)
3204        -> ::ssize_t;
3205    pub fn sendfilev(
3206        fildes: ::c_int,
3207        vec: *const sendfilevec_t,
3208        sfvcnt: ::c_int,
3209        xferred: *mut ::size_t,
3210    ) -> ::ssize_t;
3211}
3212
3213#[link(name = "lgrp")]
3214extern "C" {
3215    pub fn lgrp_init(view: lgrp_view_t) -> lgrp_cookie_t;
3216    pub fn lgrp_fini(cookie: lgrp_cookie_t) -> ::c_int;
3217    pub fn lgrp_affinity_get(
3218        idtype: ::idtype_t,
3219        id: ::id_t,
3220        lgrp: ::lgrp_id_t,
3221    ) -> ::lgrp_affinity_t;
3222    pub fn lgrp_affinity_set(
3223        idtype: ::idtype_t,
3224        id: ::id_t,
3225        lgrp: ::lgrp_id_t,
3226        aff: lgrp_affinity_t,
3227    ) -> ::lgrp_affinity_t;
3228    pub fn lgrp_cpus(
3229        cookie: ::lgrp_cookie_t,
3230        lgrp: ::lgrp_id_t,
3231        cpuids: *mut ::processorid_t,
3232        count: ::c_uint,
3233        content: ::lgrp_content_t,
3234    ) -> ::c_int;
3235    pub fn lgrp_mem_size(
3236        cookie: ::lgrp_cookie_t,
3237        lgrp: ::lgrp_id_t,
3238        tpe: ::lgrp_mem_size_flag_t,
3239        content: ::lgrp_content_t,
3240    ) -> ::lgrp_mem_size_t;
3241    pub fn lgrp_nlgrps(cookie: ::lgrp_cookie_t) -> ::c_int;
3242    pub fn lgrp_view(cookie: ::lgrp_cookie_t) -> ::lgrp_view_t;
3243    pub fn lgrp_home(idtype: ::idtype_t, id: ::id_t) -> ::lgrp_id_t;
3244    pub fn lgrp_version(version: ::c_int) -> ::c_int;
3245    pub fn lgrp_resources(
3246        cookie: ::lgrp_cookie_t,
3247        lgrp: ::lgrp_id_t,
3248        lgrps: *mut ::lgrp_id_t,
3249        count: ::c_uint,
3250        tpe: ::lgrp_rsrc_t,
3251    ) -> ::c_int;
3252    pub fn lgrp_root(cookie: ::lgrp_cookie_t) -> ::lgrp_id_t;
3253}
3254
3255mod compat;
3256pub use self::compat::*;
3257
3258cfg_if! {
3259    if #[cfg(target_os = "illumos")] {
3260        mod illumos;
3261        pub use self::illumos::*;
3262    } else if #[cfg(target_os = "solaris")] {
3263        mod solaris;
3264        pub use self::solaris::*;
3265    } else {
3266        // Unknown target_os
3267    }
3268}
3269
3270cfg_if! {
3271    if #[cfg(target_arch = "x86_64")] {
3272        mod x86_64;
3273        mod x86_common;
3274        pub use self::x86_64::*;
3275        pub use self::x86_common::*;
3276    } else if #[cfg(target_arch = "x86")] {
3277        mod x86;
3278        mod x86_common;
3279        pub use self::x86::*;
3280        pub use self::x86_common::*;
3281    }
3282}
3283