pub type c_long = i64; pub type c_ulong = u64; s! { pub struct sigset_t { pub ss_set: [c_ulong; 4], } pub struct fd_set { pub fds_bits: [c_long; 1024], } pub struct flock { pub l_type: ::c_short, pub l_whence: ::c_short, pub l_sysid: ::c_uint, pub l_pid: ::pid_t, pub l_vfs: ::c_int, pub l_start: ::off_t, pub l_len: ::off_t, } pub struct statvfs { pub f_bsize: ::c_ulong, pub f_frsize: ::c_ulong, pub f_blocks: ::fsblkcnt_t, pub f_bfree: ::fsblkcnt_t, pub f_bavail: ::fsblkcnt_t, pub f_files: ::fsfilcnt_t, pub f_ffree: ::fsfilcnt_t, pub f_favail: ::fsfilcnt_t, pub f_fsid: ::c_ulong, pub f_basetype: [::c_char; 16], pub f_flag: ::c_ulong, pub f_namemax: ::c_ulong, pub f_fstr: [::c_char; 32], pub f_filler: [::c_ulong; 16] } pub struct pthread_rwlock_t { __rw_word: [::c_long; 10], } pub struct pthread_cond_t { __cv_word: [::c_long; 6], } pub struct pthread_mutex_t { __mt_word: [::c_long; 8], } pub struct stat { pub st_dev: ::dev_t, pub st_ino: ::ino_t, pub st_mode: ::mode_t, pub st_nlink: ::nlink_t, pub st_flag: ::c_ushort, pub st_uid: ::uid_t, pub st_gid: ::gid_t, pub st_rdev: ::dev_t, pub st_ssize: ::c_int, pub st_atime: ::st_timespec, pub st_mtime: ::st_timespec, pub st_ctime: ::st_timespec, pub st_blksize: ::blksize_t, pub st_blocks: ::blkcnt_t, pub st_vfstype: ::c_int, pub st_vfs: ::c_uint, pub st_type: ::c_uint, pub st_gen: ::c_uint, pub st_reserved: [::c_uint; 9], pub st_padto_ll: ::c_uint, pub st_size: ::off_t, } pub struct statfs { pub f_version: ::c_int, pub f_type: ::c_int, pub f_bsize: ::c_ulong, pub f_blocks: ::fsblkcnt_t, pub f_bfree: ::fsblkcnt_t, pub f_bavail: ::fsblkcnt_t, pub f_files: ::fsblkcnt_t, pub f_ffree: ::fsblkcnt_t, pub f_fsid: ::fsid64_t, pub f_vfstype: ::c_int, pub f_fsize: ::c_ulong, pub f_vfsnumber: ::c_int, pub f_vfsoff: ::c_int, pub f_vfslen: ::c_int, pub f_vfsvers: ::c_int, pub f_fname: [::c_char; 32], pub f_fpack: [::c_char; 32], pub f_name_max: ::c_int, } pub struct aiocb { pub aio_lio_opcode: ::c_int, pub aio_fildes: ::c_int, pub aio_word1: ::c_int, pub aio_offset: ::off_t, pub aio_buf: *mut ::c_void, pub aio_return: ::ssize_t, pub aio_errno: ::c_int, pub aio_nbytes: ::size_t, pub aio_reqprio: ::c_int, pub aio_sigevent: ::sigevent, pub aio_word2: ::c_int, pub aio_fp: ::c_int, pub aio_handle: *mut aiocb, pub aio_reserved: [::c_uint; 2], pub aio_sigev_tid: c_long, } pub struct ucontext_t { pub __sc_onstack: ::c_int, pub uc_sigmask: ::sigset_t, pub __sc_uerror: ::c_int, pub uc_mcontext: ::mcontext_t, pub uc_link: *mut ucontext_t, pub uc_stack: ::stack_t, // Should be pointer to __extctx_t pub __extctx: *mut ::c_void, pub __extctx_magic: ::c_int, pub __pad: [::c_int; 1], } pub struct mcontext_t { pub gpr: [::c_ulonglong; 32], pub msr: ::c_ulonglong, pub iar: ::c_ulonglong, pub lr: ::c_ulonglong, pub ctr: ::c_ulonglong, pub cr: ::c_uint, pub xer: ::c_uint, pub fpscr: ::c_uint, pub fpscrx: ::c_uint, pub except: [::c_ulonglong; 1], // Should be array of double type pub fpr: [::uint64_t; 32], pub fpeu: ::c_char, pub fpinfo: ::c_char, pub fpscr24_31: ::c_char, pub pad: [::c_char; 1], pub excp_type: ::c_int, } pub struct utmpx { pub ut_user: [::c_char; 256], pub ut_id: [::c_char; 14], pub ut_line: [::c_char; 64], pub ut_pid: ::pid_t, pub ut_type: ::c_short, pub ut_tv: ::timeval, pub ut_host: [::c_char; 256], pub __dbl_word_pad: ::c_int, pub __reservedA: [::c_int; 2], pub __reservedV: [::c_int; 6], } pub struct pthread_spinlock_t { pub __sp_word: [::c_long; 3], } pub struct pthread_barrier_t { pub __br_word: [::c_long; 5], } pub struct msqid_ds { pub msg_perm: ::ipc_perm, pub msg_first: ::c_uint, pub msg_last: ::c_uint, pub msg_cbytes: ::c_uint, pub msg_qnum: ::c_uint, pub msg_qbytes: ::c_ulong, pub msg_lspid: ::pid_t, pub msg_lrpid: ::pid_t, pub msg_stime: ::time_t, pub msg_rtime: ::time_t, pub msg_ctime: ::time_t, pub msg_rwait: ::c_int, pub msg_wwait: ::c_int, pub msg_reqevents: ::c_ushort, } } s_no_extra_traits! { pub struct siginfo_t { pub si_signo: ::c_int, pub si_errno: ::c_int, pub si_code: ::c_int, pub si_pid: ::pid_t, pub si_uid: ::uid_t, pub si_status: ::c_int, pub si_addr: *mut ::c_void, pub si_band: ::c_long, pub si_value: ::sigval, pub __si_flags: ::c_int, pub __pad: [::c_int; 3], } #[cfg(libc_union)] pub union _kernel_simple_lock { pub _slock: ::c_long, // Should be pointer to 'lock_data_instrumented' pub _slockp: *mut ::c_void, } pub struct fileops_t { pub fo_rw: extern fn(file: *mut file, rw: ::uio_rw, io: *mut ::c_void, ext: ::c_long, secattr: *mut ::c_void) -> ::c_int, pub fo_ioctl: extern fn(file: *mut file, a: ::c_long, b: ::caddr_t, c: ::c_long, d: ::c_long) -> ::c_int, pub fo_select: extern fn(file: *mut file, a: ::c_int, b: *mut ::c_ushort, c: extern fn()) -> ::c_int, pub fo_close: extern fn(file: *mut file) -> ::c_int, pub fo_fstat: extern fn(file: *mut file, sstat: *mut ::stat) -> ::c_int, } pub struct file { pub f_flag: ::c_long, pub f_count: ::c_int, pub f_options: ::c_short, pub f_type: ::c_short, // Should be pointer to 'vnode' pub f_data: *mut ::c_void, pub f_offset: ::c_longlong, pub f_dir_off: ::c_long, // Should be pointer to 'cred' pub f_cred: *mut ::c_void, #[cfg(libc_union)] pub f_lock: _kernel_simple_lock, #[cfg(libc_union)] pub f_offset_lock: _kernel_simple_lock, pub f_vinfo: ::caddr_t, pub f_ops: *mut fileops_t, pub f_parentp: ::caddr_t, pub f_fnamep: ::caddr_t, pub f_fdata: [::c_char; 160], } #[cfg(libc_union)] pub union __ld_info_file { pub _ldinfo_fd: ::c_int, pub _ldinfo_fp: *mut file, pub _core_offset: ::c_long, } pub struct ld_info { pub ldinfo_next: ::c_uint, pub ldinfo_flags: ::c_uint, #[cfg(libc_union)] pub _file: __ld_info_file, pub ldinfo_textorg: *mut ::c_void, pub ldinfo_textsize: ::c_ulong, pub ldinfo_dataorg: *mut ::c_void, pub ldinfo_datasize: ::c_ulong, pub ldinfo_filename: [::c_char; 2], } #[cfg(libc_union)] pub union __pollfd_ext_u { pub addr: *mut ::c_void, pub data32: u32, pub data: u64, } pub struct pollfd_ext { pub fd: ::c_int, pub events: ::c_ushort, pub revents: ::c_ushort, #[cfg(libc_union)] pub data: __pollfd_ext_u, } } impl siginfo_t { pub unsafe fn si_addr(&self) -> *mut ::c_void { self.si_addr } pub unsafe fn si_value(&self) -> ::sigval { self.si_value } pub unsafe fn si_pid(&self) -> ::pid_t { self.si_pid } pub unsafe fn si_uid(&self) -> ::uid_t { self.si_uid } pub unsafe fn si_status(&self) -> ::c_int { self.si_status } } cfg_if! { if #[cfg(feature = "extra_traits")] { impl PartialEq for siginfo_t { fn eq(&self, other: &siginfo_t) -> bool { #[cfg(libc_union)] let value_eq = self.si_value == other.si_value; #[cfg(not(libc_union))] let value_eq = true; self.si_signo == other.si_signo && self.si_errno == other.si_errno && self.si_code == other.si_code && self.si_pid == other.si_pid && self.si_uid == other.si_uid && self.si_status == other.si_status && self.si_addr == other.si_addr && self.si_band == other.si_band && self.__si_flags == other.__si_flags && value_eq } } impl Eq for siginfo_t {} impl ::fmt::Debug for siginfo_t { fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { let mut struct_formatter = f.debug_struct("siginfo_t"); struct_formatter.field("si_signo", &self.si_signo); struct_formatter.field("si_errno", &self.si_errno); struct_formatter.field("si_code", &self.si_code); struct_formatter.field("si_pid", &self.si_pid); struct_formatter.field("si_uid", &self.si_uid); struct_formatter.field("si_status", &self.si_status); struct_formatter.field("si_addr", &self.si_addr); struct_formatter.field("si_band", &self.si_band); #[cfg(libc_union)] struct_formatter.field("si_value", &self.si_value); struct_formatter.field("__si_flags", &self.__si_flags); struct_formatter.finish() } } impl ::hash::Hash for siginfo_t { fn hash(&self, state: &mut H) { self.si_signo.hash(state); self.si_errno.hash(state); self.si_code.hash(state); self.si_pid.hash(state); self.si_uid.hash(state); self.si_status.hash(state); self.si_addr.hash(state); self.si_band.hash(state); #[cfg(libc_union)] self.si_value.hash(state); self.__si_flags.hash(state); } } #[cfg(libc_union)] impl PartialEq for _kernel_simple_lock { fn eq(&self, other: &_kernel_simple_lock) -> bool { unsafe { self._slock == other._slock && self._slockp == other._slockp } } } #[cfg(libc_union)] impl Eq for _kernel_simple_lock {} #[cfg(libc_union)] impl ::fmt::Debug for _kernel_simple_lock { fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { f.debug_struct("_kernel_simple_lock") .field("_slock", unsafe { &self._slock }) .field("_slockp", unsafe { &self._slockp }) .finish() } } #[cfg(libc_union)] impl ::hash::Hash for _kernel_simple_lock { fn hash(&self, state: &mut H) { unsafe { self._slock.hash(state); self._slockp.hash(state); } } } impl PartialEq for fileops_t { fn eq(&self, other: &fileops_t) -> bool { self.fo_rw == other.fo_rw && self.fo_ioctl == other.fo_ioctl && self.fo_select == other.fo_select && self.fo_close == other.fo_close && self.fo_fstat == other.fo_fstat } } impl Eq for fileops_t {} impl ::fmt::Debug for fileops_t { fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { let mut struct_formatter = f.debug_struct("fileops_t"); struct_formatter.field("fo_rw", &self.fo_rw); struct_formatter.field("fo_ioctl", &self.fo_ioctl); struct_formatter.field("fo_select", &self.fo_select); struct_formatter.field("fo_close", &self.fo_close); struct_formatter.field("fo_fstat", &self.fo_fstat); struct_formatter.finish() } } impl ::hash::Hash for fileops_t { fn hash(&self, state: &mut H) { self.fo_rw.hash(state); self.fo_ioctl.hash(state); self.fo_select.hash(state); self.fo_close.hash(state); self.fo_fstat.hash(state); } } impl PartialEq for file { fn eq(&self, other: &file) -> bool { #[cfg(libc_union)] let lock_eq = self.f_lock == other.f_lock && self.f_offset_lock == other.f_offset_lock; #[cfg(not(libc_union))] let lock_eq = true; self.f_flag == other.f_flag && self.f_count == other.f_count && self.f_options == other.f_options && self.f_type == other.f_type && self.f_data == other.f_data && self.f_offset == other.f_offset && self.f_dir_off == other.f_dir_off && self.f_cred == other.f_cred && self.f_vinfo == other.f_vinfo && self.f_ops == other.f_ops && self.f_parentp == other.f_parentp && self.f_fnamep == other.f_fnamep && self.f_fdata == other.f_fdata && lock_eq } } impl Eq for file {} impl ::fmt::Debug for file { fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { let mut struct_formatter = f.debug_struct("file"); struct_formatter.field("f_flag", &self.f_flag); struct_formatter.field("f_count", &self.f_count); struct_formatter.field("f_options", &self.f_options); struct_formatter.field("f_type", &self.f_type); struct_formatter.field("f_data", &self.f_data); struct_formatter.field("f_offset", &self.f_offset); struct_formatter.field("f_dir_off", &self.f_dir_off); struct_formatter.field("f_cred", &self.f_cred); #[cfg(libc_union)] struct_formatter.field("f_lock", &self.f_lock); #[cfg(libc_union)] struct_formatter.field("f_offset_lock", &self.f_offset_lock); struct_formatter.field("f_vinfo", &self.f_vinfo); struct_formatter.field("f_ops", &self.f_ops); struct_formatter.field("f_parentp", &self.f_parentp); struct_formatter.field("f_fnamep", &self.f_fnamep); struct_formatter.field("f_fdata", &self.f_fdata); struct_formatter.finish() } } impl ::hash::Hash for file { fn hash(&self, state: &mut H) { self.f_flag.hash(state); self.f_count.hash(state); self.f_options.hash(state); self.f_type.hash(state); self.f_data.hash(state); self.f_offset.hash(state); self.f_dir_off.hash(state); self.f_cred.hash(state); #[cfg(libc_union)] self.f_lock.hash(state); #[cfg(libc_union)] self.f_offset_lock.hash(state); self.f_vinfo.hash(state); self.f_ops.hash(state); self.f_parentp.hash(state); self.f_fnamep.hash(state); self.f_fdata.hash(state); } } #[cfg(libc_union)] impl PartialEq for __ld_info_file { fn eq(&self, other: &__ld_info_file) -> bool { unsafe { self._ldinfo_fd == other._ldinfo_fd && self._ldinfo_fp == other._ldinfo_fp && self._core_offset == other._core_offset } } } #[cfg(libc_union)] impl Eq for __ld_info_file {} #[cfg(libc_union)] impl ::fmt::Debug for __ld_info_file { fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { f.debug_struct("__ld_info_file") .field("_ldinfo_fd", unsafe { &self._ldinfo_fd }) .field("_ldinfo_fp", unsafe { &self._ldinfo_fp }) .field("_core_offset", unsafe { &self._core_offset }) .finish() } } #[cfg(libc_union)] impl ::hash::Hash for __ld_info_file { fn hash(&self, state: &mut H) { unsafe { self._ldinfo_fd.hash(state); self._ldinfo_fp.hash(state); self._core_offset.hash(state); } } } impl PartialEq for ld_info { fn eq(&self, other: &ld_info) -> bool { #[cfg(libc_union)] let file_eq = self._file == other._file; #[cfg(not(libc_union))] let file_eq = true; self.ldinfo_next == other.ldinfo_next && self.ldinfo_flags == other.ldinfo_flags && self.ldinfo_textorg == other.ldinfo_textorg && self.ldinfo_textsize == other.ldinfo_textsize && self.ldinfo_dataorg == other.ldinfo_dataorg && self.ldinfo_datasize == other.ldinfo_datasize && self.ldinfo_filename == other.ldinfo_filename && file_eq } } impl Eq for ld_info {} impl ::fmt::Debug for ld_info { fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { let mut struct_formatter = f.debug_struct("ld_info"); struct_formatter.field("ldinfo_next", &self.ldinfo_next); struct_formatter.field("ldinfo_flags", &self.ldinfo_flags); struct_formatter.field("ldinfo_textorg", &self.ldinfo_textorg); struct_formatter.field("ldinfo_textsize", &self.ldinfo_textsize); struct_formatter.field("ldinfo_dataorg", &self.ldinfo_dataorg); struct_formatter.field("ldinfo_datasize", &self.ldinfo_datasize); struct_formatter.field("ldinfo_filename", &self.ldinfo_filename); #[cfg(libc_union)] struct_formatter.field("_file", &self._file); struct_formatter.finish() } } impl ::hash::Hash for ld_info { fn hash(&self, state: &mut H) { self.ldinfo_next.hash(state); self.ldinfo_flags.hash(state); self.ldinfo_textorg.hash(state); self.ldinfo_textsize.hash(state); self.ldinfo_dataorg.hash(state); self.ldinfo_datasize.hash(state); self.ldinfo_filename.hash(state); #[cfg(libc_union)] self._file.hash(state); } } #[cfg(libc_union)] impl PartialEq for __pollfd_ext_u { fn eq(&self, other: &__pollfd_ext_u) -> bool { unsafe { self.addr == other.addr && self.data32 == other.data32 && self.data == other.data } } } #[cfg(libc_union)] impl Eq for __pollfd_ext_u {} #[cfg(libc_union)] impl ::fmt::Debug for __pollfd_ext_u { fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { f.debug_struct("__pollfd_ext_u") .field("addr", unsafe { &self.addr }) .field("data32", unsafe { &self.data32 }) .field("data", unsafe { &self.data }) .finish() } } #[cfg(libc_union)] impl ::hash::Hash for __pollfd_ext_u { fn hash(&self, state: &mut H) { unsafe { self.addr.hash(state); self.data.hash(state); self.data32.hash(state); } } } impl PartialEq for pollfd_ext { fn eq(&self, other: &pollfd_ext) -> bool { #[cfg(libc_union)] let data_eq = self.data == other.data; #[cfg(not(libc_union))] let data_eq = true; self.fd == other.fd && self.events == other.events && self.revents == other.revents && data_eq } } impl Eq for pollfd_ext {} impl ::fmt::Debug for pollfd_ext { fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { let mut struct_formatter = f.debug_struct("pollfd_ext"); struct_formatter.field("fd", &self.fd); struct_formatter.field("events", &self.events); struct_formatter.field("revents", &self.revents); #[cfg(libc_union)] struct_formatter.field("data", &self.data); struct_formatter.finish() } } impl ::hash::Hash for pollfd_ext { fn hash(&self, state: &mut H) { self.fd.hash(state); self.events.hash(state); self.revents.hash(state); #[cfg(libc_union)] self.data.hash(state); } } } } pub const PTHREAD_MUTEX_INITIALIZER: pthread_mutex_t = pthread_mutex_t { __mt_word: [0, 2, 0, 0, 0, 0, 0, 0], }; pub const PTHREAD_COND_INITIALIZER: pthread_cond_t = pthread_cond_t { __cv_word: [0, 0, 0, 0, 2, 0], }; pub const PTHREAD_RWLOCK_INITIALIZER: pthread_rwlock_t = pthread_rwlock_t { __rw_word: [2, 0, 0, 0, 0, 0, 0, 0, 0, 0], }; pub const RLIM_INFINITY: ::c_ulong = 0x7fffffffffffffff; extern "C" { pub fn getsystemcfg(label: ::c_int) -> ::c_ulong; }