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