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