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