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