| use crate::off_t; |
| use crate::prelude::*; |
| |
| 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: crate::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: crate::fsblkcnt_t, |
| pub f_bfree: crate::fsblkcnt_t, |
| pub f_bavail: crate::fsblkcnt_t, |
| pub f_files: crate::fsfilcnt_t, |
| pub f_ffree: crate::fsfilcnt_t, |
| pub f_favail: crate::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: crate::dev_t, |
| pub st_ino: crate::ino_t, |
| pub st_mode: crate::mode_t, |
| pub st_nlink: crate::nlink_t, |
| pub st_flag: c_ushort, |
| pub st_uid: crate::uid_t, |
| pub st_gid: crate::gid_t, |
| pub st_rdev: crate::dev_t, |
| pub st_ssize: c_int, |
| pub st_atime: crate::st_timespec, |
| pub st_mtime: crate::st_timespec, |
| pub st_ctime: crate::st_timespec, |
| pub st_blksize: crate::blksize_t, |
| pub st_blocks: crate::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: crate::fsblkcnt_t, |
| pub f_bfree: crate::fsblkcnt_t, |
| pub f_bavail: crate::fsblkcnt_t, |
| pub f_files: crate::fsblkcnt_t, |
| pub f_ffree: crate::fsblkcnt_t, |
| pub f_fsid: crate::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: crate::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: crate::sigset_t, |
| pub __sc_uerror: c_int, |
| pub uc_mcontext: crate::mcontext_t, |
| pub uc_link: *mut ucontext_t, |
| pub uc_stack: crate::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: [crate::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: crate::pid_t, |
| pub ut_type: c_short, |
| pub ut_tv: crate::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: crate::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: crate::pid_t, |
| pub msg_lrpid: crate::pid_t, |
| pub msg_stime: crate::time_t, |
| pub msg_rtime: crate::time_t, |
| pub msg_ctime: crate::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: crate::pid_t, |
| pub si_uid: crate::uid_t, |
| pub si_status: c_int, |
| pub si_addr: *mut c_void, |
| pub si_band: c_long, |
| pub si_value: crate::sigval, |
| pub __si_flags: c_int, |
| pub __pad: [c_int; 3], |
| } |
| |
| 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 "C" fn( |
| file: *mut file, |
| rw: crate::uio_rw, |
| io: *mut c_void, |
| ext: c_long, |
| secattr: *mut c_void, |
| ) -> c_int, |
| pub fo_ioctl: extern "C" fn( |
| file: *mut file, |
| a: c_long, |
| b: crate::caddr_t, |
| c: c_long, |
| d: c_long, |
| ) -> c_int, |
| pub fo_select: |
| extern "C" fn(file: *mut file, a: c_int, b: *mut c_ushort, c: extern "C" fn()) -> c_int, |
| pub fo_close: extern "C" fn(file: *mut file) -> c_int, |
| pub fo_fstat: extern "C" fn(file: *mut file, sstat: *mut crate::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, |
| pub f_lock: _kernel_simple_lock, |
| pub f_offset_lock: _kernel_simple_lock, |
| pub f_vinfo: crate::caddr_t, |
| pub f_ops: *mut fileops_t, |
| pub f_parentp: crate::caddr_t, |
| pub f_fnamep: crate::caddr_t, |
| pub f_fdata: [c_char; 160], |
| } |
| |
| 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, |
| 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], |
| } |
| |
| 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, |
| 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) -> crate::sigval { |
| self.si_value |
| } |
| |
| pub unsafe fn si_pid(&self) -> crate::pid_t { |
| self.si_pid |
| } |
| |
| pub unsafe fn si_uid(&self) -> crate::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 { |
| 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 |
| && self.si_value == other.si_value |
| } |
| } |
| impl Eq for siginfo_t {} |
| impl fmt::Debug for siginfo_t { |
| fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { |
| f.debug_struct("siginfo_t") |
| .field("si_signo", &self.si_signo) |
| .field("si_errno", &self.si_errno) |
| .field("si_code", &self.si_code) |
| .field("si_pid", &self.si_pid) |
| .field("si_uid", &self.si_uid) |
| .field("si_status", &self.si_status) |
| .field("si_addr", &self.si_addr) |
| .field("si_band", &self.si_band) |
| .field("si_value", &self.si_value) |
| .field("__si_flags", &self.__si_flags) |
| .finish() |
| } |
| } |
| impl hash::Hash for siginfo_t { |
| fn hash<H: hash::Hasher>(&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); |
| self.si_value.hash(state); |
| self.__si_flags.hash(state); |
| } |
| } |
| |
| impl PartialEq for _kernel_simple_lock { |
| fn eq(&self, other: &_kernel_simple_lock) -> bool { |
| unsafe { self._slock == other._slock && self._slockp == other._slockp } |
| } |
| } |
| impl Eq for _kernel_simple_lock {} |
| impl hash::Hash for _kernel_simple_lock { |
| fn hash<H: hash::Hasher>(&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 { |
| f.debug_struct("fileops_t") |
| .field("fo_rw", &self.fo_rw) |
| .field("fo_ioctl", &self.fo_ioctl) |
| .field("fo_select", &self.fo_select) |
| .field("fo_close", &self.fo_close) |
| .field("fo_fstat", &self.fo_fstat) |
| .finish() |
| } |
| } |
| impl hash::Hash for fileops_t { |
| fn hash<H: hash::Hasher>(&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 { |
| 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 |
| && self.f_lock == other.f_lock |
| && self.f_offset_lock == other.f_offset_lock |
| } |
| } |
| impl Eq for file {} |
| impl fmt::Debug for file { |
| fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { |
| f.debug_struct("file") |
| .field("f_flag", &self.f_flag) |
| .field("f_count", &self.f_count) |
| .field("f_options", &self.f_options) |
| .field("f_type", &self.f_type) |
| .field("f_data", &self.f_data) |
| .field("f_offset", &self.f_offset) |
| .field("f_dir_off", &self.f_dir_off) |
| .field("f_cred", &self.f_cred) |
| .field("f_lock", &self.f_lock) |
| .field("f_offset_lock", &self.f_offset_lock) |
| .field("f_vinfo", &self.f_vinfo) |
| .field("f_ops", &self.f_ops) |
| .field("f_parentp", &self.f_parentp) |
| .field("f_fnamep", &self.f_fnamep) |
| .field("f_fdata", &self.f_fdata) |
| .finish() |
| } |
| } |
| impl hash::Hash for file { |
| fn hash<H: hash::Hasher>(&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); |
| self.f_lock.hash(state); |
| 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); |
| } |
| } |
| |
| 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 |
| } |
| } |
| } |
| impl Eq for __ld_info_file {} |
| impl hash::Hash for __ld_info_file { |
| fn hash<H: hash::Hasher>(&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 { |
| 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 |
| && self._file == other._file |
| } |
| } |
| impl Eq for ld_info {} |
| impl fmt::Debug for ld_info { |
| fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { |
| f.debug_struct("ld_info") |
| .field("ldinfo_next", &self.ldinfo_next) |
| .field("ldinfo_flags", &self.ldinfo_flags) |
| .field("ldinfo_textorg", &self.ldinfo_textorg) |
| .field("ldinfo_textsize", &self.ldinfo_textsize) |
| .field("ldinfo_dataorg", &self.ldinfo_dataorg) |
| .field("ldinfo_datasize", &self.ldinfo_datasize) |
| .field("ldinfo_filename", &self.ldinfo_filename) |
| .field("_file", &self._file) |
| .finish() |
| } |
| } |
| impl hash::Hash for ld_info { |
| fn hash<H: hash::Hasher>(&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); |
| self._file.hash(state); |
| } |
| } |
| |
| 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 |
| } |
| } |
| } |
| impl Eq for __pollfd_ext_u {} |
| impl hash::Hash for __pollfd_ext_u { |
| fn hash<H: hash::Hasher>(&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 { |
| self.fd == other.fd |
| && self.events == other.events |
| && self.revents == other.revents |
| && self.data == other.data |
| } |
| } |
| impl Eq for pollfd_ext {} |
| impl fmt::Debug for pollfd_ext { |
| fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { |
| f.debug_struct("pollfd_ext") |
| .field("fd", &self.fd) |
| .field("events", &self.events) |
| .field("revents", &self.revents) |
| .field("data", &self.data) |
| .finish() |
| } |
| } |
| impl hash::Hash for pollfd_ext { |
| fn hash<H: hash::Hasher>(&self, state: &mut H) { |
| self.fd.hash(state); |
| self.events.hash(state); |
| self.revents.hash(state); |
| 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; |
| } |