diff options
Diffstat (limited to 'libc/src/unix')
85 files changed, 8284 insertions, 1939 deletions
| diff --git a/libc/src/unix/align.rs b/libc/src/unix/align.rs new file mode 100644 index 0000000..4fdba9a --- /dev/null +++ b/libc/src/unix/align.rs @@ -0,0 +1,6 @@ +s! { +    #[repr(align(4))] +    pub struct in6_addr { +        pub s6_addr: [u8; 16], +    } +} diff --git a/libc/src/unix/bsd/apple/b32.rs b/libc/src/unix/bsd/apple/b32.rs index 907ab02..13b1a0b 100644 --- a/libc/src/unix/bsd/apple/b32.rs +++ b/libc/src/unix/bsd/apple/b32.rs @@ -5,11 +5,6 @@ pub type c_ulong = u32;  pub type boolean_t = ::c_int;  s! { -    pub struct pthread_attr_t { -        __sig: c_long, -        __opaque: [::c_char; 36] -    } -      pub struct if_data {          pub ifi_type: ::c_uchar,          pub ifi_typelen: ::c_uchar, @@ -50,6 +45,42 @@ s! {      }  } +s_no_extra_traits!{ +    pub struct pthread_attr_t { +        __sig: c_long, +        __opaque: [::c_char; 36] +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for pthread_attr_t { +            fn eq(&self, other: &pthread_attr_t) -> bool { +                self.__sig == other.__sig +                    && self.__opaque +                    .iter() +                    .zip(other.__opaque.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for pthread_attr_t {} +        impl ::fmt::Debug for pthread_attr_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_attr_t") +                    .field("__sig", &self.__sig) +                // FIXME: .field("__opaque", &self.__opaque) +                    .finish() +            } +        } +        impl ::hash::Hash for pthread_attr_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.__sig.hash(state); +                self.__opaque.hash(state); +            } +        } +    } +} +  pub const __PTHREAD_MUTEX_SIZE__: usize = 40;  pub const __PTHREAD_COND_SIZE__: usize = 24;  pub const __PTHREAD_CONDATTR_SIZE__: usize = 4; diff --git a/libc/src/unix/bsd/apple/b64.rs b/libc/src/unix/bsd/apple/b64.rs index 8e8c87d..50b48fa 100644 --- a/libc/src/unix/bsd/apple/b64.rs +++ b/libc/src/unix/bsd/apple/b64.rs @@ -5,11 +5,6 @@ pub type c_ulong = u64;  pub type boolean_t = ::c_uint;  s! { -    pub struct pthread_attr_t { -        __sig: c_long, -        __opaque: [::c_char; 56] -    } -      pub struct timeval32 {          pub tv_sec: i32,          pub tv_usec: i32, @@ -55,6 +50,42 @@ s! {      }  } +s_no_extra_traits!{ +    pub struct pthread_attr_t { +        __sig: c_long, +        __opaque: [::c_char; 56] +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for pthread_attr_t { +            fn eq(&self, other: &pthread_attr_t) -> bool { +                self.__sig == other.__sig +                    && self.__opaque +                    .iter() +                    .zip(other.__opaque.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for pthread_attr_t {} +        impl ::fmt::Debug for pthread_attr_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_attr_t") +                    .field("__sig", &self.__sig) +                // FIXME: .field("__opaque", &self.__opaque) +                    .finish() +            } +        } +        impl ::hash::Hash for pthread_attr_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.__sig.hash(state); +                self.__opaque.hash(state); +            } +        } +    } +} +  pub const __PTHREAD_MUTEX_SIZE__: usize = 56;  pub const __PTHREAD_COND_SIZE__: usize = 40;  pub const __PTHREAD_CONDATTR_SIZE__: usize = 8; diff --git a/libc/src/unix/bsd/apple/mod.rs b/libc/src/unix/bsd/apple/mod.rs index 837efff..9483e90 100644 --- a/libc/src/unix/bsd/apple/mod.rs +++ b/libc/src/unix/bsd/apple/mod.rs @@ -1,8 +1,6 @@  //! Apple (ios/darwin)-specific definitions  //!  //! This covers *-apple-* triples currently -use dox::mem; -  pub type c_char = i8;  pub type clock_t = c_ulong;  pub type time_t = c_long; @@ -33,10 +31,21 @@ pub type posix_spawnattr_t = *mut ::c_void;  pub type posix_spawn_file_actions_t = *mut ::c_void;  pub type key_t = ::c_int;  pub type shmatt_t = ::c_ushort; +pub type vm_size_t = ::uintptr_t; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum timezone {} +impl ::Copy for timezone {} +impl ::Clone for timezone { +    fn clone(&self) -> timezone { *self } +}  s! { +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } +      pub struct aiocb {          pub aio_fildes: ::c_int,          pub aio_offset: ::off_t, @@ -47,17 +56,6 @@ s! {          pub aio_lio_opcode: ::c_int      } -    pub struct utmpx { -        pub ut_user: [::c_char; _UTX_USERSIZE], -        pub ut_id: [::c_char; _UTX_IDSIZE], -        pub ut_line: [::c_char; _UTX_LINESIZE], -        pub ut_pid: ::pid_t, -        pub ut_type: ::c_short, -        pub ut_tv: ::timeval, -        pub ut_host: [::c_char; _UTX_HOSTSIZE], -        ut_pad: [::uint32_t; 16], -    } -      pub struct glob_t {          pub gl_pathc:  ::size_t,          __unused1: ::c_int, @@ -74,14 +72,6 @@ s! {          __unused8: *mut ::c_void,      } -    pub struct sockaddr_storage { -        pub ss_len: u8, -        pub ss_family: ::sa_family_t, -        __ss_pad1: [u8; 6], -        __ss_align: i64, -        __ss_pad2: [u8; 112], -    } -      pub struct addrinfo {          pub ai_flags: ::c_int,          pub ai_family: ::c_int, @@ -123,40 +113,16 @@ s! {          pub st_qspare: [::int64_t; 2],      } -    pub struct dirent { -        pub d_ino: u64, -        pub d_seekoff: u64, -        pub d_reclen: u16, -        pub d_namlen: u16, -        pub d_type: u8, -        pub d_name: [::c_char; 1024], -    } - -    pub struct pthread_mutex_t { -        __sig: ::c_long, -        __opaque: [u8; __PTHREAD_MUTEX_SIZE__], -    } -      pub struct pthread_mutexattr_t {          __sig: ::c_long,          __opaque: [u8; 8],      } -    pub struct pthread_cond_t { -        __sig: ::c_long, -        __opaque: [u8; __PTHREAD_COND_SIZE__], -    } -      pub struct pthread_condattr_t {          __sig: ::c_long,          __opaque: [u8; __PTHREAD_CONDATTR_SIZE__],      } -    pub struct pthread_rwlock_t { -        __sig: ::c_long, -        __opaque: [u8; __PTHREAD_RWLOCK_SIZE__], -    } -      pub struct pthread_rwlockattr_t {          __sig: ::c_long,          __opaque: [u8; __PTHREAD_RWLOCKATTR_SIZE__], @@ -174,6 +140,7 @@ s! {      }      pub struct sigaction { +        // FIXME: this field is actually a union          pub sa_sigaction: ::sighandler_t,          pub sa_mask: sigset_t,          pub sa_flags: ::c_int, @@ -227,35 +194,6 @@ s! {          pub sin_zero: [::c_char; 8],      } -    pub struct statfs { -        pub f_bsize: ::uint32_t, -        pub f_iosize: ::int32_t, -        pub f_blocks: ::uint64_t, -        pub f_bfree: ::uint64_t, -        pub f_bavail: ::uint64_t, -        pub f_files: ::uint64_t, -        pub f_ffree: ::uint64_t, -        pub f_fsid: ::fsid_t, -        pub f_owner: ::uid_t, -        pub f_type: ::uint32_t, -        pub f_flags: ::uint32_t, -        pub f_fssubtype: ::uint32_t, -        pub f_fstypename: [::c_char; 16], -        pub f_mntonname: [::c_char; 1024], -        pub f_mntfromname: [::c_char; 1024], -        pub f_reserved: [::uint32_t; 8], -    } - -    #[cfg_attr(feature = "rustc-dep-of-std", repr(packed(4)))] -    pub struct kevent { -        pub ident: ::uintptr_t, -        pub filter: ::int16_t, -        pub flags: ::uint16_t, -        pub fflags: ::uint32_t, -        pub data: ::intptr_t, -        pub udata: *mut ::c_void, -    } -      pub struct kevent64_s {          pub ident: ::uint64_t,          pub filter: ::int16_t, @@ -400,20 +338,6 @@ s! {          pub ptinfo: proc_taskinfo,      } -    pub struct proc_threadinfo { -        pub pth_user_time: u64, -        pub pth_system_time: u64, -        pub pth_cpu_usage: i32, -        pub pth_policy: i32, -        pub pth_run_state: i32, -        pub pth_flags: i32, -        pub pth_sleep_time: i32, -        pub pth_curpri: i32, -        pub pth_priority: i32, -        pub pth_maxpriority: i32, -        pub pth_name: [::c_char; MAXTHREADNAMESIZE], -    } -      pub struct xsw_usage {          pub xsu_total: u64,          pub xsu_avail: u64, @@ -544,7 +468,33 @@ s! {          pub sem_flg: ::c_short,      } -    #[cfg_attr(feature = "rustc-dep-of-std", repr(packed(4)))] +    // sys/shm.h + +    pub struct arphdr { +        pub ar_hrd: u16, +        pub ar_pro: u16, +        pub ar_hln: u8, +        pub ar_pln: u8, +        pub ar_op: u16, +    } + +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } +} + +s_no_extra_traits!{ +    #[cfg_attr(libc_packedN, repr(packed(4)))] +    pub struct kevent { +        pub ident: ::uintptr_t, +        pub filter: ::int16_t, +        pub flags: ::uint16_t, +        pub fflags: ::uint32_t, +        pub data: ::intptr_t, +        pub udata: *mut ::c_void, +    } + +    #[cfg_attr(libc_packedN, repr(packed(4)))]      pub struct semid_ds {          // Note the manpage shows different types than the system header.          pub sem_perm: ipc_perm, @@ -557,15 +507,7 @@ s! {          pub sem_pad3: [::int32_t; 4],      } -    pub union semun { -        pub val: ::c_int, -        pub buf: *mut semid_ds, -        pub array: *mut ::c_ushort, -    } - -    // sys/shm.h - -    #[cfg_attr(feature = "rustc-dep-of-std", repr(packed(4)))] +    #[cfg_attr(libc_packedN, repr(packed(4)))]      pub struct shmid_ds {          pub shm_perm: ipc_perm,          pub shm_segsz: ::size_t, @@ -577,15 +519,630 @@ s! {          pub shm_ctime: ::time_t,  // FIXME: 64-bit wrong align => wrong offset          // FIXME: 64-bit wrong align => wrong offset:          pub shm_internal: *mut ::c_void, +    } +    pub struct proc_threadinfo { +        pub pth_user_time: u64, +        pub pth_system_time: u64, +        pub pth_cpu_usage: i32, +        pub pth_policy: i32, +        pub pth_run_state: i32, +        pub pth_flags: i32, +        pub pth_sleep_time: i32, +        pub pth_curpri: i32, +        pub pth_priority: i32, +        pub pth_maxpriority: i32, +        pub pth_name: [::c_char; MAXTHREADNAMESIZE],      } -    pub struct arphdr { -        pub ar_hrd: u16, -        pub ar_pro: u16, -        pub ar_hln: u8, -        pub ar_pln: u8, -        pub ar_op: u16, +    pub struct statfs { +        pub f_bsize: ::uint32_t, +        pub f_iosize: ::int32_t, +        pub f_blocks: ::uint64_t, +        pub f_bfree: ::uint64_t, +        pub f_bavail: ::uint64_t, +        pub f_files: ::uint64_t, +        pub f_ffree: ::uint64_t, +        pub f_fsid: ::fsid_t, +        pub f_owner: ::uid_t, +        pub f_type: ::uint32_t, +        pub f_flags: ::uint32_t, +        pub f_fssubtype: ::uint32_t, +        pub f_fstypename: [::c_char; 16], +        pub f_mntonname: [::c_char; 1024], +        pub f_mntfromname: [::c_char; 1024], +        pub f_reserved: [::uint32_t; 8], +    } + +    pub struct dirent { +        pub d_ino: u64, +        pub d_seekoff: u64, +        pub d_reclen: u16, +        pub d_namlen: u16, +        pub d_type: u8, +        pub d_name: [::c_char; 1024], +    } + +    pub struct pthread_rwlock_t { +        __sig: ::c_long, +        __opaque: [u8; __PTHREAD_RWLOCK_SIZE__], +    } + +    pub struct pthread_mutex_t { +        __sig: ::c_long, +        __opaque: [u8; __PTHREAD_MUTEX_SIZE__], +    } + +    pub struct pthread_cond_t { +        __sig: ::c_long, +        __opaque: [u8; __PTHREAD_COND_SIZE__], +    } + +    pub struct sockaddr_storage { +        pub ss_len: u8, +        pub ss_family: ::sa_family_t, +        __ss_pad1: [u8; 6], +        __ss_align: i64, +        __ss_pad2: [u8; 112], +    } + +    pub struct utmpx { +        pub ut_user: [::c_char; _UTX_USERSIZE], +        pub ut_id: [::c_char; _UTX_IDSIZE], +        pub ut_line: [::c_char; _UTX_LINESIZE], +        pub ut_pid: ::pid_t, +        pub ut_type: ::c_short, +        pub ut_tv: ::timeval, +        pub ut_host: [::c_char; _UTX_HOSTSIZE], +        ut_pad: [::uint32_t; 16], +    } +} + +cfg_if! { +    if #[cfg(libc_union)] { +        s_no_extra_traits! { +            pub union semun { +                pub val: ::c_int, +                pub buf: *mut semid_ds, +                pub array: *mut ::c_ushort, +            } +        } + +        cfg_if! { +            if #[cfg(feature = "extra_traits")] { +                impl PartialEq for semun { +                    fn eq(&self, other: &semun) -> bool { +                        unsafe { self.val == other.val } +                    } +                } +                impl Eq for semun {} +                impl ::fmt::Debug for semun { +                    fn fmt(&self, f: &mut ::fmt::Formatter) +                           -> ::fmt::Result { +                        f.debug_struct("semun") +                            .field("val", unsafe { &self.val }) +                            .finish() +                    } +                } +                impl ::hash::Hash for semun { +                    fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                        unsafe { self.val.hash(state) }; +                    } +                } +            } +        } +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for kevent { +            fn eq(&self, other: &kevent) -> bool { +                self.ident == other.ident +                    && self.filter == other.filter +                    && self.flags == other.flags +                    && self.fflags == other.fflags +                    && self.data == other.data +                    && self.udata == other.udata +            } +        } +        impl Eq for kevent {} +        impl ::fmt::Debug for kevent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                let ident = self.ident; +                let filter = self.filter; +                let flags = self.flags; +                let fflags = self.fflags; +                let data = self.data; +                let udata = self.udata; +                f.debug_struct("kevent") +                    .field("ident", &ident) +                    .field("filter", &filter) +                    .field("flags", &flags) +                    .field("fflags", &fflags) +                    .field("data", &data) +                    .field("udata", &udata) +                    .finish() +            } +        } +        impl ::hash::Hash for kevent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                let ident = self.ident; +                let filter = self.filter; +                let flags = self.flags; +                let fflags = self.fflags; +                let data = self.data; +                let udata = self.udata; +                ident.hash(state); +                filter.hash(state); +                flags.hash(state); +                fflags.hash(state); +                data.hash(state); +                udata.hash(state); +            } +        } + +        impl PartialEq for semid_ds { +            fn eq(&self, other: &semid_ds) -> bool { +                let sem_perm = self.sem_perm; +                let sem_pad3 = self.sem_pad3; +                let other_sem_perm = other.sem_perm; +                let other_sem_pad3 = other.sem_pad3; +                sem_perm == other_sem_perm +                    && self.sem_base == other.sem_base +                    && self.sem_nsems == other.sem_nsems +                    && self.sem_otime == other.sem_otime +                    && self.sem_pad1 == other.sem_pad1 +                    && self.sem_ctime == other.sem_ctime +                    && self.sem_pad2 == other.sem_pad2 +                    && sem_pad3 == other_sem_pad3 +            } +        } +        impl Eq for semid_ds {} +        impl ::fmt::Debug for semid_ds { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                let sem_perm = self.sem_perm; +                let sem_base = self.sem_base; +                let sem_nsems = self.sem_nsems; +                let sem_otime = self.sem_otime; +                let sem_pad1 = self.sem_pad1; +                let sem_ctime = self.sem_ctime; +                let sem_pad2 = self.sem_pad2; +                let sem_pad3 = self.sem_pad3; +                f.debug_struct("semid_ds") +                    .field("sem_perm", &sem_perm) +                    .field("sem_base", &sem_base) +                    .field("sem_nsems", &sem_nsems) +                    .field("sem_otime", &sem_otime) +                    .field("sem_pad1", &sem_pad1) +                    .field("sem_ctime", &sem_ctime) +                    .field("sem_pad2", &sem_pad2) +                    .field("sem_pad3", &sem_pad3) +                    .finish() +            } +        } +        impl ::hash::Hash for semid_ds { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                let sem_perm = self.sem_perm; +                let sem_base = self.sem_base; +                let sem_nsems = self.sem_nsems; +                let sem_otime = self.sem_otime; +                let sem_pad1 = self.sem_pad1; +                let sem_ctime = self.sem_ctime; +                let sem_pad2 = self.sem_pad2; +                let sem_pad3 = self.sem_pad3; +                sem_perm.hash(state); +                sem_base.hash(state); +                sem_nsems.hash(state); +                sem_otime.hash(state); +                sem_pad1.hash(state); +                sem_ctime.hash(state); +                sem_pad2.hash(state); +                sem_pad3.hash(state); +            } +        } + +        impl PartialEq for shmid_ds { +            fn eq(&self, other: &shmid_ds) -> bool { +                let shm_perm = self.shm_perm; +                let other_shm_perm = other.shm_perm; +                shm_perm == other_shm_perm +                    && self.shm_segsz == other.shm_segsz +                    && self.shm_lpid == other.shm_lpid +                    && self.shm_cpid == other.shm_cpid +                    && self.shm_nattch == other.shm_nattch +                    && self.shm_atime == other.shm_atime +                    && self.shm_dtime == other.shm_dtime +                    && self.shm_ctime == other.shm_ctime +                    && self.shm_internal == other.shm_internal +            } +        } +        impl Eq for shmid_ds {} +        impl ::fmt::Debug for shmid_ds { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                let shm_perm = self.shm_perm; +                let shm_segsz = self.shm_segsz; +                let shm_lpid = self.shm_lpid; +                let shm_cpid = self.shm_cpid; +                let shm_nattch = self.shm_nattch; +                let shm_atime = self.shm_atime; +                let shm_dtime = self.shm_dtime; +                let shm_ctime = self.shm_ctime; +                let shm_internal = self.shm_internal; +                f.debug_struct("shmid_ds") +                    .field("shm_perm", &shm_perm) +                    .field("shm_segsz", &shm_segsz) +                    .field("shm_lpid", &shm_lpid) +                    .field("shm_cpid", &shm_cpid) +                    .field("shm_nattch", &shm_nattch) +                    .field("shm_atime", &shm_atime) +                    .field("shm_dtime", &shm_dtime) +                    .field("shm_ctime", &shm_ctime) +                    .field("shm_internal", &shm_internal) +                    .finish() +            } +        } +        impl ::hash::Hash for shmid_ds { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                let shm_perm = self.shm_perm; +                let shm_segsz = self.shm_segsz; +                let shm_lpid = self.shm_lpid; +                let shm_cpid = self.shm_cpid; +                let shm_nattch = self.shm_nattch; +                let shm_atime = self.shm_atime; +                let shm_dtime = self.shm_dtime; +                let shm_ctime = self.shm_ctime; +                let shm_internal = self.shm_internal; +                shm_perm.hash(state); +                shm_segsz.hash(state); +                shm_lpid.hash(state); +                shm_cpid.hash(state); +                shm_nattch.hash(state); +                shm_atime.hash(state); +                shm_dtime.hash(state); +                shm_ctime.hash(state); +                shm_internal.hash(state); +            } +        } + +        impl PartialEq for proc_threadinfo { +            fn eq(&self, other: &proc_threadinfo) -> bool { +                self.pth_user_time == other.pth_user_time +                    && self.pth_system_time == other.pth_system_time +                    && self.pth_cpu_usage == other.pth_cpu_usage +                    && self.pth_policy == other.pth_policy +                    && self.pth_run_state == other.pth_run_state +                    && self.pth_flags == other.pth_flags +                    && self.pth_sleep_time == other.pth_sleep_time +                    && self.pth_curpri == other.pth_curpri +                    && self.pth_priority == other.pth_priority +                    && self.pth_maxpriority == other.pth_maxpriority +                    && self.pth_name +                           .iter() +                           .zip(other.pth_name.iter()) +                           .all(|(a,b)| a == b) +            } +        } +        impl Eq for proc_threadinfo {} +        impl ::fmt::Debug for proc_threadinfo { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("proc_threadinfo") +                    .field("pth_user_time", &self.pth_user_time) +                    .field("pth_system_time", &self.pth_system_time) +                    .field("pth_cpu_usage", &self.pth_cpu_usage) +                    .field("pth_policy", &self.pth_policy) +                    .field("pth_run_state", &self.pth_run_state) +                    .field("pth_flags", &self.pth_flags) +                    .field("pth_sleep_time", &self.pth_sleep_time) +                    .field("pth_curpri", &self.pth_curpri) +                    .field("pth_priority", &self.pth_priority) +                    .field("pth_maxpriority", &self.pth_maxpriority) +                      // FIXME: .field("pth_name", &self.pth_name) +                    .finish() +            } +        } +        impl ::hash::Hash for proc_threadinfo { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.pth_user_time.hash(state); +                self.pth_system_time.hash(state); +                self.pth_cpu_usage.hash(state); +                self.pth_policy.hash(state); +                self.pth_run_state.hash(state); +                self.pth_flags.hash(state); +                self.pth_sleep_time.hash(state); +                self.pth_curpri.hash(state); +                self.pth_priority.hash(state); +                self.pth_maxpriority.hash(state); +                self.pth_name.hash(state); +            } +        } + +        impl PartialEq for statfs { +            fn eq(&self, other: &statfs) -> bool { +                self.f_bsize == other.f_bsize +                    && self.f_iosize == other.f_iosize +                    && self.f_blocks == other.f_blocks +                    && self.f_bfree == other.f_bfree +                    && self.f_bavail == other.f_bavail +                    && self.f_files == other.f_files +                    && self.f_ffree == other.f_ffree +                    && self.f_fsid == other.f_fsid +                    && self.f_owner == other.f_owner +                    && self.f_flags == other.f_flags +                    && self.f_fssubtype == other.f_fssubtype +                    && self.f_fstypename == other.f_fstypename +                    && self.f_type == other.f_type +                    && self +                    .f_mntonname +                    .iter() +                    .zip(other.f_mntonname.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .f_mntfromname +                    .iter() +                    .zip(other.f_mntfromname.iter()) +                    .all(|(a,b)| a == b) +                    && self.f_reserved == other.f_reserved +            } +        } + +        impl Eq for statfs {} +        impl ::fmt::Debug for statfs { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("statfs") +                    .field("f_bsize", &self.f_bsize) +                    .field("f_iosize", &self.f_iosize) +                    .field("f_blocks", &self.f_blocks) +                    .field("f_bfree", &self.f_bfree) +                    .field("f_bavail", &self.f_bavail) +                    .field("f_files", &self.f_files) +                    .field("f_ffree", &self.f_ffree) +                    .field("f_fsid", &self.f_fsid) +                    .field("f_owner", &self.f_owner) +                    .field("f_flags", &self.f_flags) +                    .field("f_fssubtype", &self.f_fssubtype) +                    .field("f_fstypename", &self.f_fstypename) +                    .field("f_type", &self.f_type) +                // FIXME: .field("f_mntonname", &self.f_mntonname) +                // FIXME: .field("f_mntfromname", &self.f_mntfromname) +                    .field("f_reserved", &self.f_reserved) +                    .finish() +            } +        } + +        impl ::hash::Hash for statfs { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.f_bsize.hash(state); +                self.f_iosize.hash(state); +                self.f_blocks.hash(state); +                self.f_bfree.hash(state); +                self.f_bavail.hash(state); +                self.f_files.hash(state); +                self.f_ffree.hash(state); +                self.f_fsid.hash(state); +                self.f_owner.hash(state); +                self.f_flags.hash(state); +                self.f_fssubtype.hash(state); +                self.f_fstypename.hash(state); +                self.f_type.hash(state); +                self.f_mntonname.hash(state); +                self.f_mntfromname.hash(state); +                self.f_reserved.hash(state); +            } +        } + +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_ino == other.d_ino +                    && self.d_seekoff == other.d_seekoff +                    && self.d_reclen == other.d_reclen +                    && self.d_namlen == other.d_namlen +                    && self.d_type == other.d_type +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for dirent {} +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_ino", &self.d_ino) +                    .field("d_seekoff", &self.d_seekoff) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_namlen", &self.d_namlen) +                    .field("d_type", &self.d_type) +                    // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_ino.hash(state); +                self.d_seekoff.hash(state); +                self.d_reclen.hash(state); +                self.d_namlen.hash(state); +                self.d_type.hash(state); +                self.d_name.hash(state); +            } +        } +        impl PartialEq for pthread_rwlock_t { +            fn eq(&self, other: &pthread_rwlock_t) -> bool { +                self.__sig == other.__sig +                    && self. +                    __opaque +                    .iter() +                    .zip(other.__opaque.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for pthread_rwlock_t {} +        impl ::fmt::Debug for pthread_rwlock_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_rwlock_t") +                    .field("__sig", &self.__sig) +                    // FIXME: .field("__opaque", &self.__opaque) +                    .finish() +            } +        } +        impl ::hash::Hash for pthread_rwlock_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.__sig.hash(state); +                self.__opaque.hash(state); +            } +        } + +        impl PartialEq for pthread_mutex_t { +            fn eq(&self, other: &pthread_mutex_t) -> bool { +                self.__sig == other.__sig +                    && self. +                    __opaque +                    .iter() +                    .zip(other.__opaque.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for pthread_mutex_t {} + +        impl ::fmt::Debug for pthread_mutex_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_mutex_t") +                    .field("__sig", &self.__sig) +                    // FIXME: .field("__opaque", &self.__opaque) +                    .finish() +            } +        } + +        impl ::hash::Hash for pthread_mutex_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.__sig.hash(state); +                self.__opaque.hash(state); +            } +        } + +        impl PartialEq for pthread_cond_t { +            fn eq(&self, other: &pthread_cond_t) -> bool { +                self.__sig == other.__sig +                    && self. +                    __opaque +                    .iter() +                    .zip(other.__opaque.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for pthread_cond_t {} + +        impl ::fmt::Debug for pthread_cond_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_cond_t") +                    .field("__sig", &self.__sig) +                    // FIXME: .field("__opaque", &self.__opaque) +                    .finish() +            } +        } + +        impl ::hash::Hash for pthread_cond_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.__sig.hash(state); +                self.__opaque.hash(state); +            } +        } + +        impl PartialEq for sockaddr_storage { +            fn eq(&self, other: &sockaddr_storage) -> bool { +                self.ss_len == other.ss_len +                    && self.ss_family == other.ss_family +                    && self +                    .__ss_pad1 +                    .iter() +                    .zip(other.__ss_pad1.iter()) +                    .all(|(a, b)| a == b) +                    && self.__ss_align == other.__ss_align +                    && self +                    .__ss_pad2 +                    .iter() +                    .zip(other.__ss_pad2.iter()) +                    .all(|(a, b)| a == b) +            } +        } + +        impl Eq for sockaddr_storage {} + +        impl ::fmt::Debug for sockaddr_storage { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_storage") +                    .field("ss_len", &self.ss_len) +                    .field("ss_family", &self.ss_family) +                    .field("__ss_pad1", &self.__ss_pad1) +                    .field("__ss_align", &self.__ss_align) +                    // FIXME: .field("__ss_pad2", &self.__ss_pad2) +                    .finish() +            } +        } + +        impl ::hash::Hash for sockaddr_storage { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ss_len.hash(state); +                self.ss_family.hash(state); +                self.__ss_pad1.hash(state); +                self.__ss_align.hash(state); +                self.__ss_pad2.hash(state); +            } +        } + +        impl PartialEq for utmpx { +            fn eq(&self, other: &utmpx) -> bool { +                self.ut_user +                    .iter() +                    .zip(other.ut_user.iter()) +                    .all(|(a,b)| a == b) +                    && self.ut_id == other.ut_id +                    && self.ut_line == other.ut_line +                    && self.ut_pid == other.ut_pid +                    && self.ut_type == other.ut_type +                    && self.ut_tv == other.ut_tv +                    && self +                    .ut_host +                    .iter() +                    .zip(other.ut_host.iter()) +                    .all(|(a,b)| a == b) +                    && self.ut_pad == other.ut_pad +            } +        } + +        impl Eq for utmpx {} + +        impl ::fmt::Debug for utmpx { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utmpx") +                    // FIXME: .field("ut_user", &self.ut_user) +                    .field("ut_id", &self.ut_id) +                    .field("ut_line", &self.ut_line) +                    .field("ut_pid", &self.ut_pid) +                    .field("ut_type", &self.ut_type) +                    .field("ut_tv", &self.ut_tv) +                    // FIXME: .field("ut_host", &self.ut_host) +                    .field("ut_pad", &self.ut_pad) +                    .finish() +            } +        } + +        impl ::hash::Hash for utmpx { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ut_user.hash(state); +                self.ut_id.hash(state); +                self.ut_line.hash(state); +                self.ut_pid.hash(state); +                self.ut_type.hash(state); +                self.ut_tv.hash(state); +                self.ut_host.hash(state); +                self.ut_pad.hash(state); +            } +        }      }  } @@ -1862,12 +2419,14 @@ pub const NOTE_NONE: ::uint32_t = 0x00000080;  pub const NOTE_EXIT: ::uint32_t = 0x80000000;  pub const NOTE_FORK: ::uint32_t = 0x40000000;  pub const NOTE_EXEC: ::uint32_t = 0x20000000; +#[deprecated(since="0.2.49", note="Deprecated since MacOSX 10.9")]  pub const NOTE_REAP: ::uint32_t = 0x10000000;  pub const NOTE_SIGNAL: ::uint32_t = 0x08000000;  pub const NOTE_EXITSTATUS: ::uint32_t = 0x04000000;  pub const NOTE_EXIT_DETAIL: ::uint32_t = 0x02000000;  pub const NOTE_PDATAMASK: ::uint32_t = 0x000fffff;  pub const NOTE_PCTRLMASK: ::uint32_t = 0xfff00000; +#[deprecated(since="0.2.49", note="Deprecated since MacOSX 10.9")]  pub const NOTE_EXIT_REPARENTED: ::uint32_t = 0x00080000;  pub const NOTE_EXIT_DETAIL_MASK: ::uint32_t = 0x00070000;  pub const NOTE_EXIT_DECRYPTFAIL: ::uint32_t = 0x00010000; @@ -2073,7 +2632,9 @@ pub const KERN_KDSETRTCDEC: ::c_int = 15;  pub const KERN_KDGETENTROPY: ::c_int = 16;  pub const KERN_KDWRITETR: ::c_int = 17;  pub const KERN_KDWRITEMAP: ::c_int = 18; +#[deprecated(since = "0.2.49", note ="Removed in MacOSX 10.12")]  pub const KERN_KDENABLE_BG_TRACE: ::c_int = 19; +#[deprecated(since = "0.2.49", note ="Removed in MacOSX 10.12")]  pub const KERN_KDDISABLE_BG_TRACE: ::c_int = 20;  pub const KERN_KDREADCURTHRMAP: ::c_int = 21;  pub const KERN_KDSET_TYPEFILTER: ::c_int = 22; @@ -2384,9 +2945,18 @@ pub const SF_IMMUTABLE:     ::c_uint = 0x00020000;  pub const SF_APPEND:        ::c_uint = 0x00040000;  pub const UF_HIDDEN:        ::c_uint = 0x00008000; -fn __DARWIN_ALIGN32(p: usize) -> usize { -    const __DARWIN_ALIGNBYTES32: usize = mem::size_of::<u32>() - 1; -    p + __DARWIN_ALIGNBYTES32 & !__DARWIN_ALIGNBYTES32 +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        fn __DARWIN_ALIGN32(p: usize) -> usize { +            const __DARWIN_ALIGNBYTES32: usize = ::mem::size_of::<u32>() - 1; +            p + __DARWIN_ALIGNBYTES32 & !__DARWIN_ALIGNBYTES32 +        } +    } else { +        fn __DARWIN_ALIGN32(p: usize) -> usize { +            let __DARWIN_ALIGNBYTES32: usize = ::mem::size_of::<u32>() - 1; +            p + __DARWIN_ALIGNBYTES32 & !__DARWIN_ALIGNBYTES32 +        } +    }  }  f! { @@ -2396,11 +2966,10 @@ f! {              return ::CMSG_FIRSTHDR(mhdr);          };          let cmsg_len = (*cmsg).cmsg_len as usize; -        let next = cmsg as usize + __DARWIN_ALIGN32(cmsg_len as usize) -            + __DARWIN_ALIGN32(mem::size_of::<::cmsghdr>()); +        let next = cmsg as usize + __DARWIN_ALIGN32(cmsg_len as usize);          let max = (*mhdr).msg_control as usize                     + (*mhdr).msg_controllen as usize; -        if next > max { +        if next + __DARWIN_ALIGN32(::mem::size_of::<::cmsghdr>()) > max {              0 as *mut ::cmsghdr          } else {              next as *mut ::cmsghdr @@ -2409,17 +2978,17 @@ f! {      pub fn CMSG_DATA(cmsg: *const ::cmsghdr) -> *mut ::c_uchar {          (cmsg as *mut ::c_uchar) -            .offset(__DARWIN_ALIGN32(mem::size_of::<::cmsghdr>()) as isize) +            .offset(__DARWIN_ALIGN32(::mem::size_of::<::cmsghdr>()) as isize)      }      pub fn CMSG_SPACE(length: ::c_uint) -> ::c_uint { -        (__DARWIN_ALIGN32(mem::size_of::<::cmsghdr>()) +        (__DARWIN_ALIGN32(::mem::size_of::<::cmsghdr>())              + __DARWIN_ALIGN32(length as usize))              as ::c_uint      }      pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint { -        __DARWIN_ALIGN32(mem::size_of::<::cmsghdr>() + length as usize) +        (__DARWIN_ALIGN32(::mem::size_of::<::cmsghdr>()) + length as usize)              as ::c_uint      } @@ -2445,6 +3014,16 @@ f! {  }  extern { +    #[deprecated(since="0.2.49", note="Deprecated in MacOSX 10.5")] +    #[link_name = "daemon$1050"] +    pub fn daemon(nochdir: ::c_int, noclose: ::c_int) -> ::c_int; +    #[deprecated(since="0.2.49", note="Deprecated in MacOSX 10.10")] +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    #[deprecated(since="0.2.49", note="Deprecated in MacOSX 10.10")] +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int;      pub fn aio_read(aiocbp: *mut aiocb) -> ::c_int;      pub fn aio_write(aiocbp: *mut aiocb) -> ::c_int;      pub fn aio_fsync(op: ::c_int, aiocbp: *mut aiocb) -> ::c_int; @@ -2589,6 +3168,7 @@ extern {                     name: *mut ::c_char,                     termp: *mut termios,                     winp: *mut ::winsize) -> ::pid_t; +    pub fn login_tty(fd: ::c_int) -> ::c_int;      pub fn duplocale(base: ::locale_t) -> ::locale_t;      pub fn freelocale(loc: ::locale_t) -> ::c_int;      pub fn localeconv_l(loc: ::locale_t) -> *mut lconv; diff --git a/libc/src/unix/bsd/freebsdlike/dragonfly/mod.rs b/libc/src/unix/bsd/freebsdlike/dragonfly/mod.rs index 992d008..e91b351 100644 --- a/libc/src/unix/bsd/freebsdlike/dragonfly/mod.rs +++ b/libc/src/unix/bsd/freebsdlike/dragonfly/mod.rs @@ -1,3 +1,4 @@ +pub type c_char = i8;  pub type clock_t = u64;  pub type ino_t = u64;  pub type lwpid_t = i32; @@ -15,34 +16,22 @@ pub type uuid_t = ::uuid;  pub type fsblkcnt_t = u64;  pub type fsfilcnt_t = u64; +pub type mqd_t = ::c_int;  pub type sem_t = *mut sem; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum sem {} +impl ::Copy for sem {} +impl ::Clone for sem { +    fn clone(&self) -> sem { *self } +}  s! { -      pub struct exit_status {          pub e_termination: u16,          pub e_exit: u16      } -    pub struct utmpx { -        pub ut_name: [::c_char; 32], -        pub ut_id: [::c_char; 4], - -        pub ut_line: [::c_char; 32], -        pub ut_host: [::c_char; 256], - -        pub ut_unused: [u8; 16], -        pub ut_session: u16, -        pub ut_type: u16, -        pub ut_pid: ::pid_t, -        ut_exit: exit_status, -        ut_ss: ::sockaddr_storage, -        pub ut_tv: ::timeval, -        pub ut_unused2: [u8; 16], -    } -      pub struct aiocb {          pub aio_fildes: ::c_int,          pub aio_offset: ::off_t, @@ -55,15 +44,6 @@ s! {          _aio_err: ::c_int      } -    pub struct dirent { -        pub d_fileno: ::ino_t, -        pub d_namlen: u16, -        pub d_type: u8, -        __unused1: u8, -        __unused2: u32, -        pub d_name: [::c_char; 256], -    } -      pub struct uuid {          pub time_low: u32,          pub time_mid: u16, @@ -115,27 +95,6 @@ s! {          pub f_uid_uuid: ::uuid_t,      } -    pub struct statfs { -        pub f_bsize: ::c_long, -        pub f_iosize: ::c_long, -        pub f_blocks: ::c_long, -        pub f_bfree: ::c_long, -        pub f_bavail: ::c_long, -        pub f_files: ::c_long, -        pub f_ffree: ::c_long, -        pub f_fsid: ::fsid_t, -        pub f_owner: ::uid_t, -        pub f_type: ::int32_t, -        pub f_flags: ::int32_t, -        pub f_syncwrites: ::c_long, -        pub f_asyncwrites: ::c_long, -        pub f_fstypename: [::c_char; 16], -        pub f_mntonname: [::c_char; 90], -        pub f_syncreads: ::c_long, -        pub f_asyncreads: ::c_long, -        pub f_mntfromname: [::c_char; 90], -    } -      pub struct stat {          pub st_ino: ::ino_t,          pub st_nlink: ::nlink_t, @@ -218,6 +177,230 @@ s! {      }  } +s_no_extra_traits! { +    pub struct utmpx { +        pub ut_name: [::c_char; 32], +        pub ut_id: [::c_char; 4], + +        pub ut_line: [::c_char; 32], +        pub ut_host: [::c_char; 256], + +        pub ut_unused: [u8; 16], +        pub ut_session: u16, +        pub ut_type: u16, +        pub ut_pid: ::pid_t, +        ut_exit: exit_status, +        ut_ss: ::sockaddr_storage, +        pub ut_tv: ::timeval, +        pub ut_unused2: [u8; 16], +    } + +    pub struct dirent { +        pub d_fileno: ::ino_t, +        pub d_namlen: u16, +        pub d_type: u8, +        __unused1: u8, +        __unused2: u32, +        pub d_name: [::c_char; 256], +    } + +    pub struct statfs { +        pub f_bsize: ::c_long, +        pub f_iosize: ::c_long, +        pub f_blocks: ::c_long, +        pub f_bfree: ::c_long, +        pub f_bavail: ::c_long, +        pub f_files: ::c_long, +        pub f_ffree: ::c_long, +        pub f_fsid: ::fsid_t, +        pub f_owner: ::uid_t, +        pub f_type: ::int32_t, +        pub f_flags: ::int32_t, +        pub f_syncwrites: ::c_long, +        pub f_asyncwrites: ::c_long, +        pub f_fstypename: [::c_char; 16], +        pub f_mntonname: [::c_char; 90], +        pub f_syncreads: ::c_long, +        pub f_asyncreads: ::c_long, +        pub f_mntfromname: [::c_char; 90], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for utmpx { +            fn eq(&self, other: &utmpx) -> bool { +                self.ut_name == other.ut_name +                    && self.ut_id == other.ut_id +                    && self.ut_line == other.ut_line +                    && self +                    .ut_host +                    .iter() +                    .zip(other.ut_host.iter()) +                    .all(|(a,b)| a == b) +                    && self.ut_unused == other.ut_unused +                    && self.ut_session == other.ut_session +                    && self.ut_type == other.ut_type +                    && self.ut_pid == other.ut_pid +                    && self.ut_exit == other.ut_exit +                    && self.ut_ss == other.ut_ss +                    && self.ut_tv == other.ut_tv +                    && self.ut_unused2 == other.ut_unused2 +            } +        } +        impl Eq for utmpx {} +        impl ::fmt::Debug for utmpx { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utmpx") +                    .field("ut_name", &self.ut_name) +                    .field("ut_id", &self.ut_id) +                    .field("ut_line", &self.ut_line) +                    // FIXME: .field("ut_host", &self.ut_host) +                    .field("ut_unused", &self.ut_unused) +                    .field("ut_session", &self.ut_session) +                    .field("ut_type", &self.ut_type) +                    .field("ut_pid", &self.ut_pid) +                    .field("ut_exit", &self.ut_exit) +                    .field("ut_ss", &self.ut_ss) +                    .field("ut_tv", &self.ut_tv) +                    .field("ut_unused2", &self.ut_unused2) +                    .finish() +            } +        } +        impl ::hash::Hash for utmpx { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ut_name.hash(state); +                self.ut_id.hash(state); +                self.ut_line.hash(state); +                self.ut_host.hash(state); +                self.ut_unused.hash(state); +                self.ut_session.hash(state); +                self.ut_type.hash(state); +                self.ut_pid.hash(state); +                self.ut_exit.hash(state); +                self.ut_ss.hash(state); +                self.ut_tv.hash(state); +                self.ut_unused2.hash(state); +            } +        } + +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_fileno == other.d_fileno +                    && self.d_namlen == other.d_namlen +                    && self.d_type == other.d_type +                    // Ignore __unused1 +                    // Ignore __unused2 +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for dirent {} +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_fileno", &self.d_fileno) +                    .field("d_namlen", &self.d_namlen) +                    .field("d_type", &self.d_type) +                    // Ignore __unused1 +                    // Ignore __unused2 +                    // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_fileno.hash(state); +                self.d_namlen.hash(state); +                self.d_type.hash(state); +                    // Ignore __unused1 +                    // Ignore __unused2 +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for statfs { +            fn eq(&self, other: &statfs) -> bool { +                self.f_bsize == other.f_bsize +                    && self.f_iosize == other.f_iosize +                    && self.f_blocks == other.f_blocks +                    && self.f_bfree == other.f_bfree +                    && self.f_bavail == other.f_bavail +                    && self.f_files == other.f_files +                    && self.f_ffree == other.f_ffree +                    && self.f_fsid == other.f_fsid +                    && self.f_owner == other.f_owner +                    && self.f_type == other.f_type +                    && self.f_flags == other.f_flags +                    && self.f_syncwrites == other.f_syncwrites +                    && self.f_asyncwrites == other.f_asyncwrites +                    && self.f_fstypename == other.f_fstypename +                    && self +                    .f_mntonname +                    .iter() +                    .zip(other.f_mntonname.iter()) +                    .all(|(a,b)| a == b) +                    && self.f_syncreads == other.f_syncreads +                    && self.f_asyncreads == other.f_asyncreads +                    && self +                    .f_mntfromname +                    .iter() +                    .zip(other.f_mntfromname.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for statfs {} +        impl ::fmt::Debug for statfs { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("statfs") +                    .field("f_bsize", &self.f_bsize) +                    .field("f_iosize", &self.f_iosize) +                    .field("f_blocks", &self.f_blocks) +                    .field("f_bfree", &self.f_bfree) +                    .field("f_bavail", &self.f_bavail) +                    .field("f_files", &self.f_files) +                    .field("f_ffree", &self.f_ffree) +                    .field("f_fsid", &self.f_fsid) +                    .field("f_owner", &self.f_owner) +                    .field("f_type", &self.f_type) +                    .field("f_flags", &self.f_flags) +                    .field("f_syncwrites", &self.f_syncwrites) +                    .field("f_asyncwrites", &self.f_asyncwrites) +                    // FIXME: .field("f_mntonname", &self.f_mntonname) +                    .field("f_syncreads", &self.f_syncreads) +                    .field("f_asyncreads", &self.f_asyncreads) +                    // FIXME: .field("f_mntfromname", &self.f_mntfromname) +                    .finish() +            } +        } +        impl ::hash::Hash for statfs { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.f_bsize.hash(state); +                self.f_iosize.hash(state); +                self.f_blocks.hash(state); +                self.f_bfree.hash(state); +                self.f_bavail.hash(state); +                self.f_files.hash(state); +                self.f_ffree.hash(state); +                self.f_fsid.hash(state); +                self.f_owner.hash(state); +                self.f_type.hash(state); +                self.f_flags.hash(state); +                self.f_syncwrites.hash(state); +                self.f_asyncwrites.hash(state); +                self.f_fstypename.hash(state); +                self.f_mntonname.hash(state); +                self.f_syncreads.hash(state); +                self.f_asyncreads.hash(state); +                self.f_mntfromname.hash(state); +            } +        } +    } +} +  pub const RAND_MAX: ::c_int = 0x7fff_ffff;  pub const PTHREAD_STACK_MIN: ::size_t = 16384;  pub const SIGSTKSZ: ::size_t = 40960; @@ -795,29 +978,32 @@ fn _CMSG_ALIGN(n: usize) -> usize {  f! {      pub fn CMSG_DATA(cmsg: *const ::cmsghdr) -> *mut ::c_uchar {          (cmsg as *mut ::c_uchar) -            .offset(_CMSG_ALIGN(mem::size_of::<::cmsghdr>()) as isize) +            .offset(_CMSG_ALIGN(::mem::size_of::<::cmsghdr>()) as isize)      }      pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint { -        _CMSG_ALIGN(mem::size_of::<::cmsghdr>()) + length as usize +        (_CMSG_ALIGN(::mem::size_of::<::cmsghdr>()) + length as usize) +            as ::c_uint      }      pub fn CMSG_NXTHDR(mhdr: *const ::msghdr, cmsg: *const ::cmsghdr)          -> *mut ::cmsghdr      { -        let next = cmsg as usize + _CMSG_ALIGN((*cmsg).cmsg_len) -            + _CMSG_ALIGN(mem::size_of::<::cmsghdr>()); +        let next = cmsg as usize + _CMSG_ALIGN((*cmsg).cmsg_len as usize) +            + _CMSG_ALIGN(::mem::size_of::<::cmsghdr>());          let max = (*mhdr).msg_control as usize              + (*mhdr).msg_controllen as usize;          if next <= max { -            (cmsg as usize + _CMSG_ALIGN((*cmsg).cmsg_len)) as *mut ::cmsghdr +            (cmsg as usize + _CMSG_ALIGN((*cmsg).cmsg_len as usize)) +                as *mut ::cmsghdr          } else {              0 as *mut ::cmsghdr          }      }      pub fn CMSG_SPACE(length: ::c_uint) -> ::c_uint { -        _CMSG_ALIGN(mem::size_of::<::cmsghdr>()) + _CMSG_ALIGN(length as usize) +        (_CMSG_ALIGN(::mem::size_of::<::cmsghdr>()) + +            _CMSG_ALIGN(length as usize)) as ::c_uint      }  } diff --git a/libc/src/unix/bsd/freebsdlike/freebsd/aarch64.rs b/libc/src/unix/bsd/freebsdlike/freebsd/aarch64.rs index d33b475..996abc5 100644 --- a/libc/src/unix/bsd/freebsdlike/freebsd/aarch64.rs +++ b/libc/src/unix/bsd/freebsdlike/freebsd/aarch64.rs @@ -1,5 +1,4 @@ -use dox::mem; - +pub type c_char = u8;  pub type c_long = i64;  pub type c_ulong = u64;  pub type time_t = i64; @@ -32,6 +31,14 @@ s! {  }  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_longlong>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_longlong>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +} +  pub const MAP_32BIT: ::c_int = 0x00080000; diff --git a/libc/src/unix/bsd/freebsdlike/freebsd/arm.rs b/libc/src/unix/bsd/freebsdlike/freebsd/arm.rs new file mode 100644 index 0000000..945aca9 --- /dev/null +++ b/libc/src/unix/bsd/freebsdlike/freebsd/arm.rs @@ -0,0 +1,47 @@ +pub type c_char = u8; +pub type c_long = i32; +pub type c_ulong = u32; +pub type time_t = i64; +pub type suseconds_t = i32; + +s! { +    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_uid: ::uid_t, +        pub st_gid: ::gid_t, +        pub st_rdev: ::dev_t, +        pub st_atime: ::time_t, +        pub st_atime_nsec: ::c_long, +        pub st_atime_pad: ::c_long, +        pub st_mtime: ::time_t, +        pub st_mtime_nsec: ::c_long, +        pub st_mtime_pad: ::c_long, +        pub st_ctime: ::time_t, +        pub st_ctime_nsec: ::c_long, +        pub st_ctime_pad: ::c_long, +        pub st_size: ::off_t, +        pub st_blocks: ::blkcnt_t, +        pub st_blksize: ::blksize_t, +        pub st_flags: ::fflags_t, +        pub st_gen: ::uint32_t, +        pub st_lspare: ::int32_t, +        pub st_birthtime: ::time_t, +        pub st_birthtime_nsec: ::c_long, +        pub st_birthtime_pad: ::c_long, +    } +} + +// should be pub(crate), but that requires Rust 1.18.0 +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_int>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 4 - 1; +    } +} +pub const MAP_32BIT: ::c_int = 0x00080000; diff --git a/libc/src/unix/bsd/freebsdlike/freebsd/mod.rs b/libc/src/unix/bsd/freebsdlike/freebsd/mod.rs index 91eab30..3ce96e8 100644 --- a/libc/src/unix/bsd/freebsdlike/freebsd/mod.rs +++ b/libc/src/unix/bsd/freebsdlike/freebsd/mod.rs @@ -1,5 +1,3 @@ -use dox::mem; -  pub type fflags_t = u32;  pub type clock_t = i32;  pub type ino_t = u32; @@ -17,21 +15,11 @@ pub type key_t = ::c_long;  pub type msglen_t = ::c_ulong;  pub type msgqnum_t = ::c_ulong; +pub type mqd_t = *mut ::c_void;  pub type posix_spawnattr_t = *mut ::c_void;  pub type posix_spawn_file_actions_t = *mut ::c_void;  s! { -    pub struct utmpx { -        pub ut_type: ::c_short, -        pub ut_tv: ::timeval, -        pub ut_id: [::c_char; 8], -        pub ut_pid: ::pid_t, -        pub ut_user: [::c_char; 32], -        pub ut_line: [::c_char; 16], -        pub ut_host: [::c_char; 128], -        pub __ut_spare: [::c_char; 64], -    } -      pub struct aiocb {          pub aio_fildes: ::c_int,          pub aio_offset: ::off_t, @@ -48,14 +36,6 @@ s! {          pub aio_sigevent: sigevent      } -    pub struct dirent { -        pub d_fileno: u32, -        pub d_reclen: u16, -        pub d_type: u8, -        pub d_namlen: u8, -        pub d_name: [::c_char; 256], -    } -      pub struct jail {          pub version: u32,          pub path: *mut ::c_char, @@ -101,31 +81,6 @@ s! {          pub f_namemax: ::c_ulong,      } -    pub struct statfs { -        pub f_version: ::uint32_t, -        pub f_type: ::uint32_t, -        pub f_flags: ::uint64_t, -        pub f_bsize: ::uint64_t, -        pub f_iosize: ::uint64_t, -        pub f_blocks: ::uint64_t, -        pub f_bfree: ::uint64_t, -        pub f_bavail: ::int64_t, -        pub f_files: ::uint64_t, -        pub f_ffree: ::int64_t, -        pub f_syncwrites: ::uint64_t, -        pub f_asyncwrites: ::uint64_t, -        pub f_syncreads: ::uint64_t, -        pub f_asyncreads: ::uint64_t, -        f_spare: [::uint64_t; 10], -        pub f_namemax: ::uint32_t, -        pub f_owner: ::uid_t, -        pub f_fsid: ::fsid_t, -        f_charspare: [::c_char; 80], -        pub f_fstypename: [::c_char; 16], -        pub f_mntfromname: [::c_char; 88], -        pub f_mntonname: [::c_char; 88], -    } -      // internal structure has changed over time      pub struct _sem {          data: [u32; 4], @@ -174,6 +129,63 @@ s! {          __cr_unused1: *mut ::c_void,      } +    pub struct stack_t { +        pub ss_sp: *mut ::c_void, +        pub ss_size: ::size_t, +        pub ss_flags: ::c_int, +    } + +    pub struct mmsghdr { +        pub msg_hdr: ::msghdr, +        pub msg_len: ::ssize_t, +    } +} + +s_no_extra_traits! { +    pub struct utmpx { +        pub ut_type: ::c_short, +        pub ut_tv: ::timeval, +        pub ut_id: [::c_char; 8], +        pub ut_pid: ::pid_t, +        pub ut_user: [::c_char; 32], +        pub ut_line: [::c_char; 16], +        pub ut_host: [::c_char; 128], +        pub __ut_spare: [::c_char; 64], +    } + +    pub struct dirent { +        pub d_fileno: u32, +        pub d_reclen: u16, +        pub d_type: u8, +        pub d_namlen: u8, +        pub d_name: [::c_char; 256], +    } + +    pub struct statfs { +        pub f_version: ::uint32_t, +        pub f_type: ::uint32_t, +        pub f_flags: ::uint64_t, +        pub f_bsize: ::uint64_t, +        pub f_iosize: ::uint64_t, +        pub f_blocks: ::uint64_t, +        pub f_bfree: ::uint64_t, +        pub f_bavail: ::int64_t, +        pub f_files: ::uint64_t, +        pub f_ffree: ::int64_t, +        pub f_syncwrites: ::uint64_t, +        pub f_asyncwrites: ::uint64_t, +        pub f_syncreads: ::uint64_t, +        pub f_asyncreads: ::uint64_t, +        f_spare: [::uint64_t; 10], +        pub f_namemax: ::uint32_t, +        pub f_owner: ::uid_t, +        pub f_fsid: ::fsid_t, +        f_charspare: [::c_char; 80], +        pub f_fstypename: [::c_char; 16], +        pub f_mntfromname: [::c_char; 88], +        pub f_mntonname: [::c_char; 88], +    } +      pub struct sockaddr_dl {          pub sdl_len: ::c_uchar,          pub sdl_family: ::c_uchar, @@ -184,11 +196,227 @@ s! {          pub sdl_slen: ::c_uchar,          pub sdl_data: [::c_char; 46],      } +} -    pub struct stack_t { -        pub ss_sp: *mut ::c_void, -        pub ss_size: ::size_t, -        pub ss_flags: ::c_int, +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for utmpx { +            fn eq(&self, other: &utmpx) -> bool { +                self.ut_type == other.ut_type +                    && self.ut_tv == other.ut_tv +                    && self.ut_id == other.ut_id +                    && self.ut_pid == other.ut_pid +                    && self.ut_user == other.ut_user +                    && self.ut_line == other.ut_line +                    && self +                    .ut_host +                    .iter() +                    .zip(other.ut_host.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .__ut_spare +                    .iter() +                    .zip(other.__ut_spare.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for utmpx {} +        impl ::fmt::Debug for utmpx { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utmpx") +                    .field("ut_type", &self.ut_type) +                    .field("ut_tv", &self.ut_tv) +                    .field("ut_id", &self.ut_id) +                    .field("ut_pid", &self.ut_pid) +                    .field("ut_user", &self.ut_user) +                    .field("ut_line", &self.ut_line) +                    // FIXME: .field("ut_host", &self.ut_host) +                    // FIXME: .field("__ut_spare", &self.__ut_spare) +                    .finish() +            } +        } +        impl ::hash::Hash for utmpx { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ut_type.hash(state); +                self.ut_tv.hash(state); +                self.ut_id.hash(state); +                self.ut_pid.hash(state); +                self.ut_user.hash(state); +                self.ut_line.hash(state); +                self.ut_host.hash(state); +                self.__ut_spare.hash(state); +            } +        } + +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_fileno == other.d_fileno +                    && self.d_reclen == other.d_reclen +                    && self.d_type == other.d_type +                    && self.d_namlen == other.d_namlen +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for dirent {} +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_fileno", &self.d_fileno) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_type", &self.d_type) +                    .field("d_namlen", &self.d_namlen) +                    // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_fileno.hash(state); +                self.d_reclen.hash(state); +                self.d_type.hash(state); +                self.d_namlen.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for statfs { +            fn eq(&self, other: &statfs) -> bool { +                self.f_version == other.f_version +                    && self.f_type == other.f_type +                    && self.f_flags == other.f_flags +                    && self.f_bsize == other.f_bsize +                    && self.f_iosize == other.f_iosize +                    && self.f_blocks == other.f_blocks +                    && self.f_bfree == other.f_bfree +                    && self.f_bavail == other.f_bavail +                    && self.f_files == other.f_files +                    && self.f_ffree == other.f_ffree +                    && self.f_syncwrites == other.f_syncwrites +                    && self.f_asyncwrites == other.f_asyncwrites +                    && self.f_syncreads == other.f_syncreads +                    && self.f_asyncreads == other.f_asyncreads +                    && self.f_spare == other.f_spare +                    && self.f_namemax == other.f_namemax +                    && self.f_owner == other.f_owner +                    && self.f_fsid == other.f_fsid +                    && self +                    .f_charspare +                    .iter() +                    .zip(other.f_charspare.iter()) +                    .all(|(a,b)| a == b) +                    && self.f_fstypename == other.f_fstypename +                    && self +                    .f_mntfromname +                    .iter() +                    .zip(other.f_mntfromname.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .f_mntonname +                    .iter() +                    .zip(other.f_mntonname.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for statfs {} +        impl ::fmt::Debug for statfs { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("statfs") +                    .field("f_bsize", &self.f_bsize) +                    .field("f_iosize", &self.f_iosize) +                    .field("f_blocks", &self.f_blocks) +                    .field("f_bfree", &self.f_bfree) +                    .field("f_bavail", &self.f_bavail) +                    .field("f_files", &self.f_files) +                    .field("f_ffree", &self.f_ffree) +                    .field("f_syncwrites", &self.f_syncwrites) +                    .field("f_asyncwrites", &self.f_asyncwrites) +                    .field("f_syncreads", &self.f_syncreads) +                    .field("f_asyncreads", &self.f_asyncreads) +                    .field("f_spare", &self.f_spare) +                    .field("f_namemax", &self.f_namemax) +                    .field("f_owner", &self.f_owner) +                    .field("f_fsid", &self.f_fsid) +                    // FIXME: .field("f_charspare", &self.f_charspare) +                    .field("f_fstypename", &self.f_fstypename) +                    // FIXME: .field("f_mntfromname", &self.f_mntfromname) +                    // FIXME: .field("f_mntonname", &self.f_mntonname) +                    .finish() +            } +        } +        impl ::hash::Hash for statfs { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.f_version.hash(state); +                self.f_type.hash(state); +                self.f_flags.hash(state); +                self.f_bsize.hash(state); +                self.f_iosize.hash(state); +                self.f_blocks.hash(state); +                self.f_bfree.hash(state); +                self.f_bavail.hash(state); +                self.f_files.hash(state); +                self.f_ffree.hash(state); +                self.f_syncwrites.hash(state); +                self.f_asyncwrites.hash(state); +                self.f_syncreads.hash(state); +                self.f_asyncreads.hash(state); +                self.f_spare.hash(state); +                self.f_namemax.hash(state); +                self.f_owner.hash(state); +                self.f_fsid.hash(state); +                self.f_charspare.hash(state); +                self.f_fstypename.hash(state); +                self.f_mntfromname.hash(state); +                self.f_mntonname.hash(state); +            } +        } + +        impl PartialEq for sockaddr_dl { +            fn eq(&self, other: &sockaddr_dl) -> bool { +                self.sdl_len == other.sdl_len +                    && self.sdl_family == other.sdl_family +                    && self.sdl_index == other.sdl_index +                    && self.sdl_type == other.sdl_type +                    && self.sdl_nlen == other.sdl_nlen +                    && self.sdl_alen == other.sdl_alen +                    && self.sdl_slen == other.sdl_slen +                    && self +                    .sdl_data +                    .iter() +                    .zip(other.sdl_data.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sockaddr_dl {} +        impl ::fmt::Debug for sockaddr_dl { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_dl") +                    .field("sdl_len", &self.sdl_len) +                    .field("sdl_family", &self.sdl_family) +                    .field("sdl_index", &self.sdl_index) +                    .field("sdl_type", &self.sdl_type) +                    .field("sdl_nlen", &self.sdl_nlen) +                    .field("sdl_alen", &self.sdl_alen) +                    .field("sdl_slen", &self.sdl_slen) +                    // FIXME: .field("sdl_data", &self.sdl_data) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_dl { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sdl_len.hash(state); +                self.sdl_family.hash(state); +                self.sdl_index.hash(state); +                self.sdl_type.hash(state); +                self.sdl_nlen.hash(state); +                self.sdl_alen.hash(state); +                self.sdl_slen.hash(state); +                self.sdl_data.hash(state); +            } +        }      }  } @@ -824,8 +1052,16 @@ pub const TCP_PCAP_OUT: ::c_int = 2048;  pub const TCP_PCAP_IN: ::c_int = 4096;  pub const IP_BINDANY: ::c_int = 24; +pub const IP_BINDMULTI: ::c_int = 25; +pub const IP_RSS_LISTEN_BUCKET: ::c_int = 26; +pub const IP_ORIGDSTADDR : ::c_int = 27; +pub const IP_RECVORIGDSTADDR : ::c_int = IP_ORIGDSTADDR; +  pub const IP_RECVTOS: ::c_int = 68; +pub const IPV6_ORIGDSTADDR: ::c_int = 72; +pub const IPV6_RECVORIGDSTADDR: ::c_int = IPV6_ORIGDSTADDR; +  pub const PF_SLOW: ::c_int = AF_SLOW;  pub const PF_SCLUSTER: ::c_int = AF_SCLUSTER;  pub const PF_ARP: ::c_int = AF_ARP; @@ -977,11 +1213,11 @@ fn _ALIGN(p: usize) -> usize {  f! {      pub fn CMSG_DATA(cmsg: *const ::cmsghdr) -> *mut ::c_uchar {          (cmsg as *mut ::c_uchar) -            .offset(_ALIGN(mem::size_of::<::cmsghdr>()) as isize) +            .offset(_ALIGN(::mem::size_of::<::cmsghdr>()) as isize)      }      pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint { -        _ALIGN(mem::size_of::<::cmsghdr>()) as ::c_uint + length +        _ALIGN(::mem::size_of::<::cmsghdr>()) as ::c_uint + length      }      pub fn CMSG_NXTHDR(mhdr: *const ::msghdr, cmsg: *const ::cmsghdr) @@ -991,7 +1227,7 @@ f! {              return ::CMSG_FIRSTHDR(mhdr);          };          let next = cmsg as usize + _ALIGN((*cmsg).cmsg_len as usize) -            + _ALIGN(mem::size_of::<::cmsghdr>()); +            + _ALIGN(::mem::size_of::<::cmsghdr>());          let max = (*mhdr).msg_control as usize              + (*mhdr).msg_controllen as usize;          if next > max { @@ -1003,7 +1239,7 @@ f! {      }      pub fn CMSG_SPACE(length: ::c_uint) -> ::c_uint { -        (_ALIGN(mem::size_of::<::cmsghdr>()) + _ALIGN(length as usize)) +        (_ALIGN(::mem::size_of::<::cmsghdr>()) + _ALIGN(length as usize))              as ::c_uint      } @@ -1097,6 +1333,7 @@ extern {      pub fn aio_waitcomplete(iocbp: *mut *mut aiocb,                              timeout: *mut ::timespec) -> ::ssize_t; +    pub fn mq_getfd_np(mqd: ::mqd_t) -> ::c_int;      pub fn freelocale(loc: ::locale_t) -> ::c_int;      pub fn waitid(idtype: idtype_t, id: ::id_t, infop: *mut ::siginfo_t, @@ -1199,6 +1436,11 @@ extern {      pub fn dup3(src: ::c_int, dst: ::c_int, flags: ::c_int) -> ::c_int;      pub fn __xuname(nmln: ::c_int, buf: *mut ::c_void) -> ::c_int; + +    pub fn sendmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::size_t, +                    flags: ::c_int) -> ::ssize_t; +    pub fn recvmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::size_t, +                    flags: ::c_int, timeout: *const ::timespec) -> ::ssize_t;  }  #[link(name = "util")] @@ -1219,6 +1461,12 @@ cfg_if! {      } else if #[cfg(target_arch = "aarch64")] {          mod aarch64;          pub use self::aarch64::*; +    } else if #[cfg(target_arch = "arm")] { +        mod arm; +        pub use self::arm::*; +    } else if #[cfg(target_arch = "powerpc64")] { +        mod powerpc64; +        pub use self::powerpc64::*;      } else {          // Unknown target_arch      } diff --git a/libc/src/unix/bsd/freebsdlike/freebsd/powerpc64.rs b/libc/src/unix/bsd/freebsdlike/freebsd/powerpc64.rs new file mode 100644 index 0000000..9d893b6 --- /dev/null +++ b/libc/src/unix/bsd/freebsdlike/freebsd/powerpc64.rs @@ -0,0 +1,44 @@ +pub type c_char = u8; +pub type c_long = i64; +pub type c_ulong = u64; +pub type time_t = i64; +pub type suseconds_t = i64; + +s! { +    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_uid: ::uid_t, +        pub st_gid: ::gid_t, +        pub st_rdev: ::dev_t, +        pub st_atime: ::time_t, +        pub st_atime_nsec: ::c_long, +        pub st_mtime: ::time_t, +        pub st_mtime_nsec: ::c_long, +        pub st_ctime: ::time_t, +        pub st_ctime_nsec: ::c_long, +        pub st_size: ::off_t, +        pub st_blocks: ::blkcnt_t, +        pub st_blksize: ::blksize_t, +        pub st_flags: ::fflags_t, +        pub st_gen: ::uint32_t, +        pub st_lspare: ::int32_t, +        pub st_birthtime: ::time_t, +        pub st_birthtime_nsec: ::c_long, +    } +} + +// should be pub(crate), but that requires Rust 1.18.0 +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_long>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +} + +pub const MAP_32BIT: ::c_int = 0x00080000; diff --git a/libc/src/unix/bsd/freebsdlike/freebsd/x86.rs b/libc/src/unix/bsd/freebsdlike/freebsd/x86.rs index a5495aa..845124d 100644 --- a/libc/src/unix/bsd/freebsdlike/freebsd/x86.rs +++ b/libc/src/unix/bsd/freebsdlike/freebsd/x86.rs @@ -1,5 +1,4 @@ -use dox::mem; - +pub type c_char = i8;  pub type c_long = i32;  pub type c_ulong = u32;  pub type time_t = i32; @@ -33,5 +32,12 @@ s! {  }  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_long>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_long>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +} diff --git a/libc/src/unix/bsd/freebsdlike/freebsd/x86_64.rs b/libc/src/unix/bsd/freebsdlike/freebsd/x86_64.rs index 711feb7..323d1ab 100644 --- a/libc/src/unix/bsd/freebsdlike/freebsd/x86_64.rs +++ b/libc/src/unix/bsd/freebsdlike/freebsd/x86_64.rs @@ -1,5 +1,4 @@ -use dox::mem; - +pub type c_char = i8;  pub type c_long = i64;  pub type c_ulong = u64;  pub type time_t = i64; @@ -32,6 +31,13 @@ s! {  }  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_long>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_long>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +}  pub const MAP_32BIT: ::c_int = 0x00080000; diff --git a/libc/src/unix/bsd/freebsdlike/mod.rs b/libc/src/unix/bsd/freebsdlike/mod.rs index 22c11b3..7a82a45 100644 --- a/libc/src/unix/bsd/freebsdlike/mod.rs +++ b/libc/src/unix/bsd/freebsdlike/mod.rs @@ -1,9 +1,7 @@ -pub type c_char = i8;  pub type dev_t = u32;  pub type mode_t = u16;  pub type pthread_attr_t = *mut ::c_void;  pub type rlim_t = i64; -pub type mqd_t = *mut ::c_void;  pub type pthread_mutex_t = *mut ::c_void;  pub type pthread_mutexattr_t = *mut ::c_void;  pub type pthread_cond_t = *mut ::c_void; @@ -15,10 +13,25 @@ pub type tcflag_t = ::c_uint;  pub type speed_t = ::c_uint;  pub type nl_item = ::c_int;  pub type id_t = i64; +pub type vm_size_t = ::uintptr_t; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum timezone {} +impl ::Copy for timezone {} +impl ::Clone for timezone { +    fn clone(&self) -> timezone { *self } +}  s! { +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } + +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } +      pub struct glob_t {          pub gl_pathc:  ::size_t,          pub gl_matchc: ::size_t, @@ -42,14 +55,6 @@ s! {          pub udata: *mut ::c_void,      } -    pub struct sockaddr_storage { -        pub ss_len: u8, -        pub ss_family: ::sa_family_t, -        __ss_pad1: [u8; 6], -        __ss_align: i64, -        __ss_pad2: [u8; 112], -    } -      pub struct addrinfo {          pub ai_flags: ::c_int,          pub ai_family: ::c_int, @@ -183,6 +188,55 @@ s! {      }  } +s_no_extra_traits! { +    pub struct sockaddr_storage { +        pub ss_len: u8, +        pub ss_family: ::sa_family_t, +        __ss_pad1: [u8; 6], +        __ss_align: i64, +        __ss_pad2: [u8; 112], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for sockaddr_storage { +            fn eq(&self, other: &sockaddr_storage) -> bool { +                self.ss_len == other.ss_len +                    && self.ss_family == other.ss_family +                    && self.__ss_pad1 == other.__ss_pad1 +                    && self.__ss_align == other.__ss_align +                    && self +                    .__ss_pad2 +                    .iter() +                    .zip(other.__ss_pad2.iter()) +                    .all(|(a, b)| a == b) +            } +        } +        impl Eq for sockaddr_storage {} +        impl ::fmt::Debug for sockaddr_storage { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_storage") +                    .field("ss_len", &self.ss_len) +                    .field("ss_family", &self.ss_family) +                    .field("__ss_pad1", &self.__ss_pad1) +                    .field("__ss_align", &self.__ss_align) +                    // FIXME: .field("__ss_pad2", &self.__ss_pad2) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_storage { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ss_len.hash(state); +                self.ss_family.hash(state); +                self.__ss_pad1.hash(state); +                self.__ss_align.hash(state); +                self.__ss_pad2.hash(state); +            } +        } +    } +} +  pub const AIO_LISTIO_MAX: ::c_int = 16;  pub const AIO_CANCELED: ::c_int = 1;  pub const AIO_NOTCANCELED: ::c_int = 2; @@ -1034,6 +1088,14 @@ f! {  }  extern { +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int; + +    pub fn daemon(nochdir: ::c_int, noclose: ::c_int) -> ::c_int; +      pub fn accept4(s: ::c_int, addr: *mut ::sockaddr,                     addrlen: *mut ::socklen_t, flags: ::c_int) -> ::c_int;      pub fn aio_read(aiocbp: *mut aiocb) -> ::c_int; @@ -1237,6 +1299,7 @@ extern {                     name: *mut ::c_char,                     termp: *mut termios,                     winp: *mut ::winsize) -> ::pid_t; +    pub fn login_tty(fd: ::c_int) -> ::c_int;  }  cfg_if! { diff --git a/libc/src/unix/bsd/mod.rs b/libc/src/unix/bsd/mod.rs index 12f6e14..03c987d 100644 --- a/libc/src/unix/bsd/mod.rs +++ b/libc/src/unix/bsd/mod.rs @@ -1,5 +1,3 @@ -use dox::{mem, Option}; -  pub type wchar_t = i32;  pub type off_t = i64;  pub type useconds_t = u32; @@ -25,12 +23,6 @@ s! {          pub sin6_scope_id: u32,      } -    pub struct sockaddr_un { -        pub sun_len: u8, -        pub sun_family: sa_family_t, -        pub sun_path: [c_char; 104] -    } -      pub struct passwd {          pub pw_name: *mut ::c_char,          pub pw_passwd: *mut ::c_char, @@ -85,6 +77,39 @@ s! {          pub tm_zone: *mut ::c_char,      } +    pub struct msghdr { +        pub msg_name: *mut ::c_void, +        pub msg_namelen: ::socklen_t, +        pub msg_iov: *mut ::iovec, +        pub msg_iovlen: ::c_int, +        pub msg_control: *mut ::c_void, +        pub msg_controllen: ::socklen_t, +        pub msg_flags: ::c_int, +    } + +    pub struct cmsghdr { +        pub cmsg_len: ::socklen_t, +        pub cmsg_level: ::c_int, +        pub cmsg_type: ::c_int, +    } + +    pub struct fsid_t { +        __fsid_val: [::int32_t; 2], +    } + +    pub struct if_nameindex { +        pub if_index: ::c_uint, +        pub if_name: *mut ::c_char, +    } +} + +s_no_extra_traits!{ +    pub struct sockaddr_un { +        pub sun_len: u8, +        pub sun_family: sa_family_t, +        pub sun_path: [c_char; 104] +    } +      pub struct utsname {          #[cfg(not(target_os = "dragonfly"))]          pub sysname: [::c_char; 256], @@ -108,29 +133,94 @@ s! {          pub machine: [::c_char; 32],      } -    pub struct msghdr { -        pub msg_name: *mut ::c_void, -        pub msg_namelen: ::socklen_t, -        pub msg_iov: *mut ::iovec, -        pub msg_iovlen: ::c_int, -        pub msg_control: *mut ::c_void, -        pub msg_controllen: ::socklen_t, -        pub msg_flags: ::c_int, -    } +} -    pub struct cmsghdr { -        pub cmsg_len: ::socklen_t, -        pub cmsg_level: ::c_int, -        pub cmsg_type: ::c_int, -    } +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for sockaddr_un { +            fn eq(&self, other: &sockaddr_un) -> bool { +                self.sun_len == other.sun_len +                    && self.sun_family == other.sun_family +                    && self +                    .sun_path +                    .iter() +                    .zip(other.sun_path.iter()) +                    .all(|(a,b)| a == b) +            } +        } -    pub struct fsid_t { -        __fsid_val: [::int32_t; 2], -    } +        impl Eq for sockaddr_un {} -    pub struct if_nameindex { -        pub if_index: ::c_uint, -        pub if_name: *mut ::c_char, +        impl ::fmt::Debug for sockaddr_un { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_un") +                    .field("sun_len", &self.sun_len) +                    .field("sun_family", &self.sun_family) +                // FIXME: .field("sun_path", &self.sun_path) +                    .finish() +            } +        } + +        impl ::hash::Hash for sockaddr_un { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sun_len.hash(state); +                self.sun_family.hash(state); +                self.sun_path.hash(state); +            } +        } + +        impl PartialEq for utsname { +            fn eq(&self, other: &utsname) -> bool { +                self.sysname +                    .iter() +                    .zip(other.sysname.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .nodename +                    .iter() +                    .zip(other.nodename.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .release +                    .iter() +                    .zip(other.release.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .version +                    .iter() +                    .zip(other.version.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .machine +                    .iter() +                    .zip(other.machine.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for utsname {} + +        impl ::fmt::Debug for utsname { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utsname") +                // FIXME: .field("sysname", &self.sysname) +                // FIXME: .field("nodename", &self.nodename) +                // FIXME: .field("release", &self.release) +                // FIXME: .field("version", &self.version) +                // FIXME: .field("machine", &self.machine) +                    .finish() +            } +        } + +        impl ::hash::Hash for utsname { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sysname.hash(state); +                self.nodename.hash(state); +                self.release.hash(state); +                self.version.hash(state); +                self.machine.hash(state); +            } +        }      }  } @@ -343,7 +433,7 @@ pub const POLLWRBAND: ::c_short = 0x100;  f! {      pub fn CMSG_FIRSTHDR(mhdr: *const ::msghdr) -> *mut ::cmsghdr { -        if (*mhdr).msg_controllen as usize >= mem::size_of::<::cmsghdr>() { +        if (*mhdr).msg_controllen as usize >= ::mem::size_of::<::cmsghdr>() {              (*mhdr).msg_control as *mut ::cmsghdr          } else {              0 as *mut ::cmsghdr @@ -351,20 +441,20 @@ f! {      }      pub fn FD_CLR(fd: ::c_int, set: *mut fd_set) -> () { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          (*set).fds_bits[fd / bits] &= !(1 << (fd % bits));          return      }      pub fn FD_ISSET(fd: ::c_int, set: *mut fd_set) -> bool { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          return ((*set).fds_bits[fd / bits] & (1 << (fd % bits))) != 0      }      pub fn FD_SET(fd: ::c_int, set: *mut fd_set) -> () { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          (*set).fds_bits[fd / bits] |= 1 << (fd % bits);          return @@ -435,7 +525,7 @@ extern {      #[cfg_attr(target_os = "freebsd", link_name = "glob@FBSD_1.0")]      pub fn glob(pattern: *const ::c_char,                  flags: ::c_int, -                errfunc: Option<extern fn(epath: *const ::c_char, +                errfunc: ::Option<extern fn(epath: *const ::c_char,                                            errno: ::c_int) -> ::c_int>,                  pglob: *mut ::glob_t) -> ::c_int;      #[cfg_attr(target_os = "netbsd", link_name = "__globfree30")] @@ -504,7 +594,7 @@ extern {      pub fn sync();      #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrgid_r")] -    pub fn getgrgid_r(uid: ::uid_t, +    pub fn getgrgid_r(gid: ::gid_t,                        grp: *mut ::group,                        buf: *mut ::c_char,                        buflen: ::size_t, @@ -533,7 +623,6 @@ extern {      pub fn pthread_cancel(thread: ::pthread_t) -> ::c_int;      pub fn pthread_kill(thread: ::pthread_t, sig: ::c_int) -> ::c_int;      pub fn sem_unlink(name: *const ::c_char) -> ::c_int; -    pub fn daemon(nochdir: ::c_int, noclose: ::c_int) -> ::c_int;      #[cfg_attr(target_os = "netbsd", link_name = "__getpwnam_r50")]      #[cfg_attr(target_os = "solaris", link_name = "__posix_getpwnam_r")]      pub fn getpwnam_r(name: *const ::c_char, @@ -553,9 +642,9 @@ extern {      #[cfg_attr(target_os = "solaris", link_name = "__posix_sigwait")]      pub fn sigwait(set: *const sigset_t,                     sig: *mut ::c_int) -> ::c_int; -    pub fn pthread_atfork(prepare: Option<unsafe extern fn()>, -                          parent: Option<unsafe extern fn()>, -                          child: Option<unsafe extern fn()>) -> ::c_int; +    pub fn pthread_atfork(prepare: ::Option<unsafe extern fn()>, +                          parent: ::Option<unsafe extern fn()>, +                          child: ::Option<unsafe extern fn()>) -> ::c_int;      pub fn getgrgid(gid: ::gid_t) -> *mut ::group;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "popen$UNIX2003")] @@ -574,8 +663,7 @@ cfg_if! {      if #[cfg(any(target_os = "macos", target_os = "ios"))] {          mod apple;          pub use self::apple::*; -    } else if #[cfg(any(target_os = "openbsd", target_os = "netbsd", -                        target_os = "bitrig"))] { +    } else if #[cfg(any(target_os = "openbsd", target_os = "netbsd"))] {          mod netbsdlike;          pub use self::netbsdlike::*;      } else if #[cfg(any(target_os = "freebsd", target_os = "dragonfly"))] { diff --git a/libc/src/unix/bsd/netbsdlike/mod.rs b/libc/src/unix/bsd/netbsdlike/mod.rs index 291c081..29b4dd7 100644 --- a/libc/src/unix/bsd/netbsdlike/mod.rs +++ b/libc/src/unix/bsd/netbsdlike/mod.rs @@ -1,5 +1,3 @@ -use dox::mem; -  pub type time_t = i64;  pub type mode_t = u32;  pub type nlink_t = ::uint32_t; @@ -13,8 +11,18 @@ pub type clockid_t = ::c_int;  pub type id_t = ::uint32_t;  pub type sem_t = *mut sem; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum timezone {} +impl ::Copy for timezone {} +impl ::Clone for timezone { +    fn clone(&self) -> timezone { *self } +} +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum sem {} +impl ::Copy for sem {} +impl ::Clone for sem { +    fn clone(&self) -> sem { *self } +}  s! {      pub struct sigaction { @@ -29,14 +37,6 @@ s! {          pub ss_flags: ::c_int,      } -    pub struct sockaddr_in { -        pub sin_len: u8, -        pub sin_family: ::sa_family_t, -        pub sin_port: ::in_port_t, -        pub sin_addr: ::in_addr, -        pub sin_zero: [::int8_t; 8], -    } -      pub struct in6_pktinfo {          pub ipi6_addr: ::in6_addr,          pub ipi6_ifindex: ::c_uint, @@ -595,58 +595,15 @@ pub const SF_APPEND:        ::c_ulong = 0x00040000;  pub const TIMER_ABSTIME: ::c_int = 1; -fn _ALIGN(p: usize) -> usize { -    (p + _ALIGNBYTES) & !_ALIGNBYTES -} - -f! { -    pub fn CMSG_DATA(cmsg: *const ::cmsghdr) -> *mut ::c_uchar { -        (cmsg as *mut ::c_uchar) -            .offset(_ALIGN(mem::size_of::<::cmsghdr>()) as isize) -    } - -    pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint { -        _ALIGN(mem::size_of::<::cmsghdr>()) as ::c_uint + length -    } - -    pub fn CMSG_NXTHDR(mhdr: *const ::msghdr, cmsg: *const ::cmsghdr) -        -> *mut ::cmsghdr -    { -        if cmsg.is_null() { -            return ::CMSG_FIRSTHDR(mhdr); -        }; -        let next = cmsg as usize + _ALIGN((*cmsg).cmsg_len as usize) -            + _ALIGN(mem::size_of::<::cmsghdr>()); -        let max = (*mhdr).msg_control as usize -            + (*mhdr).msg_controllen as usize; -        if next > max { -            0 as *mut ::cmsghdr -        } else { -            (cmsg as usize + _ALIGN((*cmsg).cmsg_len as usize)) -                as *mut ::cmsghdr -        } -    } - -    pub fn CMSG_SPACE(length: ::c_uint) -> ::c_uint { -        (_ALIGN(mem::size_of::<::cmsghdr>()) + _ALIGN(length as usize)) -            as ::c_uint -    } - -    pub fn WSTOPSIG(status: ::c_int) -> ::c_int { -        status >> 8 -    } - -    pub fn WIFSIGNALED(status: ::c_int) -> bool { -        (status & 0o177) != 0o177 && (status & 0o177) != 0 -    } - -    pub fn WIFSTOPPED(status: ::c_int) -> bool { -        (status & 0o177) == 0o177 -    } -} -  #[link(name = "util")]  extern { +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int; + +    pub fn daemon(nochdir: ::c_int, noclose: ::c_int) -> ::c_int;      pub fn mincore(addr: *mut ::c_void, len: ::size_t,                     vec: *mut ::c_char) -> ::c_int;      #[cfg_attr(target_os = "netbsd", link_name = "__clock_getres50")] @@ -686,6 +643,7 @@ extern {                     name: *mut ::c_char,                     termp: *mut termios,                     winp: *mut ::winsize) -> ::pid_t; +    pub fn login_tty(fd: ::c_int) -> ::c_int;      pub fn getpriority(which: ::c_int, who: ::id_t) -> ::c_int;      pub fn setpriority(which: ::c_int, who: ::id_t, prio: ::c_int) -> ::c_int; @@ -718,7 +676,7 @@ cfg_if! {      if #[cfg(target_os = "netbsd")] {          mod netbsd;          pub use self::netbsd::*; -    } else if #[cfg(any(target_os = "openbsd", target_os = "bitrig"))] { +    } else if #[cfg(target_os = "openbsd")] {          mod openbsdlike;          pub use self::openbsdlike::*;      } else { diff --git a/libc/src/unix/bsd/netbsdlike/netbsd/aarch64.rs b/libc/src/unix/bsd/netbsdlike/netbsd/aarch64.rs index cda75bc..58c4cf7 100644 --- a/libc/src/unix/bsd/netbsdlike/netbsd/aarch64.rs +++ b/libc/src/unix/bsd/netbsdlike/netbsd/aarch64.rs @@ -1,5 +1,3 @@ -use dox::mem; -  use PT_FIRSTMACH;  pub type c_long = i64; @@ -8,8 +6,15 @@ pub type c_char = u8;  pub type __cpu_simple_lock_nv_t = ::c_uchar;  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_int>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_int>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 4 - 1; +    } +}  pub const PT_GETREGS: ::c_int = PT_FIRSTMACH + 0;  pub const PT_SETREGS: ::c_int = PT_FIRSTMACH + 1; diff --git a/libc/src/unix/bsd/netbsdlike/netbsd/arm.rs b/libc/src/unix/bsd/netbsdlike/netbsd/arm.rs index 71c2cb7..4bf3ccd 100644 --- a/libc/src/unix/bsd/netbsdlike/netbsd/arm.rs +++ b/libc/src/unix/bsd/netbsdlike/netbsd/arm.rs @@ -1,5 +1,3 @@ -use dox::mem; -  use PT_FIRSTMACH;  pub type c_long = i32; @@ -8,8 +6,15 @@ pub type c_char = u8;  pub type __cpu_simple_lock_nv_t = ::c_int;  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_longlong>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_longlong>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +}  pub const PT_GETREGS: ::c_int = PT_FIRSTMACH + 1;  pub const PT_SETREGS: ::c_int = PT_FIRSTMACH + 2; diff --git a/libc/src/unix/bsd/netbsdlike/netbsd/mod.rs b/libc/src/unix/bsd/netbsdlike/netbsd/mod.rs index d3acfb9..ad53c19 100644 --- a/libc/src/unix/bsd/netbsdlike/netbsd/mod.rs +++ b/libc/src/unix/bsd/netbsdlike/netbsd/mod.rs @@ -1,5 +1,3 @@ -use dox::mem; -  pub type clock_t = ::c_uint;  pub type suseconds_t = ::c_int;  pub type dev_t = u64; @@ -9,6 +7,7 @@ pub type fsfilcnt_t = ::uint64_t;  pub type idtype_t = ::c_int;  pub type mqd_t = ::c_int;  type __pthread_spin_t = __cpu_simple_lock_nv_t; +pub type vm_size_t = ::uintptr_t;  s! {      pub struct aiocb { @@ -24,14 +23,6 @@ s! {          _retval: ::ssize_t      } -    pub struct dirent { -        pub d_fileno: ::ino_t, -        pub d_reclen: u16, -        pub d_namlen: u16, -        pub d_type: u8, -        pub d_name: [::c_char; 512], -    } -      pub struct glob_t {          pub gl_pathc:   ::size_t,          pub gl_matchc:  ::size_t, @@ -91,41 +82,7 @@ s! {          pub st_spare: [::uint32_t; 2],      } -    pub struct statvfs { -        pub f_flag: ::c_ulong, -        pub f_bsize: ::c_ulong, -        pub f_frsize: ::c_ulong, -        pub f_iosize: ::c_ulong, - -        pub f_blocks: ::fsblkcnt_t, -        pub f_bfree: ::fsblkcnt_t, -        pub f_bavail: ::fsblkcnt_t, -        pub f_bresvd: ::fsblkcnt_t, - -        pub f_files: ::fsfilcnt_t, -        pub f_ffree: ::fsfilcnt_t, -        pub f_favail: ::fsfilcnt_t, -        pub f_fresvd: ::fsfilcnt_t, - -        pub f_syncreads: ::uint64_t, -        pub f_syncwrites: ::uint64_t, - -        pub f_asyncreads: ::uint64_t, -        pub f_asyncwrites: ::uint64_t, - -        pub f_fsidx: ::fsid_t, -        pub f_fsid: ::c_ulong, -        pub f_namemax: ::c_ulong, -        pub f_owner: ::uid_t, - -        pub f_spare: [::uint32_t; 4], - -        pub f_fstypename: [::c_char; 32], -        pub f_mntonname: [::c_char; 1024], -        pub f_mntfromname: [::c_char; 1024], -    } - -    pub struct addrinfo { +     pub struct addrinfo {          pub ai_flags: ::c_int,          pub ai_family: ::c_int,          pub ai_socktype: ::c_int, @@ -136,14 +93,6 @@ s! {          pub ai_next: *mut ::addrinfo,      } -    pub struct sockaddr_storage { -        pub ss_len: u8, -        pub ss_family: ::sa_family_t, -        __ss_pad1: [u8; 6], -        __ss_pad2: i64, -        __ss_pad3: [u8; 112], -    } -      pub struct siginfo_t {          pub si_signo: ::c_int,          pub si_code: ::c_int, @@ -319,6 +268,13 @@ s! {          pub sdl_data: [::c_char; 12],      } +    pub struct mmsghdr { +        pub msg_hdr: ::msghdr, +        pub msg_len: ::c_uint, +    } +} + +s_no_extra_traits! {      pub struct in_pktinfo {          pub ipi_addr: ::in_addr,          pub ipi_ifindex: ::c_uint, @@ -332,6 +288,377 @@ s! {          pub ar_pln: u8,          pub ar_op: u16,      } + +    #[repr(packed)] +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } + +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } + +    pub struct sockaddr_in { +        pub sin_len: u8, +        pub sin_family: ::sa_family_t, +        pub sin_port: ::in_port_t, +        pub sin_addr: ::in_addr, +        pub sin_zero: [::int8_t; 8], +    } + +    pub struct dirent { +        pub d_fileno: ::ino_t, +        pub d_reclen: u16, +        pub d_namlen: u16, +        pub d_type: u8, +        pub d_name: [::c_char; 512], +    } + +    pub struct statvfs { +        pub f_flag: ::c_ulong, +        pub f_bsize: ::c_ulong, +        pub f_frsize: ::c_ulong, +        pub f_iosize: ::c_ulong, + +        pub f_blocks: ::fsblkcnt_t, +        pub f_bfree: ::fsblkcnt_t, +        pub f_bavail: ::fsblkcnt_t, +        pub f_bresvd: ::fsblkcnt_t, + +        pub f_files: ::fsfilcnt_t, +        pub f_ffree: ::fsfilcnt_t, +        pub f_favail: ::fsfilcnt_t, +        pub f_fresvd: ::fsfilcnt_t, + +        pub f_syncreads: ::uint64_t, +        pub f_syncwrites: ::uint64_t, + +        pub f_asyncreads: ::uint64_t, +        pub f_asyncwrites: ::uint64_t, + +        pub f_fsidx: ::fsid_t, +        pub f_fsid: ::c_ulong, +        pub f_namemax: ::c_ulong, +        pub f_owner: ::uid_t, + +        pub f_spare: [::uint32_t; 4], + +        pub f_fstypename: [::c_char; 32], +        pub f_mntonname: [::c_char; 1024], +        pub f_mntfromname: [::c_char; 1024], +    } + +    pub struct sockaddr_storage { +        pub ss_len: u8, +        pub ss_family: ::sa_family_t, +        __ss_pad1: [u8; 6], +        __ss_pad2: i64, +        __ss_pad3: [u8; 112], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for in_pktinfo { +            fn eq(&self, other: &in_pktinfo) -> bool { +                self.ipi_addr == other.ipi_addr +                    && self.ipi_ifindex == other.ipi_ifindex +            } +        } +        impl Eq for in_pktinfo {} +        impl ::fmt::Debug for in_pktinfo { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("in_pktinfo") +                    .field("ipi_addr", &self.ipi_addr) +                    .field("ipi_ifindex", &self.ipi_ifindex) +                    .finish() +            } +        } +        impl ::hash::Hash for in_pktinfo { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ipi_addr.hash(state); +                self.ipi_ifindex.hash(state); +            } +        } + +        impl PartialEq for arphdr { +            fn eq(&self, other: &arphdr) -> bool { +                self.ar_hrd == other.ar_hrd +                    && self.ar_pro == other.ar_pro +                    && self.ar_hln == other.ar_hln +                    && self.ar_pln == other.ar_pln +                    && self.ar_op == other.ar_op +            } +        } +        impl Eq for arphdr {} +        impl ::fmt::Debug for arphdr { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                let ar_hrd = self.ar_hrd; +                let ar_pro = self.ar_pro; +                let ar_op = self.ar_op; +                f.debug_struct("arphdr") +                    .field("ar_hrd", &ar_hrd) +                    .field("ar_pro", &ar_pro) +                    .field("ar_hln", &self.ar_hln) +                    .field("ar_pln", &self.ar_pln) +                    .field("ar_op", &ar_op) +                    .finish() +            } +        } +        impl ::hash::Hash for arphdr { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                let ar_hrd = self.ar_hrd; +                let ar_pro = self.ar_pro; +                let ar_op = self.ar_op; +                ar_hrd.hash(state); +                ar_pro.hash(state); +                self.ar_hln.hash(state); +                self.ar_pln.hash(state); +                ar_op.hash(state); +            } +        } + +        impl PartialEq for in_addr { +            fn eq(&self, other: &in_addr) -> bool { +                self.s_addr == other.s_addr +            } +        } +        impl Eq for in_addr {} +        impl ::fmt::Debug for in_addr { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                let s_addr = self.s_addr; +                f.debug_struct("in_addr") +                    .field("s_addr", &s_addr) +                    .finish() +            } +        } +        impl ::hash::Hash for in_addr { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                let s_addr = self.s_addr; +                s_addr.hash(state); +            } +        } + +        impl PartialEq for ip_mreq { +            fn eq(&self, other: &ip_mreq) -> bool { +                self.imr_multiaddr == other.imr_multiaddr +                    && self.imr_interface == other.imr_interface +            } +        } +        impl Eq for ip_mreq {} +        impl ::fmt::Debug for ip_mreq { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("ip_mreq") +                    .field("imr_multiaddr", &self.imr_multiaddr) +                    .field("imr_interface", &self.imr_interface) +                    .finish() +            } +        } +        impl ::hash::Hash for ip_mreq { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.imr_multiaddr.hash(state); +                self.imr_interface.hash(state); +            } +        } + +        impl PartialEq for sockaddr_in { +            fn eq(&self, other: &sockaddr_in) -> bool { +                self.sin_len == other.sin_len +                    && self.sin_family == other.sin_family +                    && self.sin_port == other.sin_port +                    && self.sin_addr == other.sin_addr +                    && self.sin_zero == other.sin_zero +            } +        } +        impl Eq for sockaddr_in {} +        impl ::fmt::Debug for sockaddr_in { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_in") +                    .field("sin_len", &self.sin_len) +                    .field("sin_family", &self.sin_family) +                    .field("sin_port", &self.sin_port) +                    .field("sin_addr", &self.sin_addr) +                    .field("sin_zero", &self.sin_zero) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_in { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sin_len.hash(state); +                self.sin_family.hash(state); +                self.sin_port.hash(state); +                self.sin_addr.hash(state); +                self.sin_zero.hash(state); +            } +        } + +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_fileno == other.d_fileno +                    && self.d_reclen == other.d_reclen +                    && self.d_namlen == other.d_namlen +                    && self.d_type == other.d_type +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for dirent {} +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_fileno", &self.d_fileno) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_namlen", &self.d_namlen) +                    .field("d_type", &self.d_type) +                    // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_fileno.hash(state); +                self.d_reclen.hash(state); +                self.d_namlen.hash(state); +                self.d_type.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for statvfs { +            fn eq(&self, other: &statvfs) -> bool { +                self.f_flag == other.f_flag +                    && self.f_bsize == other.f_bsize +                    && self.f_frsize == other.f_frsize +                    && self.f_iosize == other.f_iosize +                    && self.f_blocks == other.f_blocks +                    && self.f_bfree == other.f_bfree +                    && self.f_bavail == other.f_bavail +                    && self.f_bresvd == other.f_bresvd +                    && self.f_files == other.f_files +                    && self.f_ffree == other.f_ffree +                    && self.f_favail == other.f_favail +                    && self.f_fresvd == other.f_fresvd +                    && self.f_syncreads == other.f_syncreads +                    && self.f_syncwrites == other.f_syncwrites +                    && self.f_asyncreads == other.f_asyncreads +                    && self.f_asyncwrites == other.f_asyncwrites +                    && self.f_fsidx == other.f_fsidx +                    && self.f_fsid == other.f_fsid +                    && self.f_namemax == other.f_namemax +                    && self.f_owner == other.f_owner +                    && self.f_spare == other.f_spare +                    && self.f_fstypename == other.f_fstypename +                    && self +                    .f_mntonname +                    .iter() +                    .zip(other.f_mntonname.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .f_mntfromname +                    .iter() +                    .zip(other.f_mntfromname.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for statvfs {} +        impl ::fmt::Debug for statvfs { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("statvfs") +                    .field("f_flag", &self.f_flag) +                    .field("f_bsize", &self.f_bsize) +                    .field("f_frsize", &self.f_frsize) +                    .field("f_iosize", &self.f_iosize) +                    .field("f_blocks", &self.f_blocks) +                    .field("f_bfree", &self.f_bfree) +                    .field("f_bavail", &self.f_bavail) +                    .field("f_bresvd", &self.f_bresvd) +                    .field("f_files", &self.f_files) +                    .field("f_ffree", &self.f_ffree) +                    .field("f_favail", &self.f_favail) +                    .field("f_fresvd", &self.f_fresvd) +                    .field("f_syncreads", &self.f_syncreads) +                    .field("f_syncwrites", &self.f_syncwrites) +                    .field("f_asyncreads", &self.f_asyncreads) +                    .field("f_asyncwrites", &self.f_asyncwrites) +                    .field("f_fsidx", &self.f_fsidx) +                    .field("f_fsid", &self.f_fsid) +                    .field("f_namemax", &self.f_namemax) +                    .field("f_owner", &self.f_owner) +                    .field("f_spare", &self.f_spare) +                    .field("f_fstypename", &self.f_fstypename) +                    // FIXME: .field("f_mntonname", &self.f_mntonname) +                    // FIXME: .field("f_mntfromname", &self.f_mntfromname) +                    .finish() +            } +        } +        impl ::hash::Hash for statvfs { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.f_flag.hash(state); +                self.f_bsize.hash(state); +                self.f_frsize.hash(state); +                self.f_iosize.hash(state); +                self.f_blocks.hash(state); +                self.f_bfree.hash(state); +                self.f_bavail.hash(state); +                self.f_bresvd.hash(state); +                self.f_files.hash(state); +                self.f_ffree.hash(state); +                self.f_favail.hash(state); +                self.f_fresvd.hash(state); +                self.f_syncreads.hash(state); +                self.f_syncwrites.hash(state); +                self.f_asyncreads.hash(state); +                self.f_asyncwrites.hash(state); +                self.f_fsidx.hash(state); +                self.f_fsid.hash(state); +                self.f_namemax.hash(state); +                self.f_owner.hash(state); +                self.f_spare.hash(state); +                self.f_fstypename.hash(state); +                self.f_mntonname.hash(state); +                self.f_mntfromname.hash(state); +            } +        } + +        impl PartialEq for sockaddr_storage { +            fn eq(&self, other: &sockaddr_storage) -> bool { +                self.ss_len == other.ss_len +                    && self.ss_family == other.ss_family +                    && self.__ss_pad1 == other.__ss_pad1 +                    && self.__ss_pad2 == other.__ss_pad2 +                    && self +                    .__ss_pad3 +                    .iter() +                    .zip(other.__ss_pad3.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sockaddr_storage {} +        impl ::fmt::Debug for sockaddr_storage { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_storage") +                    .field("ss_len", &self.ss_len) +                    .field("ss_family", &self.ss_family) +                    .field("__ss_pad1", &self.__ss_pad1) +                    .field("__ss_pad2", &self.__ss_pad2) +                    // FIXME: .field("__ss_pad3", &self.__ss_pad3) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_storage { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ss_len.hash(state); +                self.ss_family.hash(state); +                self.__ss_pad1.hash(state); +                self.__ss_pad2.hash(state); +                self.__ss_pad3.hash(state); +            } +        } +    }  }  pub const AT_FDCWD: ::c_int = -100; @@ -708,21 +1035,32 @@ pub const FD_SETSIZE: usize = 0x100;  pub const ST_NOSUID: ::c_ulong = 8; -pub const PTHREAD_MUTEX_INITIALIZER: pthread_mutex_t = pthread_mutex_t { -    ptm_magic: 0x33330003, -    ptm_errorcheck: 0, -    #[cfg(any(target_arch = "sparc", target_arch = "sparc64", -              target_arch = "x86", target_arch = "x86_64"))] -    ptm_pad1: [0; 3], -    ptm_unused: 0, -    #[cfg(any(target_arch = "sparc", target_arch = "sparc64", -              target_arch = "x86", target_arch = "x86_64"))] -    ptm_pad2: [0; 3], -    ptm_waiters: 0 as *mut _, -    ptm_owner: 0, -    ptm_recursed: 0, -    ptm_spare2: 0 as *mut _, -}; +cfg_if! { +    if #[cfg(any(target_arch = "sparc", target_arch = "sparc64", +                 target_arch = "x86", target_arch = "x86_64"))] { +        pub const PTHREAD_MUTEX_INITIALIZER: pthread_mutex_t = pthread_mutex_t { +            ptm_magic: 0x33330003, +            ptm_errorcheck: 0, +            ptm_pad1: [0; 3], +            ptm_unused: 0, +            ptm_pad2: [0; 3], +            ptm_waiters: 0 as *mut _, +            ptm_owner: 0, +            ptm_recursed: 0, +            ptm_spare2: 0 as *mut _, +        }; +    } else { +        pub const PTHREAD_MUTEX_INITIALIZER: pthread_mutex_t = pthread_mutex_t { +            ptm_magic: 0x33330003, +            ptm_errorcheck: 0, +            ptm_unused: 0, +            ptm_waiters: 0 as *mut _, +            ptm_owner: 0, +            ptm_recursed: 0, +            ptm_spare2: 0 as *mut _, +        }; +    } +}  pub const PTHREAD_COND_INITIALIZER: pthread_cond_t = pthread_cond_t {      ptc_magic: 0x55550005, @@ -1018,10 +1356,58 @@ pub const SF_SNAPSHOT:  ::c_ulong = 0x00200000;  pub const SF_LOG:       ::c_ulong = 0x00400000;  pub const SF_SNAPINVAL: ::c_ulong = 0x00800000; -// dirfd() is a macro on netbsd to access -// the first field of the struct where dirp points to: -// http://cvsweb.netbsd.org/bsdweb.cgi/src/include/dirent.h?rev=1.36 +fn _ALIGN(p: usize) -> usize { +    (p + _ALIGNBYTES) & !_ALIGNBYTES +} +  f! { +    pub fn CMSG_DATA(cmsg: *const ::cmsghdr) -> *mut ::c_uchar { +        (cmsg as *mut ::c_uchar) +            .offset(_ALIGN(::mem::size_of::<::cmsghdr>()) as isize) +    } + +    pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint { +        _ALIGN(::mem::size_of::<::cmsghdr>()) as ::c_uint + length +    } + +    pub fn CMSG_NXTHDR(mhdr: *const ::msghdr, cmsg: *const ::cmsghdr) +        -> *mut ::cmsghdr +    { +        if cmsg.is_null() { +            return ::CMSG_FIRSTHDR(mhdr); +        }; +        let next = cmsg as usize + _ALIGN((*cmsg).cmsg_len as usize) +            + _ALIGN(::mem::size_of::<::cmsghdr>()); +        let max = (*mhdr).msg_control as usize +            + (*mhdr).msg_controllen as usize; +        if next > max { +            0 as *mut ::cmsghdr +        } else { +            (cmsg as usize + _ALIGN((*cmsg).cmsg_len as usize)) +                as *mut ::cmsghdr +        } +    } + +    pub fn CMSG_SPACE(length: ::c_uint) -> ::c_uint { +        (_ALIGN(::mem::size_of::<::cmsghdr>()) + _ALIGN(length as usize)) +            as ::c_uint +    } + +    pub fn WSTOPSIG(status: ::c_int) -> ::c_int { +        status >> 8 +    } + +    pub fn WIFSIGNALED(status: ::c_int) -> bool { +        (status & 0o177) != 0o177 && (status & 0o177) != 0 +    } + +    pub fn WIFSTOPPED(status: ::c_int) -> bool { +        (status & 0o177) == 0o177 +    } + +    // dirfd() is a macro on netbsd to access +    // the first field of the struct where dirp points to: +    // http://cvsweb.netbsd.org/bsdweb.cgi/src/include/dirent.h?rev=1.36      pub fn dirfd(dirp: *mut ::DIR) -> ::c_int {          *(dirp as *const ::c_int)      } @@ -1036,7 +1422,7 @@ f! {          } else {              0          }; -        mem::size_of::<sockcred>() + mem::size_of::<::gid_t>() * ngrps +        ::mem::size_of::<sockcred>() + ::mem::size_of::<::gid_t>() * ngrps      }  } @@ -1199,6 +1585,11 @@ extern {      pub fn settimeofday(tv: *const ::timeval, tz: *const ::c_void) -> ::c_int;      pub fn dup3(src: ::c_int, dst: ::c_int, flags: ::c_int) -> ::c_int; + +    pub fn sendmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::c_uint, +                    flags: ::c_int) -> ::c_int; +    pub fn recvmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::c_uint, +                    flags: ::c_int, timeout: *mut ::timespec) -> ::c_int;  }  #[link(name = "util")] diff --git a/libc/src/unix/bsd/netbsdlike/netbsd/powerpc.rs b/libc/src/unix/bsd/netbsdlike/netbsd/powerpc.rs index 3c682c3..e12fd5e 100644 --- a/libc/src/unix/bsd/netbsdlike/netbsd/powerpc.rs +++ b/libc/src/unix/bsd/netbsdlike/netbsd/powerpc.rs @@ -1,5 +1,3 @@ -use dox::mem; -  use PT_FIRSTMACH;  pub type c_long = i32; @@ -8,8 +6,15 @@ pub type c_char = u8;  pub type __cpu_simple_lock_nv_t = ::c_int;  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_double>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_double>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +}  pub const PT_STEP: ::c_int = PT_FIRSTMACH + 0;  pub const PT_GETREGS: ::c_int = PT_FIRSTMACH + 1; diff --git a/libc/src/unix/bsd/netbsdlike/netbsd/x86.rs b/libc/src/unix/bsd/netbsdlike/netbsd/x86.rs index 4da9968..daa89a1 100644 --- a/libc/src/unix/bsd/netbsdlike/netbsd/x86.rs +++ b/libc/src/unix/bsd/netbsdlike/netbsd/x86.rs @@ -1,10 +1,15 @@ -use dox::mem; -  pub type c_long = i32;  pub type c_ulong = u32;  pub type c_char = i8;  pub type __cpu_simple_lock_nv_t = ::c_uchar;  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_int>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_int>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 4 - 1; +    } +} diff --git a/libc/src/unix/bsd/netbsdlike/netbsd/x86_64.rs b/libc/src/unix/bsd/netbsdlike/netbsd/x86_64.rs index af1b8f8..0860d4f 100644 --- a/libc/src/unix/bsd/netbsdlike/netbsd/x86_64.rs +++ b/libc/src/unix/bsd/netbsdlike/netbsd/x86_64.rs @@ -1,5 +1,3 @@ -use dox::mem; -  use PT_FIRSTMACH;  pub type c_long = i64; @@ -8,8 +6,15 @@ pub type c_char = i8;  pub type __cpu_simple_lock_nv_t = ::c_uchar;  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_long>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_long>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +}  pub const PT_STEP: ::c_int = PT_FIRSTMACH + 0;  pub const PT_GETREGS: ::c_int = PT_FIRSTMACH + 1; diff --git a/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/mod.rs b/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/mod.rs deleted file mode 100644 index e5f0219..0000000 --- a/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/mod.rs +++ /dev/null @@ -1,113 +0,0 @@ -pub type c_char = i8; - -s! { -    pub struct lconv { -        pub decimal_point: *mut ::c_char, -        pub thousands_sep: *mut ::c_char, -        pub grouping: *mut ::c_char, -        pub int_curr_symbol: *mut ::c_char, -        pub currency_symbol: *mut ::c_char, -        pub mon_decimal_point: *mut ::c_char, -        pub mon_thousands_sep: *mut ::c_char, -        pub mon_grouping: *mut ::c_char, -        pub positive_sign: *mut ::c_char, -        pub negative_sign: *mut ::c_char, -        pub int_frac_digits: ::c_char, -        pub frac_digits: ::c_char, -        pub p_cs_precedes: ::c_char, -        pub p_sep_by_space: ::c_char, -        pub n_cs_precedes: ::c_char, -        pub n_sep_by_space: ::c_char, -        pub p_sign_posn: ::c_char, -        pub n_sign_posn: ::c_char, -        pub int_p_cs_precedes: ::c_char, -        pub int_n_cs_precedes: ::c_char, -        pub int_p_sep_by_space: ::c_char, -        pub int_n_sep_by_space: ::c_char, -        pub int_p_sign_posn: ::c_char, -        pub int_n_sign_posn: ::c_char, -    } -} - -pub const LC_COLLATE_MASK: ::c_int = (1 << 0); -pub const LC_CTYPE_MASK: ::c_int = (1 << 1); -pub const LC_MESSAGES_MASK: ::c_int = (1 << 2); -pub const LC_MONETARY_MASK: ::c_int = (1 << 3); -pub const LC_NUMERIC_MASK: ::c_int = (1 << 4); -pub const LC_TIME_MASK: ::c_int = (1 << 5); -pub const LC_ALL_MASK: ::c_int = LC_COLLATE_MASK -                               | LC_CTYPE_MASK -                               | LC_MESSAGES_MASK -                               | LC_MONETARY_MASK -                               | LC_NUMERIC_MASK -                               | LC_TIME_MASK; - -pub const ERA: ::nl_item = 52; -pub const ERA_D_FMT: ::nl_item = 53; -pub const ERA_D_T_FMT: ::nl_item = 54; -pub const ERA_T_FMT: ::nl_item = 55; -pub const ALT_DIGITS: ::nl_item = 56; - -pub const D_MD_ORDER: ::nl_item = 57; - -pub const ALTMON_1: ::nl_item = 58; -pub const ALTMON_2: ::nl_item = 59; -pub const ALTMON_3: ::nl_item = 60; -pub const ALTMON_4: ::nl_item = 61; -pub const ALTMON_5: ::nl_item = 62; -pub const ALTMON_6: ::nl_item = 63; -pub const ALTMON_7: ::nl_item = 64; -pub const ALTMON_8: ::nl_item = 65; -pub const ALTMON_9: ::nl_item = 66; -pub const ALTMON_10: ::nl_item = 67; -pub const ALTMON_11: ::nl_item = 68; -pub const ALTMON_12: ::nl_item = 69; - -pub const KERN_RND: ::c_int = 31; - -// https://github.com/bitrig/bitrig/blob/master/sys/net/if.h#L187 -pub const IFF_UP: ::c_int = 0x1; // interface is up -pub const IFF_BROADCAST: ::c_int = 0x2; // broadcast address valid -pub const IFF_DEBUG: ::c_int = 0x4; // turn on debugging -pub const IFF_LOOPBACK: ::c_int = 0x8; // is a loopback net -pub const IFF_POINTOPOINT: ::c_int = 0x10; // interface is point-to-point link -pub const IFF_NOTRAILERS: ::c_int = 0x20; // avoid use of trailers -pub const IFF_RUNNING: ::c_int = 0x40; // resources allocated -pub const IFF_NOARP: ::c_int = 0x80; // no address resolution protocol -pub const IFF_PROMISC: ::c_int = 0x100; // receive all packets -pub const IFF_ALLMULTI: ::c_int = 0x200; // receive all multicast packets -pub const IFF_OACTIVE: ::c_int = 0x400; // transmission in progress -pub const IFF_SIMPLEX: ::c_int = 0x800; // can't hear own transmissions -pub const IFF_LINK0: ::c_int = 0x1000; // per link layer defined bit -pub const IFF_LINK1: ::c_int = 0x2000; // per link layer defined bit -pub const IFF_LINK2: ::c_int = 0x4000; // per link layer defined bit -pub const IFF_MULTICAST: ::c_int = 0x8000; // supports multicast - -pub const SIGSTKSZ : ::size_t = 40960; - -pub const PT_FIRSTMACH: ::c_int = 32; - -extern { -    pub fn nl_langinfo_l(item: ::nl_item, locale: ::locale_t) -> *mut ::c_char; -    pub fn duplocale(base: ::locale_t) -> ::locale_t; -    pub fn freelocale(loc: ::locale_t) -> ::c_int; -    pub fn newlocale(mask: ::c_int, -                     locale: *const ::c_char, -                     base: ::locale_t) -> ::locale_t; -    pub fn uselocale(loc: ::locale_t) -> ::locale_t; -    pub fn pledge(promises: *const ::c_char, -                  paths: *mut *const ::c_char) -> ::c_int; -    pub fn querylocale(mask: ::c_int, loc: ::locale_t) -> *const ::c_char; -} - -cfg_if! { -    if #[cfg(target_arch = "x86")] { -        mod x86; -        pub use self::x86::*; -    } else if #[cfg(target_arch = "x86_64")] { -        mod x86_64; -        pub use self::x86_64::*; -    } else { -        // Unknown target_arch -    } -} diff --git a/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/x86.rs b/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/x86.rs deleted file mode 100644 index 9b0b338..0000000 --- a/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/x86.rs +++ /dev/null @@ -1,2 +0,0 @@ -pub type c_long = i32; -pub type c_ulong = u32; diff --git a/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/x86_64.rs b/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/x86_64.rs deleted file mode 100644 index d3971aa..0000000 --- a/libc/src/unix/bsd/netbsdlike/openbsdlike/bitrig/x86_64.rs +++ /dev/null @@ -1,10 +0,0 @@ -use PT_FIRSTMACH; - -pub type c_long = i64; -pub type c_ulong = u64; - -pub const PT_STEP: ::c_int = PT_FIRSTMACH + 0; -pub const PT_GETREGS: ::c_int = PT_FIRSTMACH + 1; -pub const PT_SETREGS: ::c_int = PT_FIRSTMACH + 2; -pub const PT_GETFPREGS: ::c_int = PT_FIRSTMACH + 3; -pub const PT_SETFPREGS: ::c_int = PT_FIRSTMACH + 4; diff --git a/libc/src/unix/bsd/netbsdlike/openbsdlike/mod.rs b/libc/src/unix/bsd/netbsdlike/openbsdlike/mod.rs index 1c2e47d..223064b 100644 --- a/libc/src/unix/bsd/netbsdlike/openbsdlike/mod.rs +++ b/libc/src/unix/bsd/netbsdlike/openbsdlike/mod.rs @@ -17,29 +17,21 @@ pub type pthread_rwlockattr_t = *mut ::c_void;  pub type caddr_t = *mut ::c_char;  s! { -    pub struct dirent { -        pub d_fileno: ::ino_t, -        pub d_off: ::off_t, -        pub d_reclen: u16, -        pub d_type: u8, -        pub d_namlen: u8, -        __d_padding: [u8; 4], -        pub d_name: [::c_char; 256], +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } + +    pub struct in_addr { +        pub s_addr: ::in_addr_t,      } -    pub struct glob_t { -        pub gl_pathc:   ::c_int, -        pub gl_matchc:  ::c_int, -        pub gl_offs:    ::c_int, -        pub gl_flags:   ::c_int, -        pub gl_pathv:   *mut *mut ::c_char, -        __unused1: *mut ::c_void, -        __unused2: *mut ::c_void, -        __unused3: *mut ::c_void, -        __unused4: *mut ::c_void, -        __unused5: *mut ::c_void, -        __unused6: *mut ::c_void, -        __unused7: *mut ::c_void, +    pub struct sockaddr_in { +        pub sin_len: u8, +        pub sin_family: ::sa_family_t, +        pub sin_port: ::in_port_t, +        pub sin_addr: ::in_addr, +        pub sin_zero: [::int8_t; 8],      }      pub struct kevent { @@ -99,25 +91,6 @@ s! {          pub ai_next: *mut ::addrinfo,      } -    pub struct sockaddr_storage { -        pub ss_len: u8, -        pub ss_family: ::sa_family_t, -        __ss_pad1: [u8; 6], -        __ss_pad2: i64, -        __ss_pad3: [u8; 240], -    } - -    pub struct siginfo_t { -        pub si_signo: ::c_int, -        pub si_code: ::c_int, -        pub si_errno: ::c_int, -        pub si_addr: *mut ::c_char, -        #[cfg(target_pointer_width = "32")] -        __pad: [u8; 112], -        #[cfg(target_pointer_width = "64")] -        __pad: [u8; 108], -    } -      pub struct Dl_info {          pub dli_fname: *const ::c_char,          pub dli_fbase: *mut ::c_void, @@ -125,19 +98,6 @@ s! {          pub dli_saddr: *mut ::c_void,      } -    pub struct lastlog { -        ll_time: ::time_t, -        ll_line: [::c_char; UT_LINESIZE], -        ll_host: [::c_char; UT_HOSTSIZE], -    } - -    pub struct utmp { -        pub ut_line: [::c_char; UT_LINESIZE], -        pub ut_name: [::c_char; UT_NAMESIZE], -        pub ut_host: [::c_char; UT_HOSTSIZE], -        pub ut_time: ::time_t, -    } -      pub struct if_data {          pub ifi_type: ::c_uchar,          pub ifi_addrlen: ::c_uchar, @@ -204,6 +164,230 @@ s! {      }  } +s_no_extra_traits! { +    pub struct dirent { +        pub d_fileno: ::ino_t, +        pub d_off: ::off_t, +        pub d_reclen: u16, +        pub d_type: u8, +        pub d_namlen: u8, +        __d_padding: [u8; 4], +        pub d_name: [::c_char; 256], +    } + +    pub struct sockaddr_storage { +        pub ss_len: u8, +        pub ss_family: ::sa_family_t, +        __ss_pad1: [u8; 6], +        __ss_pad2: i64, +        __ss_pad3: [u8; 240], +    } + +    pub struct siginfo_t { +        pub si_signo: ::c_int, +        pub si_code: ::c_int, +        pub si_errno: ::c_int, +        pub si_addr: *mut ::c_char, +        #[cfg(target_pointer_width = "32")] +        __pad: [u8; 112], +        #[cfg(target_pointer_width = "64")] +        __pad: [u8; 108], +    } + +    pub struct lastlog { +        ll_time: ::time_t, +        ll_line: [::c_char; UT_LINESIZE], +        ll_host: [::c_char; UT_HOSTSIZE], +    } + +    pub struct utmp { +        pub ut_line: [::c_char; UT_LINESIZE], +        pub ut_name: [::c_char; UT_NAMESIZE], +        pub ut_host: [::c_char; UT_HOSTSIZE], +        pub ut_time: ::time_t, +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_fileno == other.d_fileno +                    && self.d_off == other.d_off +                    && self.d_reclen == other.d_reclen +                    && self.d_type == other.d_type +                    && self.d_namlen == other.d_namlen +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for dirent {} + +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_fileno", &self.d_fileno) +                    .field("d_off", &self.d_off) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_type", &self.d_type) +                    .field("d_namlen", &self.d_namlen) +                // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } + +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_fileno.hash(state); +                self.d_off.hash(state); +                self.d_reclen.hash(state); +                self.d_type.hash(state); +                self.d_namlen.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for sockaddr_storage { +            fn eq(&self, other: &sockaddr_storage) -> bool { +                self.ss_len == other.ss_len +                    && self.ss_family == other.ss_family +            } +        } + +        impl Eq for sockaddr_storage {} + +        impl ::fmt::Debug for sockaddr_storage { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_storage") +                    .field("ss_len", &self.ss_len) +                    .field("ss_family", &self.ss_family) +                    .finish() +            } +        } + +        impl ::hash::Hash for sockaddr_storage { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ss_len.hash(state); +                self.ss_family.hash(state); +            } +        } + +        impl PartialEq for siginfo_t { +            fn eq(&self, other: &siginfo_t) -> bool { +                self.si_signo == other.si_signo +                    && self.si_code == other.si_code +                    && self.si_errno == other.si_errno +                    && self.si_addr == other.si_addr +            } +        } + +        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_code", &self.si_code) +                    .field("si_errno", &self.si_errno) +                    .field("si_addr", &self.si_addr) +                    .finish() +            } +        } + +        impl ::hash::Hash for siginfo_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.si_signo.hash(state); +                self.si_code.hash(state); +                self.si_errno.hash(state); +                self.si_addr.hash(state); +            } +        } + +        impl PartialEq for lastlog { +            fn eq(&self, other: &lastlog) -> bool { +                self.ll_time == other.ll_time +                    && self +                    .ll_line +                    .iter() +                    .zip(other.ll_line.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .ll_host +                    .iter() +                    .zip(other.ll_host.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for lastlog {} + +        impl ::fmt::Debug for lastlog { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("lastlog") +                    .field("ll_time", &self.ll_time) +                // FIXME: .field("ll_line", &self.ll_line) +                // FIXME: .field("ll_host", &self.ll_host) +                    .finish() +            } +        } + +        impl ::hash::Hash for lastlog { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ll_time.hash(state); +                self.ll_line.hash(state); +                self.ll_host.hash(state); +            } +        } + +        impl PartialEq for utmp { +            fn eq(&self, other: &utmp) -> bool { +                self.ut_time == other.ut_time +                    && self +                    .ut_line +                    .iter() +                    .zip(other.ut_line.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .ut_name +                    .iter() +                    .zip(other.ut_name.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .ut_host +                    .iter() +                    .zip(other.ut_host.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for utmp {} + +        impl ::fmt::Debug for utmp { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utmp") +                // FIXME: .field("ut_line", &self.ut_line) +                // FIXME: .field("ut_name", &self.ut_name) +                // FIXME: .field("ut_host", &self.ut_host) +                    .field("ut_time", &self.ut_time) +                    .finish() +            } +        } + +        impl ::hash::Hash for utmp { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ut_line.hash(state); +                self.ut_name.hash(state); +                self.ut_host.hash(state); +                self.ut_time.hash(state); +            } +        } +    } +} +  pub const UT_NAMESIZE: usize = 32;  pub const UT_LINESIZE: usize = 8;  pub const UT_HOSTSIZE: usize = 256; @@ -215,8 +399,6 @@ pub const O_RSYNC: ::c_int = O_SYNC;  pub const MS_SYNC : ::c_int = 0x0002;  pub const MS_INVALIDATE : ::c_int = 0x0004; -pub const PTHREAD_STACK_MIN : ::size_t = 2048; -  pub const POLLNORM: ::c_short = ::POLLRDNORM;  pub const ENOATTR : ::c_int = 83; @@ -757,9 +939,6 @@ cfg_if! {      if #[cfg(target_os = "openbsd")] {          mod openbsd;          pub use self::openbsd::*; -    } else if #[cfg(target_os = "bitrig")] { -        mod bitrig; -        pub use self::bitrig::*;      } else {          // Unknown target_os      } diff --git a/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/aarch64.rs b/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/aarch64.rs index 2a28c2a..6a8cbb5 100644 --- a/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/aarch64.rs +++ b/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/aarch64.rs @@ -1,9 +1,14 @@ -use dox::mem; -  pub type c_long = i64;  pub type c_ulong = u64;  pub type c_char = u8;  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_long>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_long>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +} diff --git a/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/mod.rs b/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/mod.rs index a2a7a30..c168711 100644 --- a/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/mod.rs +++ b/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/mod.rs @@ -1,4 +1,19 @@  s! { +    pub struct glob_t { +        pub gl_pathc:   ::size_t, +        pub gl_matchc:  ::size_t, +        pub gl_offs:    ::size_t, +        pub gl_flags:   ::c_int, +        pub gl_pathv:   *mut *mut ::c_char, +        __unused1: *mut ::c_void, +        __unused2: *mut ::c_void, +        __unused3: *mut ::c_void, +        __unused4: *mut ::c_void, +        __unused5: *mut ::c_void, +        __unused6: *mut ::c_void, +        __unused7: *mut ::c_void, +    } +      pub struct lconv {          pub decimal_point: *mut ::c_char,          pub thousands_sep: *mut ::c_char, @@ -26,42 +41,6 @@ s! {          pub int_n_sign_posn: ::c_char,      } -    pub struct statfs { -        pub f_flags: ::uint32_t, -        pub f_bsize: ::uint32_t, -        pub f_iosize: ::uint32_t, -        pub f_blocks: ::uint64_t, -        pub f_bfree: ::uint64_t, -        pub f_bavail: ::int64_t, -        pub f_files: ::uint64_t, -        pub f_ffree: ::uint64_t, -        pub f_favail: ::int64_t, -        pub f_syncwrites: ::uint64_t, -        pub f_syncreads: ::uint64_t, -        pub f_asyncwrites: ::uint64_t, -        pub f_asyncreads: ::uint64_t, -        pub f_fsid: ::fsid_t, -        pub f_namemax: ::uint32_t, -        pub f_owner: ::uid_t, -        pub f_ctime: ::uint64_t, -        pub f_fstypename: [::c_char; 16], -        pub f_mntonname: [::c_char; 90], -        pub f_mntfromname: [::c_char; 90], -        pub f_mntfromspec: [::c_char; 90], -        pub mount_info: mount_info, -    } - -    pub union mount_info { -        pub ufs_args: ufs_args, -        pub mfs_args: mfs_args, -        pub nfs_args: nfs_args, -        pub iso_args: iso_args, -        pub msdosfs_args: msdosfs_args, -        pub ntfs_args: ntfs_args, -        pub tmpfs_args: tmpfs_args, -        align: [::c_char; 160], -    } -      pub struct ufs_args {          pub fspec: *mut ::c_char,          pub export_info: export_args, @@ -165,6 +144,184 @@ s! {      }  } +s_no_extra_traits! { +    pub union mount_info { +        pub ufs_args: ufs_args, +        pub mfs_args: mfs_args, +        pub nfs_args: nfs_args, +        pub iso_args: iso_args, +        pub msdosfs_args: msdosfs_args, +        pub ntfs_args: ntfs_args, +        pub tmpfs_args: tmpfs_args, +        align: [::c_char; 160], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for mount_info { +            fn eq(&self, other: &mount_info) -> bool { +                unsafe { +                    self.align +                        .iter() +                        .zip(other.align.iter()) +                        .all(|(a,b)| a == b) +                } +            } +        } + +        impl Eq for mount_info { } + +        impl ::fmt::Debug for mount_info { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("mount_info") +                // FIXME: .field("align", &self.align) +                    .finish() +            } +        } + +        impl ::hash::Hash for mount_info { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                unsafe { self.align.hash(state) }; +            } +        } +    } +} + +cfg_if! { +    if #[cfg(libc_union)] { +        s_no_extra_traits! { +            // This type uses the union mount_info: +            pub struct statfs { +                pub f_flags: ::uint32_t, +                pub f_bsize: ::uint32_t, +                pub f_iosize: ::uint32_t, +                pub f_blocks: ::uint64_t, +                pub f_bfree: ::uint64_t, +                pub f_bavail: ::int64_t, +                pub f_files: ::uint64_t, +                pub f_ffree: ::uint64_t, +                pub f_favail: ::int64_t, +                pub f_syncwrites: ::uint64_t, +                pub f_syncreads: ::uint64_t, +                pub f_asyncwrites: ::uint64_t, +                pub f_asyncreads: ::uint64_t, +                pub f_fsid: ::fsid_t, +                pub f_namemax: ::uint32_t, +                pub f_owner: ::uid_t, +                pub f_ctime: ::uint64_t, +                pub f_fstypename: [::c_char; 16], +                pub f_mntonname: [::c_char; 90], +                pub f_mntfromname: [::c_char; 90], +                pub f_mntfromspec: [::c_char; 90], +                pub mount_info: mount_info, +            } +        } + +        cfg_if! { +            if #[cfg(feature = "extra_traits")] { +                impl PartialEq for statfs { +                    fn eq(&self, other: &statfs) -> bool { +                        self.f_flags == other.f_flags +                            && self.f_bsize == other.f_bsize +                            && self.f_iosize == other.f_iosize +                            && self.f_blocks == other.f_blocks +                            && self.f_bfree == other.f_bfree +                            && self.f_bavail == other.f_bavail +                            && self.f_files == other.f_files +                            && self.f_ffree == other.f_ffree +                            && self.f_favail == other.f_favail +                            && self.f_syncwrites == other.f_syncwrites +                            && self.f_syncreads == other.f_syncreads +                            && self.f_asyncwrites == other.f_asyncwrites +                            && self.f_asyncreads == other.f_asyncreads +                            && self.f_fsid == other.f_fsid +                            && self.f_namemax == other.f_namemax +                            && self.f_owner == other.f_owner +                            && self.f_ctime == other.f_ctime +                            && self.f_fstypename +                            .iter() +                            .zip(other.f_fstypename.iter()) +                            .all(|(a,b)| a == b) +                            && self.f_mntonname +                            .iter() +                            .zip(other.f_mntonname.iter()) +                            .all(|(a,b)| a == b) +                            && self.f_mntfromname +                            .iter() +                            .zip(other.f_mntfromname.iter()) +                            .all(|(a,b)| a == b) +                            && self.f_mntfromspec +                            .iter() +                            .zip(other.f_mntfromspec.iter()) +                            .all(|(a,b)| a == b) +                            && self.mount_info == other.mount_info +                    } +                } + +                impl Eq for statfs { } + +                impl ::fmt::Debug for statfs { +                    fn fmt(&self, f: &mut ::fmt::Formatter) +                           -> ::fmt::Result { +                        f.debug_struct("statfs") +                            .field("f_flags", &self.f_flags) +                            .field("f_bsize", &self.f_bsize) +                            .field("f_iosize", &self.f_iosize) +                            .field("f_blocks", &self.f_blocks) +                            .field("f_bfree", &self.f_bfree) +                            .field("f_bavail", &self.f_bavail) +                            .field("f_files", &self.f_files) +                            .field("f_ffree", &self.f_ffree) +                            .field("f_favail", &self.f_favail) +                            .field("f_syncwrites", &self.f_syncwrites) +                            .field("f_syncreads", &self.f_syncreads) +                            .field("f_asyncwrites", &self.f_asyncwrites) +                            .field("f_asyncreads", &self.f_asyncreads) +                            .field("f_fsid", &self.f_fsid) +                            .field("f_namemax", &self.f_namemax) +                            .field("f_owner", &self.f_owner) +                            .field("f_ctime", &self.f_ctime) +                        // FIXME: .field("f_fstypename", &self.f_fstypename) +                        // FIXME: .field("f_mntonname", &self.f_mntonname) +                        // FIXME: .field("f_mntfromname", &self.f_mntfromname) +                        // FIXME: .field("f_mntfromspec", &self.f_mntfromspec) +                            .field("mount_info", &self.mount_info) +                            .finish() +                    } +                } + +                impl ::hash::Hash for statfs { +                    fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                        self.f_flags.hash(state); +                        self.f_bsize.hash(state); +                        self.f_iosize.hash(state); +                        self.f_blocks.hash(state); +                        self.f_bfree.hash(state); +                        self.f_bavail.hash(state); +                        self.f_files.hash(state); +                        self.f_ffree.hash(state); +                        self.f_favail.hash(state); +                        self.f_syncwrites.hash(state); +                        self.f_syncreads.hash(state); +                        self.f_asyncwrites.hash(state); +                        self.f_asyncreads.hash(state); +                        self.f_fsid.hash(state); +                        self.f_namemax.hash(state); +                        self.f_owner.hash(state); +                        self.f_ctime.hash(state); +                        self.f_fstypename.hash(state); +                        self.f_mntonname.hash(state); +                        self.f_mntfromname.hash(state); +                        self.f_mntfromspec.hash(state); +                        self.mount_info.hash(state); +                    } +                } +            } +        } +    } +} +  //https://github.com/openbsd/src/blob/master/sys/sys/mount.h  pub const ISOFSMNT_NORRIP: ::c_int = 0x1; // disable Rock Ridge Ext  pub const ISOFSMNT_GENS: ::c_int = 0x2; // enable generation numbers @@ -246,10 +403,61 @@ pub const IFF_LINK1: ::c_int = 0x2000; // per link layer defined bit  pub const IFF_LINK2: ::c_int = 0x4000; // per link layer defined bit  pub const IFF_MULTICAST: ::c_int = 0x8000; // supports multicast +pub const PTHREAD_STACK_MIN : ::size_t = 4096;  pub const SIGSTKSZ : ::size_t = 28672;  pub const PT_FIRSTMACH: ::c_int = 32; +fn _ALIGN(p: usize) -> usize { +    (p + _ALIGNBYTES) & !_ALIGNBYTES +} + +f! { +    pub fn CMSG_DATA(cmsg: *const ::cmsghdr) -> *mut ::c_uchar { +        (cmsg as *mut ::c_uchar) +            .offset(_ALIGN(::mem::size_of::<::cmsghdr>()) as isize) +    } + +    pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint { +        _ALIGN(::mem::size_of::<::cmsghdr>()) as ::c_uint + length +    } + +    pub fn CMSG_NXTHDR(mhdr: *const ::msghdr, cmsg: *const ::cmsghdr) +        -> *mut ::cmsghdr +    { +        if cmsg.is_null() { +            return ::CMSG_FIRSTHDR(mhdr); +        }; +        let next = cmsg as usize + _ALIGN((*cmsg).cmsg_len as usize) +            + _ALIGN(::mem::size_of::<::cmsghdr>()); +        let max = (*mhdr).msg_control as usize +            + (*mhdr).msg_controllen as usize; +        if next > max { +            0 as *mut ::cmsghdr +        } else { +            (cmsg as usize + _ALIGN((*cmsg).cmsg_len as usize)) +                as *mut ::cmsghdr +        } +    } + +    pub fn CMSG_SPACE(length: ::c_uint) -> ::c_uint { +        (_ALIGN(::mem::size_of::<::cmsghdr>()) + _ALIGN(length as usize)) +            as ::c_uint +    } + +    pub fn WSTOPSIG(status: ::c_int) -> ::c_int { +        status >> 8 +    } + +    pub fn WIFSIGNALED(status: ::c_int) -> bool { +        (status & 0o177) != 0o177 && (status & 0o177) != 0 +    } + +    pub fn WIFSTOPPED(status: ::c_int) -> bool { +        (status & 0o177) == 0o177 +    } +} +  extern {      pub fn accept4(s: ::c_int, addr: *mut ::sockaddr,                     addrlen: *mut ::socklen_t, flags: ::c_int) -> ::c_int; @@ -260,14 +468,20 @@ extern {      pub fn strtonum(nptr: *const ::c_char, minval: ::c_longlong,                      maxval: ::c_longlong,                      errstr: *mut *const ::c_char) -> ::c_longlong; - -    pub fn statfs(path: *const ::c_char, buf: *mut statfs) -> ::c_int; -    pub fn fstatfs(fd: ::c_int, buf: *mut statfs) -> ::c_int; -      pub fn dup3(src: ::c_int, dst: ::c_int, flags: ::c_int) -> ::c_int;  }  cfg_if! { +    if #[cfg(libc_union)] { +        extern { +            // these functions use statfs which uses the union mount_info: +            pub fn statfs(path: *const ::c_char, buf: *mut statfs) -> ::c_int; +            pub fn fstatfs(fd: ::c_int, buf: *mut statfs) -> ::c_int; +        } +    } +} + +cfg_if! {      if #[cfg(target_arch = "x86")] {          mod x86;          pub use self::x86::*; diff --git a/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/x86.rs b/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/x86.rs index b63b69f..05538cd 100644 --- a/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/x86.rs +++ b/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/x86.rs @@ -1,9 +1,14 @@ -use dox::mem; -  pub type c_long = i32;  pub type c_ulong = u32;  pub type c_char = i8;  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_int>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_int>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 4 - 1; +    } +} diff --git a/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/x86_64.rs b/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/x86_64.rs index 581096f..7daa9d8 100644 --- a/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/x86_64.rs +++ b/libc/src/unix/bsd/netbsdlike/openbsdlike/openbsd/x86_64.rs @@ -1,5 +1,3 @@ -use dox::mem; -  use PT_FIRSTMACH;  pub type c_long = i64; @@ -7,8 +5,15 @@ pub type c_ulong = u64;  pub type c_char = i8;  // should be pub(crate), but that requires Rust 1.18.0 -#[doc(hidden)] -pub const _ALIGNBYTES: usize = mem::size_of::<::c_long>() - 1; +cfg_if! { +    if #[cfg(libc_const_size_of)] { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = ::mem::size_of::<::c_long>() - 1; +    } else { +        #[doc(hidden)] +        pub const _ALIGNBYTES: usize = 8 - 1; +    } +}  pub const PT_STEP: ::c_int = PT_FIRSTMACH + 0;  pub const PT_GETREGS: ::c_int = PT_FIRSTMACH + 1; diff --git a/libc/src/unix/haiku/mod.rs b/libc/src/unix/haiku/mod.rs index 2aa5d13..26519a4 100644 --- a/libc/src/unix/haiku/mod.rs +++ b/libc/src/unix/haiku/mod.rs @@ -1,5 +1,3 @@ -use dox::{mem, Option}; -  pub type rlim_t = ::uintptr_t;  pub type sa_family_t = u8;  pub type pthread_key_t = ::c_int; @@ -31,9 +29,23 @@ pub type nl_item = ::c_int;  pub type id_t = i32;  pub type idtype_t = ::c_uint; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum timezone {} +impl ::Copy for timezone {} +impl ::Clone for timezone { +    fn clone(&self) -> timezone { *self } +}  s! { +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } + +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } +      pub struct sockaddr {          pub sa_len: u8,          pub sa_family: sa_family_t, @@ -57,20 +69,6 @@ s! {          pub sin6_scope_id: u32,      } -    pub struct sockaddr_un { -        pub sun_len: u8, -        pub sun_family: sa_family_t, -        pub sun_path: [::c_char; 126] -    } - -    pub struct sockaddr_storage { -        pub ss_len: u8, -        pub ss_family: sa_family_t, -        __ss_pad1: [u8; 6], -        __ss_pad2: u64, -        __ss_pad3: [u8; 112], -    } -      pub struct addrinfo {          pub ai_flags: ::c_int,          pub ai_family: ::c_int, @@ -199,15 +197,6 @@ s! {          pub st_blocks: blkcnt_t,      } -    pub struct dirent { -        pub d_dev: dev_t, -        pub d_pdev: dev_t, -        pub d_ino: ino_t, -        pub d_pino: i64, -        pub d_reclen: ::c_ushort, -        pub d_name: [::c_char; 1024], // Max length is _POSIX_PATH_MAX -    } -      pub struct glob_t {          pub gl_pathc: ::size_t,          __unused1: ::size_t, @@ -319,6 +308,139 @@ s! {      }  } +s_no_extra_traits! { +    pub struct sockaddr_un { +        pub sun_len: u8, +        pub sun_family: sa_family_t, +        pub sun_path: [::c_char; 126] +    } +    pub struct sockaddr_storage { +        pub ss_len: u8, +        pub ss_family: sa_family_t, +        __ss_pad1: [u8; 6], +        __ss_pad2: u64, +        __ss_pad3: [u8; 112], +    } +    pub struct dirent { +        pub d_dev: dev_t, +        pub d_pdev: dev_t, +        pub d_ino: ino_t, +        pub d_pino: i64, +        pub d_reclen: ::c_ushort, +        pub d_name: [::c_char; 1024], // Max length is _POSIX_PATH_MAX +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for sockaddr_un { +            fn eq(&self, other: &sockaddr_un) -> bool { +                self.sun_len == other.sun_len +                    && self.sun_family == other.sun_family +                    && self +                    .sun_path +                    .iter() +                    .zip(other.sun_path.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sockaddr_un {} +        impl ::fmt::Debug for sockaddr_un { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_un") +                    .field("sun_len", &self.sun_len) +                    .field("sun_family", &self.sun_family) +                    // FIXME: .field("sun_path", &self.sun_path) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_un { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sun_len.hash(state); +                self.sun_family.hash(state); +                self.sun_path.hash(state); +            } +        } + +        impl PartialEq for sockaddr_storage { +            fn eq(&self, other: &sockaddr_storage) -> bool { +                self.ss_len == other.ss_len +                    && self.ss_family == other.ss_family +                    && self +                    .__ss_pad1 +                    .iter() +                    .zip(other.__ss_pad1.iter()) +                    .all(|(a, b)| a == b) +                    && self.__ss_pad2 == other.__ss_pad2 +                    && self +                    .__ss_pad3 +                    .iter() +                    .zip(other.__ss_pad3.iter()) +                    .all(|(a, b)| a == b) +            } +        } +        impl Eq for sockaddr_storage {} +        impl ::fmt::Debug for sockaddr_storage { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_storage") +                    .field("ss_len", &self.ss_len) +                    .field("ss_family", &self.ss_family) +                    .field("__ss_pad1", &self.__ss_pad1) +                    .field("__ss_pad2", &self.__ss_pad2) +                    // FIXME: .field("__ss_pad3", &self.__ss_pad3) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_storage { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ss_len.hash(state); +                self.ss_family.hash(state); +                self.__ss_pad1.hash(state); +                self.__ss_pad2.hash(state); +                self.__ss_pad3.hash(state); +            } +        } + +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_dev == other.d_dev +                    && self.d_pdev == other.d_pdev +                    && self.d_ino == other.d_ino +                    && self.d_pino == other.d_pino +                    && self.d_reclen == other.d_reclen +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for dirent {} +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_dev", &self.d_dev) +                    .field("d_pdev", &self.d_pdev) +                    .field("d_ino", &self.d_ino) +                    .field("d_pino", &self.d_pino) +                    .field("d_reclen", &self.d_reclen) +                    // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_dev.hash(state); +                self.d_pdev.hash(state); +                self.d_ino.hash(state); +                self.d_pino.hash(state); +                self.d_reclen.hash(state); +                self.d_name.hash(state); +            } +        } +    } +} +  // intentionally not public, only used for fd_set  cfg_if! {      if #[cfg(target_pointer_width = "32")] { @@ -1028,20 +1150,20 @@ pub const TCIOFLUSH: ::c_int = 0x03;  f! {      pub fn FD_CLR(fd: ::c_int, set: *mut fd_set) -> () {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          (*set).fds_bits[fd / size] &= !(1 << (fd % size));          return      }      pub fn FD_ISSET(fd: ::c_int, set: *mut fd_set) -> bool {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          return ((*set).fds_bits[fd / size] & (1 << (fd % size))) != 0      }      pub fn FD_SET(fd: ::c_int, set: *mut fd_set) -> () {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          (*set).fds_bits[fd / size] |= 1 << (fd % size);          return      } @@ -1096,6 +1218,12 @@ extern {  #[link(name = "bsd")]  extern { +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int; +      pub fn clock_gettime(clk_id: ::c_int, tp: *mut ::timespec) -> ::c_int;      pub fn clock_settime(clk_id: ::c_int, tp: *const ::timespec) -> ::c_int;      pub fn pthread_create(thread: *mut ::pthread_t, @@ -1132,7 +1260,7 @@ extern {      pub fn glob(pattern: *const ::c_char,                  flags: ::c_int, -                errfunc: Option<extern fn(epath: *const ::c_char, +                errfunc: ::Option<extern fn(epath: *const ::c_char,                                            errno: ::c_int) -> ::c_int>,                  pglob: *mut ::glob_t) -> ::c_int;      pub fn globfree(pglob: *mut ::glob_t); @@ -1178,7 +1306,7 @@ extern {      pub fn execvpe(file: *const ::c_char, argv: *const *const ::c_char,                     environment: *const *const ::c_char) -> ::c_int;      #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrgid_r")] -    pub fn getgrgid_r(uid: ::uid_t, +    pub fn getgrgid_r(gid: ::gid_t,                        grp: *mut ::group,                        buf: *mut ::c_char,                        buflen: ::size_t, @@ -1224,9 +1352,9 @@ extern {      #[cfg_attr(target_os = "solaris", link_name = "__posix_sigwait")]      pub fn sigwait(set: *const sigset_t,                     sig: *mut ::c_int) -> ::c_int; -    pub fn pthread_atfork(prepare: Option<unsafe extern fn()>, -                          parent: Option<unsafe extern fn()>, -                          child: Option<unsafe extern fn()>) -> ::c_int; +    pub fn pthread_atfork(prepare: ::Option<unsafe extern fn()>, +                          parent: ::Option<unsafe extern fn()>, +                          child: ::Option<unsafe extern fn()>) -> ::c_int;      pub fn getgrgid(gid: ::gid_t) -> *mut ::group;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "popen$UNIX2003")] diff --git a/libc/src/unix/hermit/mod.rs b/libc/src/unix/hermit/mod.rs index ba7a90f..288cc46 100644 --- a/libc/src/unix/hermit/mod.rs +++ b/libc/src/unix/hermit/mod.rs @@ -19,8 +19,6 @@  pub type c_long = i64;  pub type c_ulong = u64; -pub type uid_t = u16; -pub type gid_t = u16;  pub type speed_t = ::c_uint;  pub type mode_t = u32;  pub type dev_t = i16; @@ -49,7 +47,336 @@ pub type pthread_mutexattr_t = usize;  pub type pthread_rwlock_t = usize;  pub type pthread_rwlockattr_t = usize; +s_no_extra_traits! { +    pub struct dirent { +        pub d_ino: ::c_long, +        pub d_off: off_t, +        pub d_reclen: u16, +        pub d_name: [::c_char; 256], +    } + +    // Dummy +    pub struct sockaddr_un { +        pub sun_family: sa_family_t, +        pub sun_path: [::c_char; 108], +    } + +    pub struct sockaddr { +        pub sa_len: u8, +        pub sa_family: sa_family_t, +        pub sa_data: [::c_char; 14], +    } + +    pub struct sockaddr_in { +        pub sin_len: u8, +        pub sin_family: sa_family_t, +        pub sin_port: ::in_port_t, +        pub sin_addr: ::in_addr, +        pub sin_zero: [::c_char; 8], +    } + +    pub struct fd_set { +        fds_bits: [::c_ulong; FD_SETSIZE / ULONG_SIZE], +    } + +    pub struct sockaddr_storage { +        pub s2_len: u8, +        pub ss_family: sa_family_t, +        pub s2_data1: [::c_char; 2], +        pub s2_data2: [u32; 3], +        pub s2_data3: [u32; 3], +    } + +    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_uid: ::uid_t, +        pub st_gid: ::gid_t, +        pub st_rdev: dev_t, +        pub st_size: off_t, +        pub st_atime: time_t, +        pub st_atime_nsec: ::c_long, +        pub st_mtime: time_t, +        pub st_mtime_nsec: ::c_long, +        pub st_ctime: time_t, +        pub st_ctime_nsec: ::c_long, +        pub st_blksize: blksize_t, +        pub st_blocks: blkcnt_t, +        pub st_spare4: [::c_long; 2], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_ino == other.d_ino +                    && self.d_off == other.d_off +                    && self.d_reclen == other.d_reclen +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for dirent {} +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_ino", &self.d_ino) +                    .field("d_off", &self.d_off) +                    .field("d_reclen", &self.d_reclen) +                    // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_ino.hash(state); +                self.d_off.hash(state); +                self.d_reclen.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for sockaddr_un { +            fn eq(&self, other: &sockaddr_un) -> bool { +                self.sun_family == other.sun_family +                    && self +                    .sun_path +                    .iter() +                    .zip(other.sun_path.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sockaddr_un {} +        impl ::fmt::Debug for sockaddr_un { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_un") +                    .field("sun_family", &self.sun_family) +                    // FIXME: .field("sun_path", &self.sun_path) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_un { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sun_family.hash(state); +                self.sun_path.hash(state); +            } +        } + +        impl PartialEq for sockaddr { +            fn eq(&self, other: &sockaddr) -> bool { +                self.sa_len == other.sa_len +                    && self.sa_family == other.sa_family +                    && self +                    .sa_data +                    .iter() +                    .zip(other.sa_data.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sockaddr {} +        impl ::fmt::Debug for sockaddr { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr") +                    .field("sa_len", &self.sa_len) +                    .field("sa_family", &self.sa_family) +                    // FIXME: .field("sa_data", &self.sa_data) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sa_len.hash(state); +                self.sa_family.hash(state); +                self.sa_data.hash(state); +            } +        } + +        impl PartialEq for sockaddr_in { +            fn eq(&self, other: &sockaddr_in) -> bool { +                self.sin_len == other.sin_len +                    && self.sin_family == other.sin_family +                    && self.sin_port == other.sin_port +                    && self.sin_addr == other.sin_addr +                    && self +                    .sin_zero +                    .iter() +                    .zip(other.sin_zero.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sockaddr_in {} +        impl ::fmt::Debug for sockaddr_in { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_in") +                    .field("sin_len", &self.sin_len) +                    .field("sin_family", &self.sin_family) +                    .field("sin_port", &self.sin_port) +                    .field("sin_addr", &self.sin_addr) +                    // FIXME: .field("sin_zero", &self.sin_zero) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_in { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sin_len.hash(state); +                self.sin_family.hash(state); +                self.sin_port.hash(state); +                self.sin_addr.hash(state); +                self.sin_zero.hash(state); +            } +        } + +        impl PartialEq for fd_set { +            fn eq(&self, other: &fd_set) -> bool { +                self.fds_bits +                    .iter() +                    .zip(other.fds_bits.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for fd_set {} +        impl ::fmt::Debug for fd_set { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("fd_set") +                    // FIXME: .field("fds_bits", &self.fds_bits) +                    .finish() +            } +        } +        impl ::hash::Hash for fd_set { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.fds_bits.hash(state); +            } +        } + +        impl PartialEq for sockaddr_storage { +            fn eq(&self, other: &sockaddr_storage) -> bool { +                self.s2_len == other.s2_len +                    && self.ss_family == other.ss_family +                    && self.s2_data1 +                    .iter() +                    .zip(other.s2_data1.iter()) +                    .all(|(a,b)| a == b) +                    && self.s2_data2 +                    .iter() +                    .zip(other.s2_data2.iter()) +                    .all(|(a,b)| a == b) +                    && self.s2_data3 +                    .iter() +                    .zip(other.s2_data3.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sockaddr_storage {} +        impl ::fmt::Debug for sockaddr_storage { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_storage") +                    .field("s2_len", &self.s2_len) +                    .field("ss_family", &self.ss_family) +                    // FIXME: .field("s2_data1", &self.s2_data1) +                    // FIXME: .field("s2_data2", &self.s2_data2) +                    // FIXME: .field("s2_data3", &self.s2_data3) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_storage { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.s2_len.hash(state); +                self.ss_family.hash(state); +                self.s2_data1.hash(state); +                self.s2_data2.hash(state); +                self.s2_data3.hash(state); +            } +        } + +        impl PartialEq for stat { +            fn eq(&self, other: &stat) -> bool { +                self.st_dev == other.st_dev +                    && self.st_ino == other.st_ino +                    && self.st_mode == other.st_mode +                    && self.st_nlink == other.st_nlink +                    && self.st_uid == other.st_uid +                    && self.st_gid == other.st_gid +                    && self.st_rdev == other.st_rdev +                    && self.st_size == other.st_size +                    && self.st_atime == other.st_atime +                    && self.st_atime_nsec == other.st_atime_nsec +                    && self.st_mtime == other.st_mtime +                    && self.st_mtime_nsec == other.st_mtime_nsec +                    && self.st_ctime == other.st_ctime +                    && self.st_ctime_nsec == other.st_ctime_nsec +                    && self.st_blksize == other.st_blksize +                    && self.st_blocks == other.st_blocks +                    && self +                    .st_spare4 +                    .iter() +                    .zip(other.st_spare4.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for stat {} +        impl ::fmt::Debug for stat { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("stat") +                    .field("st_dev", &self.st_dev) +                    .field("st_ino", &self.st_ino) +                    .field("st_mode", &self.st_mode) +                    .field("st_nlink", &self.st_nlink) +                    .field("st_uid", &self.st_uid) +                    .field("st_gid", &self.st_gid) +                    .field("st_rdev", &self.st_rdev) +                    .field("st_size", &self.st_size) +                    .field("st_atime", &self.st_atime) +                    .field("st_atime_nsec", &self.st_atime_nsec) +                    .field("st_mtime", &self.st_mtime) +                    .field("st_mtime_nsec", &self.st_mtime_nsec) +                    .field("st_ctime", &self.st_ctime) +                    .field("st_ctime_nsec", &self.st_ctime_nsec) +                    .field("st_blksize", &self.st_blksize) +                    .field("st_blocks", &self.st_blocks) +                    // FIXME: .field("st_spare4", &self.st_spare4) +                    .finish() +            } +        } +        impl ::hash::Hash for stat { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.st_dev.hash(state); +                self.st_ino.hash(state); +                self.st_mode.hash(state); +                self.st_nlink.hash(state); +                self.st_uid.hash(state); +                self.st_gid.hash(state); +                self.st_rdev.hash(state); +                self.st_size.hash(state); +                self.st_atime.hash(state); +                self.st_atime_nsec.hash(state); +                self.st_mtime.hash(state); +                self.st_mtime_nsec.hash(state); +                self.st_ctime.hash(state); +                self.st_ctime_nsec.hash(state); +                self.st_blksize.hash(state); +                self.st_blocks.hash(state); +                self.st_spare4.hash(state); +            } +        } +    } +} +  s! { +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } + +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } +      pub struct addrinfo {          pub ai_flags: ::c_int,          pub ai_family: ::c_int, @@ -61,19 +388,8 @@ s! {          pub ai_next: *mut addrinfo,      } -    pub struct dirent { -        pub d_ino: ::c_long, -        pub d_off: off_t, -        pub d_reclen: u16, -        pub d_name: [::c_char; 256], -    } -      pub struct Dl_info {} -    pub struct fd_set { -        fds_bits: [::c_ulong; FD_SETSIZE / ULONG_SIZE], -    } -      pub struct lconv {          pub decimal_point: *mut ::c_char,          pub thousands_sep: *mut ::c_char, @@ -132,20 +448,6 @@ s! {          pub sa_handler: usize,      } -    pub struct sockaddr { -        pub sa_len: u8, -        pub sa_family: sa_family_t, -        pub sa_data: [::c_char; 14], -    } - -    pub struct sockaddr_in { -        pub sin_len: u8, -        pub sin_family: sa_family_t, -        pub sin_port: ::in_port_t, -        pub sin_addr: ::in_addr, -        pub sin_zero: [::c_char; 8], -    } -      pub struct sockaddr_in6 {          pub sin6_len: u8,          pub sin6_family: sa_family_t, @@ -155,40 +457,6 @@ s! {          pub sin6_scope_id: u32,      } -    pub struct sockaddr_storage { -        pub s2_len: u8, -        pub ss_family: sa_family_t, -        pub s2_data1: [::c_char; 2], -        pub s2_data2: [u32; 3], -        pub s2_data3: [u32; 3], -    } - -    // Dummy -    pub struct sockaddr_un { -        pub sun_family: sa_family_t, -        pub sun_path: [::c_char; 108], -    } - -    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_uid: ::uid_t, -        pub st_gid: ::gid_t, -        pub st_rdev: dev_t, -        pub st_size: off_t, -        pub st_atime: time_t, -        pub st_atime_nsec: ::c_long, -        pub st_mtime: time_t, -        pub st_mtime_nsec: ::c_long, -        pub st_ctime: time_t, -        pub st_ctime_nsec: ::c_long, -        pub st_blksize: blksize_t, -        pub st_blocks: blkcnt_t, -        pub st_spare4: [::c_long; 2], -    } -      pub struct statvfs {}      pub struct tm { @@ -696,6 +964,12 @@ f! {  }  extern { +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int; +      pub fn abs(i: ::c_int) -> ::c_int;      pub fn atof(s: *const ::c_char) -> ::c_double;      pub fn labs(i: ::c_long) -> ::c_long; diff --git a/libc/src/unix/mod.rs b/libc/src/unix/mod.rs index 88e13c5..1565b63 100644 --- a/libc/src/unix/mod.rs +++ b/libc/src/unix/mod.rs @@ -3,8 +3,6 @@  //! More functions and definitions can be found in the more specific modules  //! according to the platform in question. -use dox::Option; -  pub type int8_t = i8;  pub type int16_t = i16;  pub type int32_t = i32; @@ -41,8 +39,18 @@ pub type in_port_t = u16;  pub type sighandler_t = ::size_t;  pub type cc_t = ::c_uchar; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum DIR {} +impl ::Copy for DIR {} +impl ::Clone for DIR { +    fn clone(&self) -> DIR { *self } +} +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum locale_t {} +impl ::Copy for locale_t {} +impl ::Clone for locale_t { +    fn clone(&self) -> locale_t { *self } +}  s! {      pub struct group { @@ -127,23 +135,6 @@ s! {          __reserved: [c_long; 16],      } -    #[cfg_attr(target_os = "netbsd", repr(packed))] -    pub struct in_addr { -        pub s_addr: in_addr_t, -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct in6_addr { -        pub s6_addr: [u8; 16], -        #[cfg(not(feature = "align"))] -        __align: [u32; 0], -    } - -    pub struct ip_mreq { -        pub imr_multiaddr: in_addr, -        pub imr_interface: in_addr, -    } -      pub struct ipv6_mreq {          pub ipv6mr_multiaddr: in6_addr,          #[cfg(target_os = "android")] @@ -232,7 +223,11 @@ pub const DT_REG: u8 = 8;  pub const DT_LNK: u8 = 10;  pub const DT_SOCK: u8 = 12; -pub const FD_CLOEXEC: ::c_int = 0x1; +cfg_if! { +    if #[cfg(not(target_os = "redox"))] { +        pub const FD_CLOEXEC: ::c_int = 0x1; +    } +}  pub const USRQUOTA: ::c_int = 0;  pub const GRPQUOTA: ::c_int = 1; @@ -310,9 +305,7 @@ pub const ATF_PUBL: ::c_int = 0x08;  pub const ATF_USETRAILERS: ::c_int = 0x10;  cfg_if! { -    if #[cfg(cross_platform_docs)] { -        // on dox builds don't pull in anything -    } else if #[cfg(target_os = "l4re")] { +    if #[cfg(target_os = "l4re")] {          // required libraries for L4Re are linked externally, ATM      } else if #[cfg(feature = "use_std")] {          // cargo build, don't pull in anything extra as the libstd dep @@ -338,8 +331,7 @@ cfg_if! {      } else if #[cfg(any(target_os = "macos",                          target_os = "ios",                          target_os = "android", -                        target_os = "openbsd", -                        target_os = "bitrig"))] { +                        target_os = "openbsd"))] {          #[link(name = "c")]          #[link(name = "m")]          extern {} @@ -356,6 +348,17 @@ cfg_if! {          // to "pthread" needs to be added.          #[link(name = "pthread")]          extern {} +    } else if #[cfg(target_env = "illumos")] { +        #[link(name = "c")] +        #[link(name = "m")] +        extern {} +    } else if #[cfg(target_os = "redox")] { +        #[cfg_attr(feature = "rustc-dep-of-std", +                   link(name = "c", kind = "static-nobundle", +                        cfg(target_feature = "crt-static")))] +        #[cfg_attr(feature = "rustc-dep-of-std", +                   link(name = "c", cfg(not(target_feature = "crt-static"))))] +        extern {}      } else {          #[link(name = "c")]          #[link(name = "m")] @@ -365,8 +368,18 @@ cfg_if! {      }  } +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum FILE {} +impl ::Copy for FILE {} +impl ::Clone for FILE { +    fn clone(&self) -> FILE { *self } +} +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum fpos_t {} // TODO: fill this out with a struct +impl ::Copy for fpos_t {} +impl ::Clone for fpos_t { +    fn clone(&self) -> fpos_t { *self } +}  extern {      pub fn isalnum(c: c_int) -> c_int; @@ -509,20 +522,26 @@ extern {      pub fn snprintf(s: *mut ::c_char, n: ::size_t,                      format: *const ::c_char, ...) -> ::c_int;      pub fn sprintf(s: *mut ::c_char, format: *const ::c_char, ...) -> ::c_int; +    #[cfg_attr(target_os = "linux", link_name = "__isoc99_fscanf")]      pub fn fscanf(stream: *mut ::FILE, format: *const ::c_char, ...) -> ::c_int; +    #[cfg_attr(target_os = "linux", link_name = "__isoc99_scanf")]      pub fn scanf(format: *const ::c_char, ...) -> ::c_int; +    #[cfg_attr(target_os = "linux", link_name = "__isoc99_sscanf")]      pub fn sscanf(s: *const ::c_char, format: *const ::c_char, ...) -> ::c_int;      pub fn getchar_unlocked() -> ::c_int;      pub fn putchar_unlocked(c: ::c_int) -> ::c_int;      #[cfg_attr(target_os = "netbsd", link_name = "__socket30")] +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_socket")]      pub fn socket(domain: ::c_int, ty: ::c_int, protocol: ::c_int) -> ::c_int;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "connect$UNIX2003")] +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_connect")]      pub fn connect(socket: ::c_int, address: *const sockaddr,                     len: socklen_t) -> ::c_int;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "listen$UNIX2003")] +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_listen")]      pub fn listen(socket: ::c_int, backlog: ::c_int) -> ::c_int;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "accept$UNIX2003")] @@ -541,10 +560,12 @@ extern {                        option_len: socklen_t) -> ::c_int;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "socketpair$UNIX2003")] +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_socketpair")]      pub fn socketpair(domain: ::c_int, type_: ::c_int, protocol: ::c_int,                        socket_vector: *mut ::c_int) -> ::c_int;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "sendto$UNIX2003")] +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_sendto")]      pub fn sendto(socket: ::c_int, buf: *const ::c_void, len: ::size_t,                    flags: ::c_int, addr: *const sockaddr,                    addrlen: socklen_t) -> ::ssize_t; @@ -604,8 +625,13 @@ extern {      pub fn readdir(dirp: *mut ::DIR) -> *mut ::dirent;      #[cfg_attr(target_os = "macos", link_name = "readdir_r$INODE64")]      #[cfg_attr(target_os = "netbsd", link_name = "__readdir_r30")] -    #[cfg_attr(target_os = "solaris", link_name = "__posix_readdir_r")]      #[cfg_attr(target_os = "freebsd", link_name = "readdir_r@FBSD_1.0")] +    /// The 64-bit libc on Solaris and illumos only has readdir_r.  If a +    /// 32-bit Solaris or illumos target is ever created, it should use +    /// __posix_readdir_r.  See libc(3LIB) on Solaris or illumos: +    /// https://illumos.org/man/3lib/libc +    /// https://docs.oracle.com/cd/E36784_01/html/E36873/libc-3lib.html +    /// https://www.unix.com/man-page/opensolaris/3LIB/libc/      pub fn readdir_r(dirp: *mut ::DIR, entry: *mut ::dirent,                       result: *mut *mut ::dirent) -> ::c_int;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"), @@ -824,6 +850,14 @@ extern {      pub fn flock(fd: ::c_int, operation: ::c_int) -> ::c_int;      #[cfg_attr(target_os = "netbsd", link_name = "__gettimeofday50")] +    #[deprecated( +        since="0.2.54", +        note= +            "The signature of this function is incorrect. \ +             If you are using it, please report that in the following issue \ +             so that we can evaluate the impact of fixing it: \ +             https://github.com/rust-lang/libc/issues/1338" +    )]      pub fn gettimeofday(tp: *mut ::timeval,                          tz: *mut ::c_void) -> ::c_int;      #[cfg_attr(target_os = "netbsd", link_name = "__times13")] @@ -845,7 +879,7 @@ extern {      #[cfg_attr(target_os = "netbsd", link_name = "__libc_thr_yield")]      pub fn sched_yield() -> ::c_int;      pub fn pthread_key_create(key: *mut pthread_key_t, -                              dtor: Option<unsafe extern fn(*mut ::c_void)>) +                              dtor: ::Option<unsafe extern fn(*mut ::c_void)>)                                -> ::c_int;      pub fn pthread_key_delete(key: pthread_key_t) -> ::c_int;      pub fn pthread_getspecific(key: pthread_key_t) -> *mut ::c_void; @@ -913,6 +947,7 @@ extern {      pub fn strerror_r(errnum: ::c_int, buf: *mut c_char,                        buflen: ::size_t) -> ::c_int; +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_getsockopt")]      pub fn getsockopt(sockfd: ::c_int,                        level: ::c_int,                        optname: ::c_int, @@ -1011,16 +1046,11 @@ extern {                       locale: *const ::c_char) -> *mut ::c_char;      pub fn localeconv() -> *mut lconv; -    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "sem_wait$UNIX2003")]      pub fn sem_wait(sem: *mut sem_t) -> ::c_int;      pub fn sem_trywait(sem: *mut sem_t) -> ::c_int;      pub fn sem_post(sem: *mut sem_t) -> ::c_int; -    pub fn sem_init(sem: *mut sem_t, -                    pshared: ::c_int, -                    value: ::c_uint) -                    -> ::c_int;      pub fn statvfs(path: *const c_char, buf: *mut statvfs) -> ::c_int;      pub fn fstatvfs(fd: ::c_int, buf: *mut statvfs) -> ::c_int; @@ -1077,10 +1107,8 @@ extern {      pub fn tcdrain(fd: ::c_int) -> ::c_int;      pub fn cfgetispeed(termios: *const ::termios) -> ::speed_t;      pub fn cfgetospeed(termios: *const ::termios) -> ::speed_t; -    pub fn cfmakeraw(termios: *mut ::termios);      pub fn cfsetispeed(termios: *mut ::termios, speed: ::speed_t) -> ::c_int;      pub fn cfsetospeed(termios: *mut ::termios, speed: ::speed_t) -> ::c_int; -    pub fn cfsetspeed(termios: *mut ::termios, speed: ::speed_t) -> ::c_int;      pub fn tcgetattr(fd: ::c_int, termios: *mut ::termios) -> ::c_int;      pub fn tcsetattr(fd: ::c_int,                       optional_actions: ::c_int, @@ -1114,6 +1142,16 @@ extern {  }  cfg_if! { +   if #[cfg(not(any(target_os = "solaris", target_os = "illumos")))] { +        extern { +            pub fn cfmakeraw(termios: *mut ::termios); +            pub fn cfsetspeed(termios: *mut ::termios, +                              speed: ::speed_t) -> ::c_int; +        } +   } +} + +cfg_if! {      if #[cfg(target_env = "uclibc")] {          mod uclibc;          pub use self::uclibc::*; @@ -1130,32 +1168,37 @@ cfg_if! {                          target_os = "freebsd",                          target_os = "dragonfly",                          target_os = "openbsd", -                        target_os = "netbsd", -                        target_os = "bitrig"))] { +                        target_os = "netbsd"))] {          mod bsd;          pub use self::bsd::*; -    } else if #[cfg(target_os = "solaris")] { -        mod solaris; -        pub use self::solaris::*; +    } else if #[cfg(any(target_os = "solaris", +                        target_os = "illumos"))] { +        mod solarish; +        pub use self::solarish::*;      } else if #[cfg(target_os = "haiku")] {          mod haiku;          pub use self::haiku::*;      } else if #[cfg(target_os = "hermit")] {          mod hermit;          pub use self::hermit::*; +    } else if #[cfg(target_os = "redox")] { +        mod redox; +        pub use self::redox::*;      } else {          // Unknown target_os      }  }  cfg_if! { -    if #[cfg(core_cvoid)] { -        pub use core::ffi::c_void; +    if #[cfg(libc_core_cvoid)] { +        pub use ::ffi::c_void;      } else {          // Use repr(u8) as LLVM expects `void*` to be the same as `i8*` to help          // enable more optimization opportunities around it recognizing things          // like malloc/free.          #[repr(u8)] +        #[allow(missing_copy_implementations)] +        #[allow(missing_debug_implementations)]          pub enum c_void {              // Two dummy variants so the #[repr] attribute can be used.              #[doc(hidden)] @@ -1165,3 +1208,13 @@ cfg_if! {          }      }  } + +cfg_if! { +    if #[cfg(libc_align)] { +        mod align; +        pub use self::align::*; +    } else { +        mod no_align; +        pub use self::no_align::*; +    } +} diff --git a/libc/src/unix/newlib/align.rs b/libc/src/unix/newlib/align.rs new file mode 100644 index 0000000..c018fbc --- /dev/null +++ b/libc/src/unix/newlib/align.rs @@ -0,0 +1,61 @@ +macro_rules! expand_align { +    () => { +        s! { +            #[cfg_attr(all(target_pointer_width = "32", +                           any(target_arch = "mips", +                               target_arch = "arm", +                               target_arch = "powerpc")), +                       repr(align(4)))] +            #[cfg_attr(any(target_pointer_width = "64", +                           not(any(target_arch = "mips", +                                   target_arch = "arm", +                                   target_arch = "powerpc"))), +                       repr(align(8)))] +            pub struct pthread_mutex_t { // Unverified +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            #[cfg_attr(all(target_pointer_width = "32", +                           any(target_arch = "mips", +                               target_arch = "arm", +                               target_arch = "powerpc")), +                       repr(align(4)))] +            #[cfg_attr(any(target_pointer_width = "64", +                           not(any(target_arch = "mips", +                                   target_arch = "arm", +                                   target_arch = "powerpc"))), +                       repr(align(8)))] +            pub struct pthread_rwlock_t { // Unverified +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } + +            #[cfg_attr(any(target_pointer_width = "32", +                           target_arch = "x86_64", +                           target_arch = "powerpc64", +                           target_arch = "mips64", +                           target_arch = "s390x", +                           target_arch = "sparc64"), +                       repr(align(4)))] +            #[cfg_attr(not(any(target_pointer_width = "32", +                               target_arch = "x86_64", +                               target_arch = "powerpc64", +                               target_arch = "mips64", +                               target_arch = "s390x", +                               target_arch = "sparc64")), +                       repr(align(8)))] +            pub struct pthread_mutexattr_t { // Unverified +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            #[repr(align(8))] +            pub struct pthread_cond_t { // Unverified +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } + +            #[repr(align(4))] +            pub struct pthread_condattr_t { // Unverified +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } +    } +} diff --git a/libc/src/unix/newlib/mod.rs b/libc/src/unix/newlib/mod.rs index 0cc411d..c9a25a3 100644 --- a/libc/src/unix/newlib/mod.rs +++ b/libc/src/unix/newlib/mod.rs @@ -1,5 +1,3 @@ -use dox::mem; -  pub type blkcnt_t = i32;  pub type blksize_t = i32;  pub type clock_t = i32; @@ -238,103 +236,10 @@ s! {          __size: [u64; 7]      } -    #[cfg_attr(all(feature = "align", -                   target_pointer_width = "32", -                   any(target_arch = "mips", -                       target_arch = "arm", -                       target_arch = "powerpc")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "64", -                       not(any(target_arch = "mips", -                               target_arch = "arm", -                               target_arch = "powerpc")))), -               repr(align(8)))] -    pub struct pthread_mutex_t { // Unverified -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_long; 0], -        #[cfg(not(any(feature = "align", -                      target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEX_T], -    } - -    #[cfg_attr(all(feature = "align", -                   target_pointer_width = "32", -                   any(target_arch = "mips", -                       target_arch = "arm", -                       target_arch = "powerpc")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "64", -                       not(any(target_arch = "mips", -                               target_arch = "arm", -                               target_arch = "powerpc")))), -               repr(align(8)))] -    pub struct pthread_rwlock_t { // Unverified -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_long; 0], -        #[cfg(not(any(feature = "align", -                      target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_RWLOCK_T], -    } - -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "32", -                       target_arch = "x86_64", target_arch = "powerpc64", -                       target_arch = "mips64", target_arch = "s390x", -                       target_arch = "sparc64")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   not(any(target_pointer_width = "32", -                           target_arch = "x86_64", target_arch = "powerpc64", -                           target_arch = "mips64", target_arch = "s390x", -                           target_arch = "sparc64"))), -               repr(align(8)))] -    pub struct pthread_mutexattr_t { // Unverified -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "x86_64", target_arch = "powerpc64", -                      target_arch = "mips64", target_arch = "s390x", -                      target_arch = "sparc64")))] -        __align: [::c_int; 0], -        #[cfg(all(not(feature = "align"), -                  not(any(target_arch = "x86_64", target_arch = "powerpc64", -                          target_arch = "mips64", target_arch = "s390x", -                          target_arch = "sparc64"))))] -        __align: [::c_long; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEXATTR_T], -    } -      pub struct pthread_rwlockattr_t { // Unverified          __lockkind: ::c_int,          __pshared: ::c_int,      } - -    #[cfg_attr(feature = "align", repr(align(8)))] -    pub struct pthread_cond_t { // Unverified -        #[cfg(not(feature = "align"))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_COND_T], -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_condattr_t { // Unverified -        #[cfg(not(feature = "align"))] -        __align: [::c_int; 0], -        size: [u8; __SIZEOF_PTHREAD_CONDATTR_T], -    } -  }  // unverified constants @@ -501,7 +406,8 @@ pub const SEEK_SET: ::c_int = 0;  pub const SEEK_CUR: ::c_int = 1;  pub const SEEK_END: ::c_int = 2; -pub const FIONBIO: ::c_int = 1; +pub const FIONBIO: ::c_ulong = 1; +pub const FIOCLEX: ::c_ulong = 0x20006601;  pub const S_BLKSIZE: ::mode_t = 1024;  pub const S_IREAD: ::mode_t = 256; @@ -552,15 +458,41 @@ pub const SHUT_RD: ::c_int = 0;  pub const SHUT_WR: ::c_int = 1;  pub const SHUT_RDWR: ::c_int = 2; -pub const SO_REUSEADDR: ::c_int = 4; -pub const SO_LINGER: ::c_int = 128; -pub const SO_OOBINLINE: ::c_int = 256; -pub const SO_SNDBUF: ::c_int = 4097; -pub const SO_RCVBUF: ::c_int = 4098; -pub const SO_SNDLOWAT: ::c_int = 4099; -pub const SO_RCVLOWAT: ::c_int = 4100; -pub const SO_TYPE: ::c_int = 4104; -pub const SO_ERROR: ::c_int = 4105; +pub const SO_BINTIME: ::c_int = 0x2000; +pub const SO_NO_OFFLOAD: ::c_int = 0x4000; +pub const SO_NO_DDP: ::c_int = 0x8000; +pub const SO_REUSEPORT_LB: ::c_int = 0x10000; +pub const SO_LABEL: ::c_int = 0x1009; +pub const SO_PEERLABEL: ::c_int = 0x1010; +pub const SO_LISTENQLIMIT: ::c_int = 0x1011; +pub const SO_LISTENQLEN: ::c_int = 0x1012; +pub const SO_LISTENINCQLEN: ::c_int = 0x1013; +pub const SO_SETFIB: ::c_int = 0x1014; +pub const SO_USER_COOKIE: ::c_int = 0x1015; +pub const SO_PROTOCOL: ::c_int = 0x1016; +pub const SO_PROTOTYPE: ::c_int = SO_PROTOCOL; +pub const SO_VENDOR: ::c_int = 0x80000000; +pub const SO_DEBUG: ::c_int = 0x01; +pub const SO_ACCEPTCONN: ::c_int = 0x0002; +pub const SO_REUSEADDR: ::c_int = 0x0004; +pub const SO_KEEPALIVE: ::c_int = 0x0008; +pub const SO_DONTROUTE: ::c_int = 0x0010; +pub const SO_BROADCAST: ::c_int = 0x0020; +pub const SO_USELOOPBACK: ::c_int = 0x0040; +pub const SO_LINGER: ::c_int = 0x0080; +pub const SO_OOBINLINE: ::c_int = 0x0100; +pub const SO_REUSEPORT: ::c_int = 0x0200; +pub const SO_TIMESTAMP: ::c_int = 0x0400; +pub const SO_NOSIGPIPE: ::c_int = 0x0800; +pub const SO_ACCEPTFILTER: ::c_int = 0x1000; +pub const SO_SNDBUF: ::c_int = 0x1001; +pub const SO_RCVBUF: ::c_int = 0x1002; +pub const SO_SNDLOWAT: ::c_int = 0x1003; +pub const SO_RCVLOWAT: ::c_int = 0x1004; +pub const SO_SNDTIMEO: ::c_int = 0x1005; +pub const SO_RCVTIMEO: ::c_int = 0x1006; +pub const SO_ERROR: ::c_int = 0x1007; +pub const SO_TYPE: ::c_int = 0x1008;  pub const SOCK_CLOEXEC: ::c_int = O_CLOEXEC; @@ -586,20 +518,32 @@ pub const IFF_LINK2: ::c_int = 0x4000; // per link layer defined bit  pub const IFF_ALTPHYS: ::c_int = IFF_LINK2; // use alternate physical connection  pub const IFF_MULTICAST: ::c_int = 0x8000; // supports multicast -pub const IPPROTO_IP: ::c_int = 0; -pub const IPPROTO_UDP: ::c_int = 17; -pub const IPPROTO_TCP: ::c_int = 6; -  pub const TCP_NODELAY: ::c_int = 8193;  pub const TCP_MAXSEG: ::c_int = 8194; +pub const TCP_NOPUSH: ::c_int = 4; +pub const TCP_NOOPT: ::c_int = 8; +pub const TCP_KEEPIDLE: ::c_int = 256; +pub const TCP_KEEPINTVL: ::c_int = 512; +pub const TCP_KEEPCNT: ::c_int = 1024; -pub const IP_TOS: ::c_int = 7; +pub const IP_TOS: ::c_int = 3;  pub const IP_TTL: ::c_int = 8; -pub const IP_MULTICAST_LOOP: ::c_int = 9; +pub const IP_MULTICAST_IF: ::c_int = 9;  pub const IP_MULTICAST_TTL: ::c_int = 10; +pub const IP_MULTICAST_LOOP: ::c_int = 11;  pub const IP_ADD_MEMBERSHIP: ::c_int = 11;  pub const IP_DROP_MEMBERSHIP: ::c_int = 12; +pub const IPV6_UNICAST_HOPS: ::c_int = 4; +pub const IPV6_MULTICAST_IF: ::c_int = 9; +pub const IPV6_MULTICAST_HOPS: ::c_int = 10; +pub const IPV6_MULTICAST_LOOP: ::c_int = 11; +pub const IPV6_V6ONLY: ::c_int = 27; +pub const IPV6_JOIN_GROUP: ::c_int = 12; +pub const IPV6_LEAVE_GROUP: ::c_int = 13; +pub const IPV6_ADD_MEMBERSHIP: ::c_int = 12; +pub const IPV6_DROP_MEMBERSHIP: ::c_int = 13; +  pub const HOST_NOT_FOUND: ::c_int = 1;  pub const NO_DATA: ::c_int = 2;  pub const NO_ADDRESS: ::c_int = 2; @@ -627,20 +571,20 @@ pub const EAI_SOCKTYPE: ::c_int = -307;  f! {      pub fn FD_CLR(fd: ::c_int, set: *mut fd_set) -> () { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          (*set).fds_bits[fd / bits] &= !(1 << (fd % bits));          return      }      pub fn FD_ISSET(fd: ::c_int, set: *mut fd_set) -> bool { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          return ((*set).fds_bits[fd / bits] & (1 << (fd % bits))) != 0      }      pub fn FD_SET(fd: ::c_int, set: *mut fd_set) -> () { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          (*set).fds_bits[fd / bits] |= 1 << (fd % bits);          return @@ -654,6 +598,12 @@ f! {  }  extern { +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int; +      pub fn abs(i: ::c_int) -> ::c_int;      pub fn atof(s: *const ::c_char) -> ::c_double;      pub fn labs(i: ::c_long) -> ::c_long; @@ -674,7 +624,7 @@ extern {                     envp: *const *const ::c_char)                     -> ::c_int;      #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrgid_r")] -    pub fn getgrgid_r(uid: ::uid_t, +    pub fn getgrgid_r(gid: ::gid_t,                        grp: *mut ::group,                        buf: *mut ::c_char,                        buflen: ::size_t, @@ -720,9 +670,9 @@ extern {      #[cfg_attr(target_os = "solaris", link_name = "__posix_sigwait")]      pub fn sigwait(set: *const sigset_t,                     sig: *mut ::c_int) -> ::c_int; -    pub fn pthread_atfork(prepare: Option<unsafe extern fn()>, -                          parent: Option<unsafe extern fn()>, -                          child: Option<unsafe extern fn()>) -> ::c_int; +    pub fn pthread_atfork(prepare: ::Option<unsafe extern fn()>, +                          parent: ::Option<unsafe extern fn()>, +                          child: ::Option<unsafe extern fn()>) -> ::c_int;      pub fn getgrgid(gid: ::gid_t) -> *mut ::group;      #[cfg_attr(all(target_os = "macos", target_arch = "x86"),                 link_name = "popen$UNIX2003")] @@ -744,3 +694,14 @@ cfg_if! {          pub use target_arch_not_implemented;      }  } + +cfg_if! { +    if #[cfg(libc_align)] { +        #[macro_use] +        mod align; +    } else { +        #[macro_use] +        mod no_align; +    } +} +expand_align!(); diff --git a/libc/src/unix/newlib/no_align.rs b/libc/src/unix/newlib/no_align.rs new file mode 100644 index 0000000..316c464 --- /dev/null +++ b/libc/src/unix/newlib/no_align.rs @@ -0,0 +1,51 @@ +macro_rules! expand_align { +    () => { +        s! { +            pub struct pthread_mutex_t { // Unverified +                #[cfg(any(target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc"))] +                __align: [::c_long; 0], +                #[cfg(not(any(target_arch = "mips", +                              target_arch = "arm", +                              target_arch = "powerpc")))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            pub struct pthread_rwlock_t { // Unverified +                #[cfg(any(target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc"))] +                __align: [::c_long; 0], +                #[cfg(not(any(target_arch = "mips", +                              target_arch = "arm", +                              target_arch = "powerpc")))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } + +            pub struct pthread_mutexattr_t { // Unverified +                #[cfg(any(target_arch = "x86_64", target_arch = "powerpc64", +                          target_arch = "mips64", target_arch = "s390x", +                          target_arch = "sparc64"))] +                __align: [::c_int; 0], +                #[cfg(not(any(target_arch = "x86_64", target_arch = "powerpc64", +                              target_arch = "mips64", target_arch = "s390x", +                              target_arch = "sparc64")))] +                __align: [::c_long; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            pub struct pthread_cond_t { // Unverified +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } + +            pub struct pthread_condattr_t { // Unverified +                __align: [::c_int; 0], +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } +    } +} diff --git a/libc/src/unix/no_align.rs b/libc/src/unix/no_align.rs new file mode 100644 index 0000000..f6b9f4c --- /dev/null +++ b/libc/src/unix/no_align.rs @@ -0,0 +1,6 @@ +s! { +    pub struct in6_addr { +        pub s6_addr: [u8; 16], +        __align: [u32; 0], +    } +} diff --git a/libc/src/unix/notbsd/android/b32/mod.rs b/libc/src/unix/notbsd/android/b32/mod.rs index 394abe8..a8cc51b 100644 --- a/libc/src/unix/notbsd/android/b32/mod.rs +++ b/libc/src/unix/notbsd/android/b32/mod.rs @@ -14,7 +14,7 @@ s! {          pub sa_sigaction: ::sighandler_t,          pub sa_mask: ::sigset_t,          pub sa_flags: ::c_ulong, -        pub sa_restorer: ::dox::Option<extern fn()>, +        pub sa_restorer: ::Option<extern fn()>,      }      pub struct rlimit64 { diff --git a/libc/src/unix/notbsd/android/b64/mod.rs b/libc/src/unix/notbsd/android/b64/mod.rs index fb94334..46becc5 100644 --- a/libc/src/unix/notbsd/android/b64/mod.rs +++ b/libc/src/unix/notbsd/android/b64/mod.rs @@ -16,7 +16,7 @@ s! {          pub sa_flags: ::c_uint,          pub sa_sigaction: ::sighandler_t,          pub sa_mask: ::sigset_t, -        pub sa_restorer: ::dox::Option<extern fn()>, +        pub sa_restorer: ::Option<extern fn()>,      }      pub struct rlimit64 { @@ -34,25 +34,6 @@ s! {          __reserved: [::c_char; 16],      } -    pub struct pthread_mutex_t { -        value: ::c_int, -        __reserved: [::c_char; 36], -    } - -    pub struct pthread_cond_t { -        value: ::c_int, -        __reserved: [::c_char; 44], -    } - -    pub struct pthread_rwlock_t { -        numLocks: ::c_int, -        writerThreadId: ::c_int, -        pendingReaders: ::c_int, -        pendingWriters: ::c_int, -        attr: i32, -        __reserved: [::c_char; 36], -    } -      pub struct passwd {          pub pw_name: *mut ::c_char,          pub pw_passwd: *mut ::c_char, @@ -126,6 +107,130 @@ s! {      }  } +s_no_extra_traits!{ +    pub struct pthread_mutex_t { +        value: ::c_int, +        __reserved: [::c_char; 36], +    } + +    pub struct pthread_cond_t { +        value: ::c_int, +        __reserved: [::c_char; 44], +    } + +    pub struct pthread_rwlock_t { +        numLocks: ::c_int, +        writerThreadId: ::c_int, +        pendingReaders: ::c_int, +        pendingWriters: ::c_int, +        attr: i32, +        __reserved: [::c_char; 36], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for pthread_mutex_t { +            fn eq(&self, other: &pthread_mutex_t) -> bool { +                self.value == other.value +                    && self +                    .__reserved +                    .iter() +                    .zip(other.__reserved.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for pthread_mutex_t {} + +        impl ::fmt::Debug for pthread_mutex_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_mutex_t") +                    .field("value", &self.value) +                    // FIXME: .field("__reserved", &self.__reserved) +                    .finish() +            } +        } + +        impl ::hash::Hash for pthread_mutex_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.value.hash(state); +                self.__reserved.hash(state); +            } +        } + +        impl PartialEq for pthread_cond_t { +            fn eq(&self, other: &pthread_cond_t) -> bool { +                self.value == other.value +                    && self +                    .__reserved +                    .iter() +                    .zip(other.__reserved.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for pthread_cond_t {} + +        impl ::fmt::Debug for pthread_cond_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_cond_t") +                    .field("value", &self.value) +                    // FIXME: .field("__reserved", &self.__reserved) +                    .finish() +            } +        } + +        impl ::hash::Hash for pthread_cond_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.value.hash(state); +                self.__reserved.hash(state); +            } +        } + +        impl PartialEq for pthread_rwlock_t { +            fn eq(&self, other: &pthread_rwlock_t) -> bool { +                self.numLocks == other.numLocks +                    && self.writerThreadId == other.writerThreadId +                    && self.pendingReaders == other.pendingReaders +                    && self.pendingWriters == other.pendingWriters +                    && self.attr == other.attr +                    && self +                    .__reserved +                    .iter() +                    .zip(other.__reserved.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for pthread_rwlock_t {} + +        impl ::fmt::Debug for pthread_rwlock_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_rwlock_t") +                    .field("numLocks", &self.numLocks) +                    .field("writerThreadId", &self.writerThreadId) +                    .field("pendingReaders", &self.pendingReaders) +                    .field("pendingWriters", &self.pendingWriters) +                    .field("attr", &self.attr) +                    // FIXME: .field("__reserved", &self.__reserved) +                    .finish() +            } +        } + +        impl ::hash::Hash for pthread_rwlock_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.numLocks.hash(state); +                self.writerThreadId.hash(state); +                self.pendingReaders.hash(state); +                self.pendingWriters.hash(state); +                self.attr.hash(state); +                self.__reserved.hash(state); +            } +        } +    } +} +  pub const RTLD_GLOBAL: ::c_int = 0x00100;  pub const RTLD_NOW: ::c_int = 2;  pub const RTLD_DEFAULT: *mut ::c_void = 0i64 as *mut ::c_void; diff --git a/libc/src/unix/notbsd/android/mod.rs b/libc/src/unix/notbsd/android/mod.rs index 972281c..a430b1a 100644 --- a/libc/src/unix/notbsd/android/mod.rs +++ b/libc/src/unix/notbsd/android/mod.rs @@ -1,7 +1,5 @@  //! Android-specific definitions for linux-like values -use dox::{mem, Option}; -  pub type clock_t = ::c_long;  pub type time_t = ::c_long;  pub type suseconds_t = ::c_long; @@ -25,36 +23,12 @@ pub type idtype_t = ::c_int;  pub type loff_t = ::c_longlong;  s! { -    pub struct dirent { -        pub d_ino: u64, -        pub d_off: i64, -        pub d_reclen: ::c_ushort, -        pub d_type: ::c_uchar, -        pub d_name: [::c_char; 256], -    } - -    pub struct dirent64 { -        pub d_ino: u64, -        pub d_off: i64, -        pub d_reclen: ::c_ushort, -        pub d_type: ::c_uchar, -        pub d_name: [::c_char; 256], -    } -      pub struct stack_t {          pub ss_sp: *mut ::c_void,          pub ss_flags: ::c_int,          pub ss_size: ::size_t      } -    pub struct siginfo_t { -        pub si_signo: ::c_int, -        pub si_errno: ::c_int, -        pub si_code: ::c_int, -        pub _pad: [::c_int; 29], -        _align: [usize; 0], -    } -      pub struct __fsid_t {          __val: [::c_int; 2],      } @@ -116,33 +90,11 @@ s! {          __reserved: [::c_int; 3],      } -    pub struct lastlog { -        ll_time: ::time_t, -        ll_line: [::c_char; UT_LINESIZE], -        ll_host: [::c_char; UT_HOSTSIZE], -    } -      pub struct exit_status {          pub e_termination: ::c_short,          pub e_exit: ::c_short,      } -    pub struct utmp { -        pub ut_type: ::c_short, -        pub ut_pid: ::pid_t, -        pub ut_line: [::c_char; UT_LINESIZE], -        pub ut_id: [::c_char; 4], - -        pub ut_user: [::c_char; UT_NAMESIZE], -        pub ut_host: [::c_char; UT_HOSTSIZE], -        pub ut_exit: exit_status, -        pub ut_session: ::c_long, -        pub ut_tv: ::timeval, - -        pub ut_addr_v6: [::int32_t; 4], -        unused: [::c_char; 20], -    } -      pub struct statvfs {          pub f_bsize: ::c_ulong,          pub f_frsize: ::c_ulong, @@ -238,6 +190,361 @@ s! {          pub ipi6_addr: ::in6_addr,          pub ipi6_ifindex: ::c_int,      } + +    pub struct inotify_event { +        pub wd: ::c_int, +        pub mask: ::uint32_t, +        pub cookie: ::uint32_t, +        pub len: ::uint32_t +    } +} + +s_no_extra_traits!{ +    pub struct dirent { +        pub d_ino: u64, +        pub d_off: i64, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } + +    pub struct dirent64 { +        pub d_ino: u64, +        pub d_off: i64, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } + +    pub struct siginfo_t { +        pub si_signo: ::c_int, +        pub si_errno: ::c_int, +        pub si_code: ::c_int, +        pub _pad: [::c_int; 29], +        _align: [usize; 0], +    } + +    pub struct lastlog { +        ll_time: ::time_t, +        ll_line: [::c_char; UT_LINESIZE], +        ll_host: [::c_char; UT_HOSTSIZE], +    } + +    pub struct utmp { +        pub ut_type: ::c_short, +        pub ut_pid: ::pid_t, +        pub ut_line: [::c_char; UT_LINESIZE], +        pub ut_id: [::c_char; 4], +        pub ut_user: [::c_char; UT_NAMESIZE], +        pub ut_host: [::c_char; UT_HOSTSIZE], +        pub ut_exit: exit_status, +        pub ut_session: ::c_long, +        pub ut_tv: ::timeval, +        pub ut_addr_v6: [::int32_t; 4], +        unused: [::c_char; 20], +    } + +    pub struct sockaddr_alg { +        pub salg_family: ::sa_family_t, +        pub salg_type: [::c_uchar; 14], +        pub salg_feat: u32, +        pub salg_mask: u32, +        pub salg_name: [::c_uchar; 64], +    } + +    pub struct af_alg_iv { +        pub ivlen: u32, +        pub iv: [::c_uchar; 0], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_ino == other.d_ino +                    && self.d_off == other.d_off +                    && self.d_reclen == other.d_reclen +                    && self.d_type == other.d_type +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for dirent {} + +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_ino", &self.d_ino) +                    .field("d_off", &self.d_off) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_type", &self.d_type) +                // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } + +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_ino.hash(state); +                self.d_off.hash(state); +                self.d_reclen.hash(state); +                self.d_type.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for dirent64 { +            fn eq(&self, other: &dirent64) -> bool { +                self.d_ino == other.d_ino +                    && self.d_off == other.d_off +                    && self.d_reclen == other.d_reclen +                    && self.d_type == other.d_type +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for dirent64 {} + +        impl ::fmt::Debug for dirent64 { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent64") +                    .field("d_ino", &self.d_ino) +                    .field("d_off", &self.d_off) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_type", &self.d_type) +                // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } + +        impl ::hash::Hash for dirent64 { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_ino.hash(state); +                self.d_off.hash(state); +                self.d_reclen.hash(state); +                self.d_type.hash(state); +                self.d_name.hash(state); +            } +        } + +        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 +                // Ignore _pad +                // Ignore _align +            } +        } + +        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) +                // Ignore _pad +                // Ignore _align +                    .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); +                // Ignore _pad +                // Ignore _align +            } +        } + +        impl PartialEq for lastlog { +            fn eq(&self, other: &lastlog) -> bool { +                self.ll_time == other.ll_time +                    && self +                    .ll_line +                    .iter() +                    .zip(other.ll_line.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .ll_host +                    .iter() +                    .zip(other.ll_host.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for lastlog {} + +        impl ::fmt::Debug for lastlog { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("lastlog") +                    .field("ll_time", &self.ll_time) +                    .field("ll_line", &self.ll_line) +                // FIXME: .field("ll_host", &self.ll_host) +                    .finish() +            } +        } + +        impl ::hash::Hash for lastlog { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ll_time.hash(state); +                self.ll_line.hash(state); +                self.ll_host.hash(state); +            } +        } + +        impl PartialEq for utmp { +            fn eq(&self, other: &utmp) -> bool { +                self.ut_type == other.ut_type +                    && self.ut_pid == other.ut_pid +                    && self +                    .ut_line +                    .iter() +                    .zip(other.ut_line.iter()) +                    .all(|(a,b)| a == b) +                    && self.ut_id == other.ut_id +                    && self +                    .ut_user +                    .iter() +                    .zip(other.ut_user.iter()) +                    .all(|(a,b)| a == b) +                    && self +                    .ut_host +                    .iter() +                    .zip(other.ut_host.iter()) +                    .all(|(a,b)| a == b) +                    && self.ut_exit == other.ut_exit +                    && self.ut_session == other.ut_session +                    && self.ut_tv == other.ut_tv +                    && self.ut_addr_v6 == other.ut_addr_v6 +                    && self.unused == other.unused +            } +        } + +        impl Eq for utmp {} + +        impl ::fmt::Debug for utmp { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utmp") +                    .field("ut_type", &self.ut_type) +                    .field("ut_pid", &self.ut_pid) +                    .field("ut_line", &self.ut_line) +                    .field("ut_id", &self.ut_id) +                    .field("ut_user", &self.ut_user) +                // FIXME: .field("ut_host", &self.ut_host) +                    .field("ut_exit", &self.ut_exit) +                    .field("ut_session", &self.ut_session) +                    .field("ut_tv", &self.ut_tv) +                    .field("ut_addr_v6", &self.ut_addr_v6) +                    .field("unused", &self.unused) +                    .finish() +            } +        } + +        impl ::hash::Hash for utmp { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ut_type.hash(state); +                self.ut_pid.hash(state); +                self.ut_line.hash(state); +                self.ut_id.hash(state); +                self.ut_user.hash(state); +                self.ut_host.hash(state); +                self.ut_exit.hash(state); +                self.ut_session.hash(state); +                self.ut_tv.hash(state); +                self.ut_addr_v6.hash(state); +                self.unused.hash(state); +            } +        } + +        impl PartialEq for sockaddr_alg { +            fn eq(&self, other: &sockaddr_alg) -> bool { +                self.salg_family == other.salg_family +                    && self +                    .salg_type +                    .iter() +                    .zip(other.salg_type.iter()) +                    .all(|(a, b)| a == b) +                    && self.salg_feat == other.salg_feat +                    && self.salg_mask == other.salg_mask +                    && self +                    .salg_name +                    .iter() +                    .zip(other.salg_name.iter()) +                    .all(|(a, b)| a == b) +           } +        } + +        impl Eq for sockaddr_alg {} + +        impl ::fmt::Debug for sockaddr_alg { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_alg") +                    .field("salg_family", &self.salg_family) +                    .field("salg_type", &self.salg_type) +                    .field("salg_feat", &self.salg_feat) +                    .field("salg_mask", &self.salg_mask) +                    .field("salg_name", &&self.salg_name[..]) +                    .finish() +            } +        } + +        impl ::hash::Hash for sockaddr_alg { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.salg_family.hash(state); +                self.salg_type.hash(state); +                self.salg_feat.hash(state); +                self.salg_mask.hash(state); +                self.salg_name.hash(state); +            } +        } + +        impl af_alg_iv { +            fn as_slice(&self) -> &[u8] { +                unsafe { +                    ::core::slice::from_raw_parts( +                        self.iv.as_ptr(), +                        self.ivlen as usize +                    ) +                } +            } +        } + +        impl PartialEq for af_alg_iv { +            fn eq(&self, other: &af_alg_iv) -> bool { +                *self.as_slice() == *other.as_slice() +           } +        } + +        impl Eq for af_alg_iv {} + +        impl ::fmt::Debug for af_alg_iv { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("af_alg_iv") +                    .field("iv", &self.as_slice()) +                    .finish() +            } +        } + +        impl ::hash::Hash for af_alg_iv { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.as_slice().hash(state); +            } +        } +    }  }  pub const O_TRUNC: ::c_int = 512; @@ -1052,6 +1359,15 @@ pub const SFD_NONBLOCK: ::c_int = O_NONBLOCK;  pub const SOCK_NONBLOCK: ::c_int = O_NONBLOCK;  pub const SO_ORIGINAL_DST: ::c_int = 80; +pub const IP_ORIGDSTADDR : ::c_int = 20; +pub const IP_RECVORIGDSTADDR : ::c_int = IP_ORIGDSTADDR; +pub const IPV6_ORIGDSTADDR : ::c_int = 74; +pub const IPV6_RECVORIGDSTADDR : ::c_int = IPV6_ORIGDSTADDR; +pub const IPV6_FLOWINFO: ::c_int = 11; +pub const IPV6_FLOWLABEL_MGR: ::c_int = 32; +pub const IPV6_FLOWINFO_SEND: ::c_int = 33; +pub const IPV6_FLOWINFO_FLOWLABEL: ::c_int = 0x000fffff; +pub const IPV6_FLOWINFO_PRIORITY: ::c_int = 0x0ff00000;  pub const IUTF8: ::tcflag_t = 0x00004000;  pub const CMSPAR: ::tcflag_t = 0o10000000000;  pub const O_TMPFILE: ::c_int = 0o20000000 | O_DIRECTORY; @@ -1476,7 +1792,87 @@ pub const MODULE_INIT_IGNORE_VERMAGIC: ::c_uint = 0x0002;  // Similarity to Linux it's not used but defined for compatibility.  pub const ENOATTR: ::c_int = ::ENODATA; +// linux/if_alg.h +pub const ALG_SET_KEY: ::c_int = 1; +pub const ALG_SET_IV: ::c_int = 2; +pub const ALG_SET_OP: ::c_int = 3; +pub const ALG_SET_AEAD_ASSOCLEN: ::c_int = 4; +pub const ALG_SET_AEAD_AUTHSIZE: ::c_int = 5; + +pub const ALG_OP_DECRYPT: ::c_int = 0; +pub const ALG_OP_ENCRYPT: ::c_int = 1; + +// uapi/linux/inotify.h +pub const IN_ACCESS:        ::uint32_t = 0x0000_0001; +pub const IN_MODIFY:        ::uint32_t = 0x0000_0002; +pub const IN_ATTRIB:        ::uint32_t = 0x0000_0004; +pub const IN_CLOSE_WRITE:   ::uint32_t = 0x0000_0008; +pub const IN_CLOSE_NOWRITE: ::uint32_t = 0x0000_0010; +pub const IN_CLOSE:         ::uint32_t = (IN_CLOSE_WRITE | IN_CLOSE_NOWRITE); +pub const IN_OPEN:          ::uint32_t = 0x0000_0020; +pub const IN_MOVED_FROM:    ::uint32_t = 0x0000_0040; +pub const IN_MOVED_TO:      ::uint32_t = 0x0000_0080; +pub const IN_MOVE:          ::uint32_t = (IN_MOVED_FROM | IN_MOVED_TO); +pub const IN_CREATE:        ::uint32_t = 0x0000_0100; +pub const IN_DELETE:        ::uint32_t = 0x0000_0200; +pub const IN_DELETE_SELF:   ::uint32_t = 0x0000_0400; +pub const IN_MOVE_SELF:     ::uint32_t = 0x0000_0800; +pub const IN_UNMOUNT:       ::uint32_t = 0x0000_2000; +pub const IN_Q_OVERFLOW:    ::uint32_t = 0x0000_4000; +pub const IN_IGNORED:       ::uint32_t = 0x0000_8000; +pub const IN_ONLYDIR:       ::uint32_t = 0x0100_0000; +pub const IN_DONT_FOLLOW:   ::uint32_t = 0x0200_0000; +// pub const IN_EXCL_UNLINK:   ::uint32_t = 0x0400_0000; + +// pub const IN_MASK_CREATE:   ::uint32_t = 0x1000_0000; +// pub const IN_MASK_ADD:      ::uint32_t = 0x2000_0000; +pub const IN_ISDIR:         ::uint32_t = 0x4000_0000; +pub const IN_ONESHOT:       ::uint32_t = 0x8000_0000; + +pub const IN_ALL_EVENTS:    ::uint32_t = ( +  IN_ACCESS | IN_MODIFY | IN_ATTRIB | IN_CLOSE_WRITE | +  IN_CLOSE_NOWRITE | IN_OPEN | IN_MOVED_FROM | +  IN_MOVED_TO | IN_DELETE | IN_CREATE | IN_DELETE_SELF | +  IN_MOVE_SELF +); + +pub const IN_CLOEXEC: ::c_int = O_CLOEXEC; +pub const IN_NONBLOCK: ::c_int = O_NONBLOCK; + +pub const FUTEX_WAIT: ::c_int = 0; +pub const FUTEX_WAKE: ::c_int = 1; +pub const FUTEX_FD: ::c_int = 2; +pub const FUTEX_REQUEUE: ::c_int = 3; +pub const FUTEX_CMP_REQUEUE: ::c_int = 4; +pub const FUTEX_WAKE_OP: ::c_int = 5; +pub const FUTEX_LOCK_PI: ::c_int = 6; +pub const FUTEX_UNLOCK_PI: ::c_int = 7; +pub const FUTEX_TRYLOCK_PI: ::c_int = 8; +pub const FUTEX_WAIT_BITSET: ::c_int = 9; +pub const FUTEX_WAKE_BITSET: ::c_int = 10; +pub const FUTEX_WAIT_REQUEUE_PI: ::c_int = 11; +pub const FUTEX_CMP_REQUEUE_PI: ::c_int = 12; + +pub const FUTEX_PRIVATE_FLAG: ::c_int = 128; +pub const FUTEX_CLOCK_REALTIME: ::c_int = 256; +pub const FUTEX_CMD_MASK: ::c_int = +    !(FUTEX_PRIVATE_FLAG | FUTEX_CLOCK_REALTIME); +  f! { +    pub fn CMSG_NXTHDR(mhdr: *const msghdr, +                       cmsg: *const cmsghdr) -> *mut cmsghdr { +        let next = (cmsg as usize +                    + super::CMSG_ALIGN((*cmsg).cmsg_len as usize)) +            as *mut cmsghdr; +        let max = (*mhdr).msg_control as usize +            + (*mhdr).msg_controllen as usize; +        if (next.offset(1)) as usize > max { +            0 as *mut cmsghdr +        } else { +            next as *mut cmsghdr +        } +    } +      pub fn CPU_ZERO(cpuset: &mut cpu_set_t) -> () {          for slot in cpuset.__bits.iter_mut() {              *slot = 0; @@ -1484,21 +1880,21 @@ f! {      }      pub fn CPU_SET(cpu: usize, cpuset: &mut cpu_set_t) -> () { -        let size_in___bits = 8 * mem::size_of_val(&cpuset.__bits[0]); +        let size_in___bits = 8 * ::mem::size_of_val(&cpuset.__bits[0]);          let (idx, offset) = (cpu / size_in___bits, cpu % size_in___bits);          cpuset.__bits[idx] |= 1 << offset;          ()      }      pub fn CPU_CLR(cpu: usize, cpuset: &mut cpu_set_t) -> () { -        let size_in___bits = 8 * mem::size_of_val(&cpuset.__bits[0]); +        let size_in___bits = 8 * ::mem::size_of_val(&cpuset.__bits[0]);          let (idx, offset) = (cpu / size_in___bits, cpu % size_in___bits);          cpuset.__bits[idx] &= !(1 << offset);          ()      }      pub fn CPU_ISSET(cpu: usize, cpuset: &cpu_set_t) -> bool { -        let size_in___bits = 8 * mem::size_of_val(&cpuset.__bits[0]); +        let size_in___bits = 8 * ::mem::size_of_val(&cpuset.__bits[0]);          let (idx, offset) = (cpu / size_in___bits, cpu % size_in___bits);          0 != (cpuset.__bits[idx] & (1 << offset))      } @@ -1654,7 +2050,7 @@ extern {      pub fn setfsuid(uid: ::uid_t) -> ::c_int;      pub fn sigsuspend(mask: *const ::sigset_t) -> ::c_int;      #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrgid_r")] -    pub fn getgrgid_r(uid: ::uid_t, +    pub fn getgrgid_r(gid: ::gid_t,                        grp: *mut ::group,                        buf: *mut ::c_char,                        buflen: ::size_t, @@ -1700,9 +2096,9 @@ extern {      #[cfg_attr(target_os = "solaris", link_name = "__posix_sigwait")]      pub fn sigwait(set: *const sigset_t,                     sig: *mut ::c_int) -> ::c_int; -    pub fn pthread_atfork(prepare: Option<unsafe extern fn()>, -                          parent: Option<unsafe extern fn()>, -                          child: Option<unsafe extern fn()>) -> ::c_int; +    pub fn pthread_atfork(prepare: ::Option<unsafe extern fn()>, +                          parent: ::Option<unsafe extern fn()>, +                          child: ::Option<unsafe extern fn()>) -> ::c_int;      pub fn getgrgid(gid: ::gid_t) -> *mut ::group;      pub fn getgrouplist(user: *const ::c_char,                          group: ::gid_t, @@ -1722,6 +2118,16 @@ extern {                            f: extern fn(*mut ::c_void) -> *mut ::c_void,                            value: *mut ::c_void) -> ::c_int;      pub fn __errno() -> *mut ::c_int; +    pub fn inotify_rm_watch(fd: ::c_int, wd: ::uint32_t) -> ::c_int; +    pub fn sendmmsg(sockfd: ::c_int, msgvec: *const ::mmsghdr, vlen: ::c_uint, +                    flags: ::c_int) -> ::c_int; +    pub fn recvmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::c_uint, +                    flags: ::c_int, timeout: *const ::timespec) -> ::c_int; +    pub fn inotify_init() -> ::c_int; +    pub fn inotify_init1(flags: ::c_int) -> ::c_int; +    pub fn inotify_add_watch(fd: ::c_int, +                             path: *const ::c_char, +                             mask: ::uint32_t) -> ::c_int;  }  cfg_if! { diff --git a/libc/src/unix/notbsd/emscripten/align.rs b/libc/src/unix/notbsd/emscripten/align.rs new file mode 100644 index 0000000..26a49b2 --- /dev/null +++ b/libc/src/unix/notbsd/emscripten/align.rs @@ -0,0 +1,66 @@ +macro_rules! expand_align { +    () => { +        s! { +            #[repr(align(4))] +            pub struct pthread_mutex_t { +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            #[repr(align(4))] +            pub struct pthread_rwlock_t { +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } + +            #[repr(align(4))] +            pub struct pthread_mutexattr_t { +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            #[repr(align(4))] +            pub struct pthread_rwlockattr_t { +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCKATTR_T], +            } + +            #[repr(align(4))] +            pub struct pthread_condattr_t { +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } + +        s_no_extra_traits! { +            #[cfg_attr(target_pointer_width = "32", +                       repr(align(4)))] +            #[cfg_attr(target_pointer_width = "64", +                       repr(align(8)))] +            pub struct pthread_cond_t { +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } +        } + +        cfg_if! { +            if #[cfg(feature = "extra_traits")] { +                impl PartialEq for pthread_cond_t { +                    fn eq(&self, other: &pthread_cond_t) -> bool { +                        self.size +                            .iter() +                            .zip(other.size.iter()) +                            .all(|(a,b)| a == b) +                    } +                } +                impl Eq for pthread_cond_t {} +                impl ::fmt::Debug for pthread_cond_t { +                    fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                        f.debug_struct("pthread_cond_t") +                            // FIXME: .field("size", &self.size) +                            .finish() +                    } +                } +                impl ::hash::Hash for pthread_cond_t { +                    fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                        self.size.hash(state); +                    } +                } +            } +        } +    } +} diff --git a/libc/src/unix/notbsd/emscripten.rs b/libc/src/unix/notbsd/emscripten/mod.rs index 28791d8..0f8c76e 100644 --- a/libc/src/unix/notbsd/emscripten.rs +++ b/libc/src/unix/notbsd/emscripten/mod.rs @@ -1,5 +1,3 @@ -use dox::{mem, Option}; -  pub type c_char = i8;  pub type wchar_t = i32;  pub type useconds_t = u32; @@ -35,25 +33,14 @@ pub type c_long = i32;  pub type c_ulong = u32;  pub type nlink_t = u32; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum fpos64_t {} // TODO: fill this out with a struct +impl ::Copy for fpos64_t {} +impl ::Clone for fpos64_t { +    fn clone(&self) -> fpos64_t { *self } +}  s! { -    pub struct dirent { -        pub d_ino: ::ino_t, -        pub d_off: ::off_t, -        pub d_reclen: ::c_ushort, -        pub d_type: ::c_uchar, -        pub d_name: [::c_char; 256], -    } - -    pub struct dirent64 { -        pub d_ino: ::ino64_t, -        pub d_off: ::off64_t, -        pub d_reclen: ::c_ushort, -        pub d_type: ::c_uchar, -        pub d_name: [::c_char; 256], -    } -      pub struct rlimit64 {          pub rlim_cur: rlim64_t,          pub rlim_max: rlim64_t, @@ -72,51 +59,6 @@ s! {          __unused5: *mut ::c_void,      } -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_mutex_t { -        #[cfg(not(feature = "align"))] -        __align: [::c_long; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEX_T], -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_rwlock_t { -        #[cfg(not(feature = "align"))] -        __align: [::c_long; 0], -        size: [u8; __SIZEOF_PTHREAD_RWLOCK_T], -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_mutexattr_t { -        #[cfg(not(feature = "align"))] -        __align: [::c_int; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEXATTR_T], -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_rwlockattr_t { -        #[cfg(not(feature = "align"))] -        __align: [::c_int; 0], -        size: [u8; __SIZEOF_PTHREAD_RWLOCKATTR_T], -    } - -    #[cfg_attr(all(feature = "align", target_pointer_width = "32"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", target_pointer_width = "64"), -               repr(align(8)))] -    pub struct pthread_cond_t { -        #[cfg(not(feature = "align"))] -        __align: [*const ::c_void; 0], -        size: [u8; __SIZEOF_PTHREAD_COND_T], -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_condattr_t { -        #[cfg(not(feature = "align"))] -        __align: [::c_int; 0], -        size: [u8; __SIZEOF_PTHREAD_CONDATTR_T], -    } -      pub struct passwd {          pub pw_name: *mut ::c_char,          pub pw_passwd: *mut ::c_char, @@ -225,11 +167,6 @@ s! {          pub msgseg: ::c_ushort,      } -    pub struct mmsghdr { -        pub msg_hdr: ::msghdr, -        pub msg_len: ::c_uint, -    } -      pub struct sembuf {          pub sem_num: ::c_ushort,          pub sem_op: ::c_short, @@ -257,7 +194,7 @@ s! {          pub sa_sigaction: ::sighandler_t,          pub sa_mask: ::sigset_t,          pub sa_flags: ::c_int, -        pub sa_restorer: ::dox::Option<extern fn()>, +        pub sa_restorer: ::Option<extern fn()>,      }      pub struct ipc_perm { @@ -291,23 +228,6 @@ s! {          pub l_pid: ::pid_t,      } -    pub struct sysinfo { -        pub uptime: ::c_ulong, -        pub loads: [::c_ulong; 3], -        pub totalram: ::c_ulong, -        pub freeram: ::c_ulong, -        pub sharedram: ::c_ulong, -        pub bufferram: ::c_ulong, -        pub totalswap: ::c_ulong, -        pub freeswap: ::c_ulong, -        pub procs: ::c_ushort, -        pub pad: ::c_ushort, -        pub totalhigh: ::c_ulong, -        pub freehigh: ::c_ulong, -        pub mem_unit: ::c_uint, -        pub __reserved: [::c_char; 256], -    } -      pub struct pthread_attr_t {          __size: [u32; 11]      } @@ -482,6 +402,177 @@ s! {      }  } +s_no_extra_traits! { +    pub struct dirent { +        pub d_ino: ::ino_t, +        pub d_off: ::off_t, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } + +    pub struct dirent64 { +        pub d_ino: ::ino64_t, +        pub d_off: ::off64_t, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } + +    pub struct sysinfo { +        pub uptime: ::c_ulong, +        pub loads: [::c_ulong; 3], +        pub totalram: ::c_ulong, +        pub freeram: ::c_ulong, +        pub sharedram: ::c_ulong, +        pub bufferram: ::c_ulong, +        pub totalswap: ::c_ulong, +        pub freeswap: ::c_ulong, +        pub procs: ::c_ushort, +        pub pad: ::c_ushort, +        pub totalhigh: ::c_ulong, +        pub freehigh: ::c_ulong, +        pub mem_unit: ::c_uint, +        pub __reserved: [::c_char; 256], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_ino == other.d_ino +                    && self.d_off == other.d_off +                    && self.d_reclen == other.d_reclen +                    && self.d_type == other.d_type +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for dirent {} +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_ino", &self.d_ino) +                    .field("d_off", &self.d_off) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_type", &self.d_type) +                    // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_ino.hash(state); +                self.d_off.hash(state); +                self.d_reclen.hash(state); +                self.d_type.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for dirent64 { +            fn eq(&self, other: &dirent64) -> bool { +                self.d_ino == other.d_ino +                    && self.d_off == other.d_off +                    && self.d_reclen == other.d_reclen +                    && self.d_type == other.d_type +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for dirent64 {} +        impl ::fmt::Debug for dirent64 { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent64") +                    .field("d_ino", &self.d_ino) +                    .field("d_off", &self.d_off) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_type", &self.d_type) +                    // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } +        impl ::hash::Hash for dirent64 { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_ino.hash(state); +                self.d_off.hash(state); +                self.d_reclen.hash(state); +                self.d_type.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for sysinfo { +            fn eq(&self, other: &sysinfo) -> bool { +                self.uptime == other.uptime +                    && self.loads == other.loads +                    && self.totalram == other.totalram +                    && self.freeram == other.freeram +                    && self.sharedram == other.sharedram +                    && self.bufferram == other.bufferram +                    && self.totalswap == other.totalswap +                    && self.freeswap == other.freeswap +                    && self.procs == other.procs +                    && self.pad == other.pad +                    && self.totalhigh == other.totalhigh +                    && self.freehigh == other.freehigh +                    && self.mem_unit == other.mem_unit +                    && self +                    .__reserved +                    .iter() +                    .zip(other.__reserved.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sysinfo {} +        impl ::fmt::Debug for sysinfo { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sysinfo") +                    .field("uptime", &self.uptime) +                    .field("loads", &self.loads) +                    .field("totalram", &self.totalram) +                    .field("freeram", &self.freeram) +                    .field("sharedram", &self.sharedram) +                    .field("bufferram", &self.bufferram) +                    .field("totalswap", &self.totalswap) +                    .field("freeswap", &self.freeswap) +                    .field("procs", &self.procs) +                    .field("pad", &self.pad) +                    .field("totalhigh", &self.totalhigh) +                    .field("freehigh", &self.freehigh) +                    .field("mem_unit", &self.mem_unit) +                    // FIXME: .field("__reserved", &self.__reserved) +                    .finish() +            } +        } +        impl ::hash::Hash for sysinfo { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.uptime.hash(state); +                self.loads.hash(state); +                self.totalram.hash(state); +                self.freeram.hash(state); +                self.sharedram.hash(state); +                self.bufferram.hash(state); +                self.totalswap.hash(state); +                self.freeswap.hash(state); +                self.procs.hash(state); +                self.pad.hash(state); +                self.totalhigh.hash(state); +                self.freehigh.hash(state); +                self.mem_unit.hash(state); +                self.__reserved.hash(state); +            } +        } +    } +} +  pub const ABDAY_1: ::nl_item = 0x20000;  pub const ABDAY_2: ::nl_item = 0x20001;  pub const ABDAY_3: ::nl_item = 0x20002; @@ -1510,6 +1601,23 @@ pub const ARPD_FLUSH: ::c_ushort = 0x03;  pub const ATF_MAGIC: ::c_int = 0x80;  f! { +    pub fn CMSG_NXTHDR(mhdr: *const msghdr, +                       cmsg: *const cmsghdr) -> *mut cmsghdr { +        if ((*cmsg).cmsg_len as usize) < ::mem::size_of::<cmsghdr>() { +            return 0 as *mut cmsghdr; +        }; +        let next = (cmsg as usize + +                    super::CMSG_ALIGN((*cmsg).cmsg_len as usize)) +            as *mut cmsghdr; +        let max = (*mhdr).msg_control as usize +            + (*mhdr).msg_controllen as usize; +        if (next.offset(1)) as usize > max { +            0 as *mut cmsghdr +        } else { +            next as *mut cmsghdr +        } +    } +      pub fn CPU_ZERO(cpuset: &mut cpu_set_t) -> () {          for slot in cpuset.bits.iter_mut() {              *slot = 0; @@ -1517,21 +1625,23 @@ f! {      }      pub fn CPU_SET(cpu: usize, cpuset: &mut cpu_set_t) -> () { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc +        let size_in_bits +            = 8 * ::mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          cpuset.bits[idx] |= 1 << offset;          ()      }      pub fn CPU_CLR(cpu: usize, cpuset: &mut cpu_set_t) -> () { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc +        let size_in_bits +            = 8 * ::mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          cpuset.bits[idx] &= !(1 << offset);          ()      }      pub fn CPU_ISSET(cpu: usize, cpuset: &cpu_set_t) -> bool { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); +        let size_in_bits = 8 * ::mem::size_of_val(&cpuset.bits[0]);          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          0 != (cpuset.bits[idx] & (1 << offset))      } @@ -1640,7 +1750,7 @@ extern {      pub fn glob(pattern: *const c_char,                  flags: ::c_int, -                errfunc: Option<extern fn(epath: *const c_char, +                errfunc: ::Option<extern fn(epath: *const c_char,                                            errno: ::c_int) -> ::c_int>,                  pglob: *mut ::glob_t) -> ::c_int;      pub fn globfree(pglob: *mut ::glob_t); @@ -1666,9 +1776,9 @@ extern {      pub fn getdomainname(name: *mut ::c_char, len: ::size_t) -> ::c_int;      pub fn setdomainname(name: *const ::c_char, len: ::size_t) -> ::c_int; -    pub fn sendmmsg(sockfd: ::c_int, msgvec: *mut mmsghdr, vlen: ::c_uint, +    pub fn sendmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::c_uint,                      flags: ::c_int) -> ::c_int; -    pub fn recvmmsg(sockfd: ::c_int, msgvec: *mut mmsghdr, vlen: ::c_uint, +    pub fn recvmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::c_uint,                      flags: ::c_int, timeout: *mut ::timespec) -> ::c_int;      pub fn sync();      pub fn ioctl(fd: ::c_int, request: ::c_int, ...) -> ::c_int; @@ -1679,3 +1789,14 @@ extern {                            f: extern fn(*mut ::c_void) -> *mut ::c_void,                            value: *mut ::c_void) -> ::c_int;  } + +cfg_if! { +    if #[cfg(libc_align)] { +        #[macro_use] +        mod align; +    } else { +        #[macro_use] +        mod no_align; +    } +} +expand_align!(); diff --git a/libc/src/unix/notbsd/emscripten/no_align.rs b/libc/src/unix/notbsd/emscripten/no_align.rs new file mode 100644 index 0000000..ece4dff --- /dev/null +++ b/libc/src/unix/notbsd/emscripten/no_align.rs @@ -0,0 +1,63 @@ +macro_rules! expand_align { +    () => { +        s! { +            pub struct pthread_mutex_t { +                __align: [::c_long; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            pub struct pthread_rwlock_t { +                __align: [::c_long; 0], +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } + +            pub struct pthread_mutexattr_t { +                __align: [::c_int; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            pub struct pthread_rwlockattr_t { +                __align: [::c_int; 0], +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCKATTR_T], +            } + +            pub struct pthread_condattr_t { +                __align: [::c_int; 0], +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } + +        s_no_extra_traits! { +            pub struct pthread_cond_t { +                __align: [*const ::c_void; 0], +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } +        } + +        cfg_if! { +            if #[cfg(feature = "extra_traits")] { +                impl PartialEq for pthread_cond_t { +                    fn eq(&self, other: &pthread_cond_t) -> bool { +                        self.size +                            .iter() +                            .zip(other.size.iter()) +                            .all(|(a,b)| a == b) +                    } +                } +                impl Eq for pthread_cond_t {} +                impl ::fmt::Debug for pthread_cond_t { +                    fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                        f.debug_struct("pthread_cond_t") +                            // FIXME: .field("size", &self.size) +                            .finish() +                    } +                } +                impl ::hash::Hash for pthread_cond_t { +                    fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                        self.size.hash(state); +                    } +                } +            } +        } +    } +} diff --git a/libc/src/unix/notbsd/linux/align.rs b/libc/src/unix/notbsd/linux/align.rs new file mode 100644 index 0000000..0ff4649 --- /dev/null +++ b/libc/src/unix/notbsd/linux/align.rs @@ -0,0 +1,98 @@ +macro_rules! expand_align { +    () => { +        s! { +            #[cfg_attr(any(target_pointer_width = "32", +                           target_arch = "x86_64", +                           target_arch = "powerpc64", +                           target_arch = "mips64", +                           target_arch = "s390x", +                           target_arch = "sparc64", +                           target_arch = "aarch64"), +                       repr(align(4)))] +            #[cfg_attr(not(any(target_pointer_width = "32", +                               target_arch = "x86_64", +                               target_arch = "powerpc64", +                               target_arch = "mips64", +                               target_arch = "s390x", +                               target_arch = "sparc64", +                               target_arch = "aarch64")), +                       repr(align(8)))] +            pub struct pthread_mutexattr_t { +                #[doc(hidden)] +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            #[cfg_attr(any(target_env = "musl", target_pointer_width = "32"), +                       repr(align(4)))] +            #[cfg_attr(all(not(target_env = "musl"), +                           target_pointer_width = "64"), +                       repr(align(8)))] +            pub struct pthread_rwlockattr_t { +                #[doc(hidden)] +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCKATTR_T], +            } + +            #[repr(align(4))] +            pub struct pthread_condattr_t { +                #[doc(hidden)] +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } + +        s_no_extra_traits! { +            #[cfg_attr(all(target_env = "musl", +                           target_pointer_width = "32"), +                       repr(align(4)))] +            #[cfg_attr(all(target_env = "musl", +                           target_pointer_width = "64"), +                       repr(align(8)))] +            #[cfg_attr(all(not(target_env = "musl"), +                           target_arch = "x86"), +                       repr(align(4)))] +            #[cfg_attr(all(not(target_env = "musl"), +                           not(target_arch = "x86")), +                       repr(align(8)))] +            pub struct pthread_cond_t { +                #[doc(hidden)] +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } + +            #[cfg_attr(all(target_pointer_width = "32", +                           any(target_arch = "mips", +                               target_arch = "arm", +                               target_arch = "powerpc", +                               target_arch = "x86_64", +                               target_arch = "x86")), +                       repr(align(4)))] +            #[cfg_attr(any(target_pointer_width = "64", +                           not(any(target_arch = "mips", +                                   target_arch = "arm", +                                   target_arch = "powerpc", +                                   target_arch = "x86_64", +                                   target_arch = "x86"))), +                       repr(align(8)))] +            pub struct pthread_mutex_t { +                #[doc(hidden)] +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            #[cfg_attr(all(target_pointer_width = "32", +                           any(target_arch = "mips", +                               target_arch = "arm", +                               target_arch = "powerpc", +                               target_arch = "x86_64", +                               target_arch = "x86")), +                       repr(align(4)))] +            #[cfg_attr(any(target_pointer_width = "64", +                           not(any(target_arch = "mips", +                                   target_arch = "arm", +                                   target_arch = "powerpc", +                                   target_arch = "x86_64", +                                   target_arch = "x86"))), +                       repr(align(8)))] +            pub struct pthread_rwlock_t { +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } +        } +    } +} diff --git a/libc/src/unix/notbsd/linux/mips/align.rs b/libc/src/unix/notbsd/linux/mips/align.rs new file mode 100644 index 0000000..4a0e074 --- /dev/null +++ b/libc/src/unix/notbsd/linux/mips/align.rs @@ -0,0 +1,13 @@ +s! { +    // FIXME this is actually a union +    #[cfg_attr(target_pointer_width = "32", +               repr(align(4)))] +    #[cfg_attr(target_pointer_width = "64", +               repr(align(8)))] +    pub struct sem_t { +        #[cfg(target_pointer_width = "32")] +        __size: [::c_char; 16], +        #[cfg(target_pointer_width = "64")] +        __size: [::c_char; 32], +    } +} diff --git a/libc/src/unix/notbsd/linux/mips/mips32.rs b/libc/src/unix/notbsd/linux/mips/mips32.rs index a6c08a5..d9d5589 100644 --- a/libc/src/unix/notbsd/linux/mips/mips32.rs +++ b/libc/src/unix/notbsd/linux/mips/mips32.rs @@ -133,7 +133,7 @@ s! {          pub sa_flags: ::c_int,          pub sa_sigaction: ::sighandler_t,          pub sa_mask: sigset_t, -        pub sa_restorer: ::dox::Option<extern fn()>, +        pub sa_restorer: ::Option<extern fn()>,          _resv: [::c_int; 1],      } @@ -353,7 +353,6 @@ pub const SYS_mknod: ::c_long = 4000 +  14;  pub const SYS_chmod: ::c_long = 4000 +  15;  pub const SYS_lchown: ::c_long = 4000 +  16;  pub const SYS_break: ::c_long = 4000 +  17; -pub const SYS_unused18: ::c_long = 4000 +  18;  pub const SYS_lseek: ::c_long = 4000 +  19;  pub const SYS_getpid: ::c_long = 4000 +  20;  pub const SYS_mount: ::c_long = 4000 +  21; @@ -363,7 +362,6 @@ pub const SYS_getuid: ::c_long = 4000 +  24;  pub const SYS_stime: ::c_long = 4000 +  25;  pub const SYS_ptrace: ::c_long = 4000 +  26;  pub const SYS_alarm: ::c_long = 4000 +  27; -pub const SYS_unused28: ::c_long = 4000 +  28;  pub const SYS_pause: ::c_long = 4000 +  29;  pub const SYS_utime: ::c_long = 4000 +  30;  pub const SYS_stty: ::c_long = 4000 +  31; @@ -394,7 +392,6 @@ pub const SYS_fcntl: ::c_long = 4000 +  55;  pub const SYS_mpx: ::c_long = 4000 +  56;  pub const SYS_setpgid: ::c_long = 4000 +  57;  pub const SYS_ulimit: ::c_long = 4000 +  58; -pub const SYS_unused59: ::c_long = 4000 +  59;  pub const SYS_umask: ::c_long = 4000 +  60;  pub const SYS_chroot: ::c_long = 4000 +  61;  pub const SYS_ustat: ::c_long = 4000 +  62; @@ -417,9 +414,7 @@ pub const SYS_gettimeofday: ::c_long = 4000 +  78;  pub const SYS_settimeofday: ::c_long = 4000 +  79;  pub const SYS_getgroups: ::c_long = 4000 +  80;  pub const SYS_setgroups: ::c_long = 4000 +  81; -pub const SYS_reserved82: ::c_long = 4000 +  82;  pub const SYS_symlink: ::c_long = 4000 +  83; -pub const SYS_unused84: ::c_long = 4000 +  84;  pub const SYS_readlink: ::c_long = 4000 +  85;  pub const SYS_uselib: ::c_long = 4000 +  86;  pub const SYS_swapon: ::c_long = 4000 +  87; @@ -444,7 +439,6 @@ pub const SYS_getitimer: ::c_long = 4000 + 105;  pub const SYS_stat: ::c_long = 4000 + 106;  pub const SYS_lstat: ::c_long = 4000 + 107;  pub const SYS_fstat: ::c_long = 4000 + 108; -pub const SYS_unused109: ::c_long = 4000 + 109;  pub const SYS_iopl: ::c_long = 4000 + 110;  pub const SYS_vhangup: ::c_long = 4000 + 111;  pub const SYS_idle: ::c_long = 4000 + 112; @@ -485,7 +479,6 @@ pub const SYS_writev: ::c_long = 4000 + 146;  pub const SYS_cacheflush: ::c_long = 4000 + 147;  pub const SYS_cachectl: ::c_long = 4000 + 148;  pub const SYS_sysmips: ::c_long = 4000 + 149; -pub const SYS_unused150: ::c_long = 4000 + 150;  pub const SYS_getsid: ::c_long = 4000 + 151;  pub const SYS_fdatasync: ::c_long = 4000 + 152;  pub const SYS__sysctl: ::c_long = 4000 + 153; @@ -556,7 +549,6 @@ pub const SYS_mincore: ::c_long = 4000 + 217;  pub const SYS_madvise: ::c_long = 4000 + 218;  pub const SYS_getdents64: ::c_long = 4000 + 219;  pub const SYS_fcntl64: ::c_long = 4000 + 220; -pub const SYS_reserved221: ::c_long = 4000 + 221;  pub const SYS_gettid: ::c_long = 4000 + 222;  pub const SYS_readahead: ::c_long = 4000 + 223;  pub const SYS_setxattr: ::c_long = 4000 + 224; diff --git a/libc/src/unix/notbsd/linux/mips/mips64.rs b/libc/src/unix/notbsd/linux/mips/mips64.rs index e8b02a3..f480e50 100644 --- a/libc/src/unix/notbsd/linux/mips/mips64.rs +++ b/libc/src/unix/notbsd/linux/mips/mips64.rs @@ -131,7 +131,7 @@ s! {          pub sa_flags: ::c_int,          pub sa_sigaction: ::sighandler_t,          pub sa_mask: sigset_t, -        pub sa_restorer: ::dox::Option<extern fn()>, +        pub sa_restorer: ::Option<extern fn()>,      }      pub struct stack_t { @@ -496,7 +496,6 @@ pub const SYS_nfsservctl: ::c_long = 5000 + 173;  pub const SYS_getpmsg: ::c_long = 5000 + 174;  pub const SYS_putpmsg: ::c_long = 5000 + 175;  pub const SYS_afs_syscall: ::c_long = 5000 + 176; -pub const SYS_reserved177: ::c_long = 5000 + 177;  pub const SYS_gettid: ::c_long = 5000 + 178;  pub const SYS_readahead: ::c_long = 5000 + 179;  pub const SYS_setxattr: ::c_long = 5000 + 180; @@ -512,7 +511,6 @@ pub const SYS_removexattr: ::c_long = 5000 + 189;  pub const SYS_lremovexattr: ::c_long = 5000 + 190;  pub const SYS_fremovexattr: ::c_long = 5000 + 191;  pub const SYS_tkill: ::c_long = 5000 + 192; -pub const SYS_reserved193: ::c_long = 5000 + 193;  pub const SYS_futex: ::c_long = 5000 + 194;  pub const SYS_sched_setaffinity: ::c_long = 5000 + 195;  pub const SYS_sched_getaffinity: ::c_long = 5000 + 196; diff --git a/libc/src/unix/notbsd/linux/mips/mod.rs b/libc/src/unix/notbsd/linux/mips/mod.rs index 8809bef..35534b4 100644 --- a/libc/src/unix/notbsd/linux/mips/mod.rs +++ b/libc/src/unix/notbsd/linux/mips/mod.rs @@ -20,20 +20,6 @@ s! {          __unused5: *mut ::c_void,      } -    // FIXME this is actually a union -    #[cfg_attr(all(feature = "align", target_pointer_width = "32"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", target_pointer_width = "64"), -               repr(align(8)))] -    pub struct sem_t { -        #[cfg(target_pointer_width = "32")] -        __size: [::c_char; 16], -        #[cfg(target_pointer_width = "64")] -        __size: [::c_char; 32], -        #[cfg(not(feature = "align"))] -        __align: [::c_long; 0], -    } -      pub struct termios2 {          pub c_iflag: ::tcflag_t,          pub c_oflag: ::tcflag_t, @@ -720,10 +706,10 @@ pub const GENL_UNS_ADMIN_PERM: ::c_int = 0x10;  pub const GENL_ID_VFS_DQUOT: ::c_int = ::NLMSG_MIN_TYPE + 1;  pub const GENL_ID_PMCRAID: ::c_int = ::NLMSG_MIN_TYPE + 2; -pub const NFT_TABLE_MAXNAMELEN: ::c_int = 32; -pub const NFT_CHAIN_MAXNAMELEN: ::c_int = 32; -pub const NFT_SET_MAXNAMELEN: ::c_int = 32; -pub const NFT_OBJ_MAXNAMELEN: ::c_int = 32; +pub const NFT_TABLE_MAXNAMELEN: ::c_int = 256; +pub const NFT_CHAIN_MAXNAMELEN: ::c_int = 256; +pub const NFT_SET_MAXNAMELEN: ::c_int = 256; +pub const NFT_OBJ_MAXNAMELEN: ::c_int = 256;  pub const NFT_USERDATA_MAXLEN: ::c_int = 256;  pub const NFT_REG_VERDICT: ::c_int = 0; @@ -780,7 +766,7 @@ pub const NFT_MSG_NEWOBJ: ::c_int = 18;  pub const NFT_MSG_GETOBJ: ::c_int = 19;  pub const NFT_MSG_DELOBJ: ::c_int = 20;  pub const NFT_MSG_GETOBJ_RESET: ::c_int = 21; -pub const NFT_MSG_MAX: ::c_int = 22; +pub const NFT_MSG_MAX: ::c_int = 25;  pub const NFT_SET_ANONYMOUS: ::c_int = 0x1;  pub const NFT_SET_CONSTANT: ::c_int = 0x2; @@ -927,7 +913,7 @@ extern {                       sz: ::c_int) -> ::c_int;      pub fn glob64(pattern: *const ::c_char,                    flags: ::c_int, -                  errfunc: ::dox::Option<extern fn(epath: *const ::c_char, +                  errfunc: ::Option<extern fn(epath: *const ::c_char,                                                     errno: ::c_int)                                                     -> ::c_int>,                    pglob: *mut glob64_t) -> ::c_int; @@ -962,3 +948,13 @@ cfg_if! {          // Unknown target_arch      }  } + +cfg_if! { +    if #[cfg(libc_align)] { +        mod align; +        pub use self::align::*; +    } else { +        mod no_align; +        pub use self::no_align::*; +    } +} diff --git a/libc/src/unix/notbsd/linux/mips/no_align.rs b/libc/src/unix/notbsd/linux/mips/no_align.rs new file mode 100644 index 0000000..e32bf67 --- /dev/null +++ b/libc/src/unix/notbsd/linux/mips/no_align.rs @@ -0,0 +1,10 @@ +s! { +    // FIXME this is actually a union +    pub struct sem_t { +        #[cfg(target_pointer_width = "32")] +        __size: [::c_char; 16], +        #[cfg(target_pointer_width = "64")] +        __size: [::c_char; 32], +        __align: [::c_long; 0], +    } +} diff --git a/libc/src/unix/notbsd/linux/mod.rs b/libc/src/unix/notbsd/linux/mod.rs index 8669a06..2419a41 100644 --- a/libc/src/unix/notbsd/linux/mod.rs +++ b/libc/src/unix/notbsd/linux/mod.rs @@ -1,7 +1,5 @@  //! Linux-specific definitions for linux-like values -use dox::{mem, Option}; -  pub type useconds_t = u32;  pub type dev_t = u64;  pub type socklen_t = u32; @@ -38,25 +36,14 @@ pub type Elf64_Sxword = i64;  pub type Elf32_Section = u16;  pub type Elf64_Section = u16; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum fpos64_t {} // TODO: fill this out with a struct +impl ::Copy for fpos64_t {} +impl ::Clone for fpos64_t { +    fn clone(&self) -> fpos64_t { *self } +}  s! { -    pub struct dirent { -        pub d_ino: ::ino_t, -        pub d_off: ::off_t, -        pub d_reclen: ::c_ushort, -        pub d_type: ::c_uchar, -        pub d_name: [::c_char; 256], -    } - -    pub struct dirent64 { -        pub d_ino: ::ino64_t, -        pub d_off: ::off64_t, -        pub d_reclen: ::c_ushort, -        pub d_type: ::c_uchar, -        pub d_name: [::c_char; 256], -    } -      pub struct rlimit64 {          pub rlim_cur: rlim64_t,          pub rlim_max: rlim64_t, @@ -75,150 +62,6 @@ s! {          __unused5: *mut ::c_void,      } -    #[cfg_attr(all(feature = "align", -                   target_pointer_width = "32", -                   any(target_arch = "mips", -                       target_arch = "arm", -                       target_arch = "powerpc", -                       target_arch = "x86_64", -                       target_arch = "x86")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "64", -                       not(any(target_arch = "mips", -                               target_arch = "arm", -                               target_arch = "powerpc", -                               target_arch = "x86_64", -                               target_arch = "x86")))), -               repr(align(8)))] -    pub struct pthread_mutex_t { -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc", -                      all(target_arch = "x86_64", -                          target_pointer_width = "32"))))] -        __align: [::c_long; 0], -        #[cfg(not(any(feature = "align", -                      target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc", -                      all(target_arch = "x86_64", -                          target_pointer_width = "32"))))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEX_T], -    } - -    #[cfg_attr(all(feature = "align", -                   target_pointer_width = "32", -                   any(target_arch = "mips", -                       target_arch = "arm", -                       target_arch = "powerpc", -                       target_arch = "x86_64", -                       target_arch = "x86")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "64", -                       not(any(target_arch = "mips", -                               target_arch = "arm", -                               target_arch = "powerpc", -                               target_arch = "x86_64", -                               target_arch = "x86")))), -               repr(align(8)))] -    pub struct pthread_rwlock_t { -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc", -                      all(target_arch = "x86_64", -                          target_pointer_width = "32"))))] -        __align: [::c_long; 0], -        #[cfg(not(any(feature = "align", -                      target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc", -                      all(target_arch = "x86_64", -                          target_pointer_width = "32"))))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_RWLOCK_T], -    } - -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "32", -                       target_arch = "x86_64", target_arch = "powerpc64", -                       target_arch = "mips64", target_arch = "s390x", -                       target_arch = "sparc64", -                       all(target_arch = "aarch64", target_env = "musl"))), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   not(any(target_pointer_width = "32", -                           target_arch = "x86_64", target_arch = "powerpc64", -                           target_arch = "mips64", target_arch = "s390x", -                           target_arch = "sparc64", -                           all(target_arch = "aarch64", target_env = "musl")))), -               repr(align(8)))] -    pub struct pthread_mutexattr_t { -        #[cfg(all(not(features = "align"), -                  any(target_arch = "x86_64", target_arch = "powerpc64", -                      target_arch = "mips64", target_arch = "s390x", -                      target_arch = "sparc64", -                      all(target_arch = "aarch64", target_env = "musl"))))] -        __align: [::c_int; 0], -        #[cfg(all(not(features = "align"), -                  not(any(target_arch = "x86_64", target_arch = "powerpc64", -                          target_arch = "mips64", target_arch = "s390x", -                          target_arch = "sparc64", -                          all(target_arch = "aarch64", target_env = "musl")))))] -        __align: [::c_long; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEXATTR_T], -    } - -    #[cfg_attr(all(feature = "align", -                   any(target_env = "musl", target_pointer_width = "32")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   not(target_env = "musl"), -                   target_pointer_width = "64"), -               repr(align(8)))] -    pub struct pthread_rwlockattr_t { -        #[cfg(all(not(feature = "align"), target_env = "musl"))] -        __align: [::c_int; 0], -        #[cfg(all(not(feature = "align"), not(target_env = "musl")))] -        __align: [::c_long; 0], -        size: [u8; __SIZEOF_PTHREAD_RWLOCKATTR_T], -    } - -    #[cfg_attr(all(feature = "align", -                   target_env = "musl", -                   target_pointer_width = "32"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   target_env = "musl", -                   target_pointer_width = "64"), -               repr(align(8)))] -    #[cfg_attr(all(feature = "align", -                   not(target_env = "musl"), -                   target_arch = "x86"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   not(target_env = "musl"), -                   not(target_arch = "x86")), -               repr(align(8)))] -    pub struct pthread_cond_t { -        #[cfg(all(not(feature = "align"), target_env = "musl"))] -        __align: [*const ::c_void; 0], -        #[cfg(not(any(feature = "align", target_env = "musl")))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_COND_T], -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_condattr_t { -        #[cfg(not(feature = "align"))] -        __align: [::c_int; 0], -        size: [u8; __SIZEOF_PTHREAD_CONDATTR_T], -    } -      pub struct passwd {          pub pw_name: *mut ::c_char,          pub pw_passwd: *mut ::c_char, @@ -346,11 +189,6 @@ s! {          pub msgseg: ::c_ushort,      } -    pub struct mmsghdr { -        pub msg_hdr: ::msghdr, -        pub msg_len: ::c_uint, -    } -      pub struct sembuf {          pub sem_num: ::c_ushort,          pub sem_op: ::c_short, @@ -655,6 +493,265 @@ s! {          pub updated: ::c_ulong,          pub ha: [::c_uchar; ::MAX_ADDR_LEN],      } + +    pub struct inotify_event { +        pub wd: ::c_int, +        pub mask: ::uint32_t, +        pub cookie: ::uint32_t, +        pub len: ::uint32_t +    } +} + +s_no_extra_traits!{ +    pub struct dirent { +        pub d_ino: ::ino_t, +        pub d_off: ::off_t, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } + +    pub struct dirent64 { +        pub d_ino: ::ino64_t, +        pub d_off: ::off64_t, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } + +    pub struct sockaddr_alg { +        pub salg_family: ::sa_family_t, +        pub salg_type: [::c_uchar; 14], +        pub salg_feat: u32, +        pub salg_mask: u32, +        pub salg_name: [::c_uchar; 64], +    } + +    pub struct af_alg_iv { +        pub ivlen: u32, +        pub iv: [::c_uchar; 0], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for dirent { +            fn eq(&self, other: &dirent) -> bool { +                self.d_ino == other.d_ino +                    && self.d_off == other.d_off +                    && self.d_reclen == other.d_reclen +                    && self.d_type == other.d_type +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for dirent {} + +        impl ::fmt::Debug for dirent { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent") +                    .field("d_ino", &self.d_ino) +                    .field("d_off", &self.d_off) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_type", &self.d_type) +                // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } + +        impl ::hash::Hash for dirent { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_ino.hash(state); +                self.d_off.hash(state); +                self.d_reclen.hash(state); +                self.d_type.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for dirent64 { +            fn eq(&self, other: &dirent64) -> bool { +                self.d_ino == other.d_ino +                    && self.d_off == other.d_off +                    && self.d_reclen == other.d_reclen +                    && self.d_type == other.d_type +                    && self +                    .d_name +                    .iter() +                    .zip(other.d_name.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for dirent64 {} + +        impl ::fmt::Debug for dirent64 { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("dirent64") +                    .field("d_ino", &self.d_ino) +                    .field("d_off", &self.d_off) +                    .field("d_reclen", &self.d_reclen) +                    .field("d_type", &self.d_type) +                // FIXME: .field("d_name", &self.d_name) +                    .finish() +            } +        } + +        impl ::hash::Hash for dirent64 { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.d_ino.hash(state); +                self.d_off.hash(state); +                self.d_reclen.hash(state); +                self.d_type.hash(state); +                self.d_name.hash(state); +            } +        } + +        impl PartialEq for pthread_cond_t { +            fn eq(&self, other: &pthread_cond_t) -> bool { +                self.size.iter().zip(other.size.iter()).all(|(a,b)| a == b) +            } +        } + +        impl Eq for pthread_cond_t {} + +        impl ::fmt::Debug for pthread_cond_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_cond_t") +                // FIXME: .field("size", &self.size) +                    .finish() +            } +        } + +        impl ::hash::Hash for pthread_cond_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.size.hash(state); +            } +        } + +        impl PartialEq for pthread_mutex_t { +            fn eq(&self, other: &pthread_mutex_t) -> bool { +                self.size.iter().zip(other.size.iter()).all(|(a,b)| a == b) +            } +        } + +        impl Eq for pthread_mutex_t {} + +        impl ::fmt::Debug for pthread_mutex_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_mutex_t") +                // FIXME: .field("size", &self.size) +                    .finish() +            } +        } + +        impl ::hash::Hash for pthread_mutex_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.size.hash(state); +            } +        } + +        impl PartialEq for pthread_rwlock_t { +            fn eq(&self, other: &pthread_rwlock_t) -> bool { +                self.size.iter().zip(other.size.iter()).all(|(a,b)| a == b) +            } +        } + +        impl Eq for pthread_rwlock_t {} + +        impl ::fmt::Debug for pthread_rwlock_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("pthread_rwlock_t") +                // FIXME: .field("size", &self.size) +                    .finish() +            } +        } + +        impl ::hash::Hash for pthread_rwlock_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.size.hash(state); +            } +        } + +        impl PartialEq for sockaddr_alg { +            fn eq(&self, other: &sockaddr_alg) -> bool { +                self.salg_family == other.salg_family +                    && self +                    .salg_type +                    .iter() +                    .zip(other.salg_type.iter()) +                    .all(|(a, b)| a == b) +                    && self.salg_feat == other.salg_feat +                    && self.salg_mask == other.salg_mask +                    && self +                    .salg_name +                    .iter() +                    .zip(other.salg_name.iter()) +                    .all(|(a, b)| a == b) +           } +        } + +        impl Eq for sockaddr_alg {} + +        impl ::fmt::Debug for sockaddr_alg { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_alg") +                    .field("salg_family", &self.salg_family) +                    .field("salg_type", &self.salg_type) +                    .field("salg_feat", &self.salg_feat) +                    .field("salg_mask", &self.salg_mask) +                    .field("salg_name", &&self.salg_name[..]) +                    .finish() +            } +        } + +        impl ::hash::Hash for sockaddr_alg { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.salg_family.hash(state); +                self.salg_type.hash(state); +                self.salg_feat.hash(state); +                self.salg_mask.hash(state); +                self.salg_name.hash(state); +            } +        } + +        impl af_alg_iv { +            fn as_slice(&self) -> &[u8] { +                unsafe { +                    ::core::slice::from_raw_parts( +                        self.iv.as_ptr(), +                        self.ivlen as usize +                    ) +                } +            } +        } + +        impl PartialEq for af_alg_iv { +            fn eq(&self, other: &af_alg_iv) -> bool { +                *self.as_slice() == *other.as_slice() +           } +        } + +        impl Eq for af_alg_iv {} + +        impl ::fmt::Debug for af_alg_iv { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("af_alg_iv") +                    .field("iv", &self.as_slice()) +                    .finish() +            } +        } + +        impl ::hash::Hash for af_alg_iv { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.as_slice().hash(state); +            } +        } +    }  }  pub const ABDAY_1: ::nl_item = 0x20000; @@ -1315,6 +1412,15 @@ pub const FALLOC_FL_UNSHARE_RANGE: ::c_int = 0x40;  pub const ENOATTR: ::c_int = ::ENODATA;  pub const SO_ORIGINAL_DST: ::c_int = 80; +pub const IP_ORIGDSTADDR : ::c_int = 20; +pub const IP_RECVORIGDSTADDR : ::c_int = IP_ORIGDSTADDR; +pub const IPV6_ORIGDSTADDR : ::c_int = 74; +pub const IPV6_RECVORIGDSTADDR : ::c_int = IPV6_ORIGDSTADDR; +pub const IPV6_FLOWINFO: ::c_int = 11; +pub const IPV6_FLOWLABEL_MGR: ::c_int = 32; +pub const IPV6_FLOWINFO_SEND: ::c_int = 33; +pub const IPV6_FLOWINFO_FLOWLABEL: ::c_int = 0x000fffff; +pub const IPV6_FLOWINFO_PRIORITY: ::c_int = 0x0ff00000;  pub const IUTF8: ::tcflag_t = 0x00004000;  pub const CMSPAR: ::tcflag_t = 0o10000000000; @@ -1696,7 +1802,92 @@ pub const SOF_TIMESTAMPING_SOFTWARE: ::c_uint = 1 << 4;  pub const SOF_TIMESTAMPING_SYS_HARDWARE: ::c_uint = 1 << 5;  pub const SOF_TIMESTAMPING_RAW_HARDWARE: ::c_uint = 1 << 6; +// linux/if_alg.h +pub const ALG_SET_KEY: ::c_int = 1; +pub const ALG_SET_IV: ::c_int = 2; +pub const ALG_SET_OP: ::c_int = 3; +pub const ALG_SET_AEAD_ASSOCLEN: ::c_int = 4; +pub const ALG_SET_AEAD_AUTHSIZE: ::c_int = 5; + +pub const ALG_OP_DECRYPT: ::c_int = 0; +pub const ALG_OP_ENCRYPT: ::c_int = 1; + +// uapi/linux/inotify.h +pub const IN_ACCESS:        ::uint32_t = 0x0000_0001; +pub const IN_MODIFY:        ::uint32_t = 0x0000_0002; +pub const IN_ATTRIB:        ::uint32_t = 0x0000_0004; +pub const IN_CLOSE_WRITE:   ::uint32_t = 0x0000_0008; +pub const IN_CLOSE_NOWRITE: ::uint32_t = 0x0000_0010; +pub const IN_CLOSE:         ::uint32_t = (IN_CLOSE_WRITE | IN_CLOSE_NOWRITE); +pub const IN_OPEN:          ::uint32_t = 0x0000_0020; +pub const IN_MOVED_FROM:    ::uint32_t = 0x0000_0040; +pub const IN_MOVED_TO:      ::uint32_t = 0x0000_0080; +pub const IN_MOVE:          ::uint32_t = (IN_MOVED_FROM | IN_MOVED_TO); +pub const IN_CREATE:        ::uint32_t = 0x0000_0100; +pub const IN_DELETE:        ::uint32_t = 0x0000_0200; +pub const IN_DELETE_SELF:   ::uint32_t = 0x0000_0400; +pub const IN_MOVE_SELF:     ::uint32_t = 0x0000_0800; +pub const IN_UNMOUNT:       ::uint32_t = 0x0000_2000; +pub const IN_Q_OVERFLOW:    ::uint32_t = 0x0000_4000; +pub const IN_IGNORED:       ::uint32_t = 0x0000_8000; +pub const IN_ONLYDIR:       ::uint32_t = 0x0100_0000; +pub const IN_DONT_FOLLOW:   ::uint32_t = 0x0200_0000; +// pub const IN_EXCL_UNLINK:   ::uint32_t = 0x0400_0000; + +// pub const IN_MASK_CREATE:   ::uint32_t = 0x1000_0000; +// pub const IN_MASK_ADD:      ::uint32_t = 0x2000_0000; +pub const IN_ISDIR:         ::uint32_t = 0x4000_0000; +pub const IN_ONESHOT:       ::uint32_t = 0x8000_0000; + +pub const IN_ALL_EVENTS:    ::uint32_t = ( +  IN_ACCESS | IN_MODIFY | IN_ATTRIB | IN_CLOSE_WRITE | +  IN_CLOSE_NOWRITE | IN_OPEN | IN_MOVED_FROM | +  IN_MOVED_TO | IN_DELETE | IN_CREATE | IN_DELETE_SELF | +  IN_MOVE_SELF +); + +pub const IN_CLOEXEC: ::c_int = O_CLOEXEC; +pub const IN_NONBLOCK: ::c_int = O_NONBLOCK; + +pub const FUTEX_WAIT: ::c_int = 0; +pub const FUTEX_WAKE: ::c_int = 1; +pub const FUTEX_FD: ::c_int = 2; +pub const FUTEX_REQUEUE: ::c_int = 3; +pub const FUTEX_CMP_REQUEUE: ::c_int = 4; +pub const FUTEX_WAKE_OP: ::c_int = 5; +pub const FUTEX_LOCK_PI: ::c_int = 6; +pub const FUTEX_UNLOCK_PI: ::c_int = 7; +pub const FUTEX_TRYLOCK_PI: ::c_int = 8; +pub const FUTEX_WAIT_BITSET: ::c_int = 9; +pub const FUTEX_WAKE_BITSET: ::c_int = 10; +pub const FUTEX_WAIT_REQUEUE_PI: ::c_int = 11; +pub const FUTEX_CMP_REQUEUE_PI: ::c_int = 12; + +pub const FUTEX_PRIVATE_FLAG: ::c_int = 128; +pub const FUTEX_CLOCK_REALTIME: ::c_int = 256; +pub const FUTEX_CMD_MASK: ::c_int = +    !(FUTEX_PRIVATE_FLAG | FUTEX_CLOCK_REALTIME); +  f! { +    pub fn CMSG_NXTHDR(mhdr: *const msghdr, +                       cmsg: *const cmsghdr) -> *mut cmsghdr { +        if ((*cmsg).cmsg_len as usize) < ::mem::size_of::<cmsghdr>() { +            return 0 as *mut cmsghdr; +        }; +        let next = (cmsg as usize + +                    super::CMSG_ALIGN((*cmsg).cmsg_len as usize)) +            as *mut cmsghdr; +        let max = (*mhdr).msg_control as usize +            + (*mhdr).msg_controllen as usize; +        if (next.offset(1)) as usize > max || +            next as usize + super::CMSG_ALIGN((*next).cmsg_len as usize) > max +        { +            0 as *mut cmsghdr +        } else { +            next as *mut cmsghdr +        } +    } +      pub fn CPU_ZERO(cpuset: &mut cpu_set_t) -> () {          for slot in cpuset.bits.iter_mut() {              *slot = 0; @@ -1704,21 +1895,23 @@ f! {      }      pub fn CPU_SET(cpu: usize, cpuset: &mut cpu_set_t) -> () { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc +        let size_in_bits +            = 8 * ::mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          cpuset.bits[idx] |= 1 << offset;          ()      }      pub fn CPU_CLR(cpu: usize, cpuset: &mut cpu_set_t) -> () { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc +        let size_in_bits +            = 8 * ::mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          cpuset.bits[idx] &= !(1 << offset);          ()      }      pub fn CPU_ISSET(cpu: usize, cpuset: &cpu_set_t) -> bool { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); +        let size_in_bits = 8 * ::mem::size_of_val(&cpuset.bits[0]);          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          0 != (cpuset.bits[idx] & (1 << offset))      } @@ -1979,7 +2172,7 @@ extern {      pub fn glob(pattern: *const c_char,                  flags: ::c_int, -                errfunc: Option<extern fn(epath: *const c_char, +                errfunc: ::Option<extern fn(epath: *const c_char,                                            errno: ::c_int) -> ::c_int>,                  pglob: *mut ::glob_t) -> ::c_int;      pub fn globfree(pglob: *mut ::glob_t); @@ -2008,9 +2201,9 @@ extern {      pub fn getdomainname(name: *mut ::c_char, len: ::size_t) -> ::c_int;      pub fn setdomainname(name: *const ::c_char, len: ::size_t) -> ::c_int;      pub fn vhangup() -> ::c_int; -    pub fn sendmmsg(sockfd: ::c_int, msgvec: *mut mmsghdr, vlen: ::c_uint, +    pub fn sendmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::c_uint,                      flags: ::c_int) -> ::c_int; -    pub fn recvmmsg(sockfd: ::c_int, msgvec: *mut mmsghdr, vlen: ::c_uint, +    pub fn recvmmsg(sockfd: ::c_int, msgvec: *mut ::mmsghdr, vlen: ::c_uint,                      flags: ::c_int, timeout: *mut ::timespec) -> ::c_int;      pub fn sync();      pub fn syscall(num: ::c_long, ...) -> ::c_long; @@ -2104,7 +2297,7 @@ extern {                      count: ::size_t) -> ::ssize_t;      pub fn sigsuspend(mask: *const ::sigset_t) -> ::c_int;      #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrgid_r")] -    pub fn getgrgid_r(uid: ::uid_t, +    pub fn getgrgid_r(gid: ::gid_t,                        grp: *mut ::group,                        buf: *mut ::c_char,                        buflen: ::size_t, @@ -2152,9 +2345,9 @@ extern {      #[cfg_attr(target_os = "solaris", link_name = "__posix_sigwait")]      pub fn sigwait(set: *const sigset_t,                     sig: *mut ::c_int) -> ::c_int; -    pub fn pthread_atfork(prepare: Option<unsafe extern fn()>, -                          parent: Option<unsafe extern fn()>, -                          child: Option<unsafe extern fn()>) -> ::c_int; +    pub fn pthread_atfork(prepare: ::Option<unsafe extern fn()>, +                          parent: ::Option<unsafe extern fn()>, +                          child: ::Option<unsafe extern fn()>) -> ::c_int;      pub fn getgrgid(gid: ::gid_t) -> *mut ::group;      pub fn getgrouplist(user: *const ::c_char,                          group: ::gid_t, @@ -2173,7 +2366,7 @@ extern {                            f: extern fn(*mut ::c_void) -> *mut ::c_void,                            value: *mut ::c_void) -> ::c_int;      pub fn dl_iterate_phdr( -        callback: Option<unsafe extern fn( +        callback: ::Option<unsafe extern fn(              info: *mut ::dl_phdr_info,              size: ::size_t,              data: *mut ::c_void @@ -2259,6 +2452,12 @@ extern {          nobj: ::size_t,          stream: *mut ::FILE      ) -> ::size_t; +    pub fn inotify_rm_watch(fd: ::c_int, wd: ::c_int) -> ::c_int; +    pub fn inotify_init() -> ::c_int; +    pub fn inotify_init1(flags: ::c_int) -> ::c_int; +    pub fn inotify_add_watch(fd: ::c_int, +                             path: *const ::c_char, +                             mask: ::uint32_t) -> ::c_int;  }  cfg_if! { @@ -2277,3 +2476,14 @@ cfg_if! {          pub use self::other::*;      }  } + +cfg_if! { +    if #[cfg(libc_align)] { +        #[macro_use] +        mod align; +    } else { +        #[macro_use] +        mod no_align; +    } +} +expand_align!(); diff --git a/libc/src/unix/notbsd/linux/musl/b32/mips.rs b/libc/src/unix/notbsd/linux/musl/b32/mips.rs index b0694d1..37430af 100644 --- a/libc/src/unix/notbsd/linux/musl/b32/mips.rs +++ b/libc/src/unix/notbsd/linux/musl/b32/mips.rs @@ -514,7 +514,6 @@ pub const SYS_mknod: ::c_long = 4000 +  14;  pub const SYS_chmod: ::c_long = 4000 +  15;  pub const SYS_lchown: ::c_long = 4000 +  16;  pub const SYS_break: ::c_long = 4000 +  17; -pub const SYS_unused18: ::c_long = 4000 +  18;  pub const SYS_lseek: ::c_long = 4000 +  19;  pub const SYS_getpid: ::c_long = 4000 +  20;  pub const SYS_mount: ::c_long = 4000 +  21; @@ -524,7 +523,6 @@ pub const SYS_getuid: ::c_long = 4000 +  24;  pub const SYS_stime: ::c_long = 4000 +  25;  pub const SYS_ptrace: ::c_long = 4000 +  26;  pub const SYS_alarm: ::c_long = 4000 +  27; -pub const SYS_unused28: ::c_long = 4000 +  28;  pub const SYS_pause: ::c_long = 4000 +  29;  pub const SYS_utime: ::c_long = 4000 +  30;  pub const SYS_stty: ::c_long = 4000 +  31; @@ -555,7 +553,6 @@ pub const SYS_fcntl: ::c_long = 4000 +  55;  pub const SYS_mpx: ::c_long = 4000 +  56;  pub const SYS_setpgid: ::c_long = 4000 +  57;  pub const SYS_ulimit: ::c_long = 4000 +  58; -pub const SYS_unused59: ::c_long = 4000 +  59;  pub const SYS_umask: ::c_long = 4000 +  60;  pub const SYS_chroot: ::c_long = 4000 +  61;  pub const SYS_ustat: ::c_long = 4000 +  62; @@ -578,9 +575,7 @@ pub const SYS_gettimeofday: ::c_long = 4000 +  78;  pub const SYS_settimeofday: ::c_long = 4000 +  79;  pub const SYS_getgroups: ::c_long = 4000 +  80;  pub const SYS_setgroups: ::c_long = 4000 +  81; -pub const SYS_reserved82: ::c_long = 4000 +  82;  pub const SYS_symlink: ::c_long = 4000 +  83; -pub const SYS_unused84: ::c_long = 4000 +  84;  pub const SYS_readlink: ::c_long = 4000 +  85;  pub const SYS_uselib: ::c_long = 4000 +  86;  pub const SYS_swapon: ::c_long = 4000 +  87; @@ -605,7 +600,6 @@ pub const SYS_getitimer: ::c_long = 4000 + 105;  pub const SYS_stat: ::c_long = 4000 + 106;  pub const SYS_lstat: ::c_long = 4000 + 107;  pub const SYS_fstat: ::c_long = 4000 + 108; -pub const SYS_unused109: ::c_long = 4000 + 109;  pub const SYS_iopl: ::c_long = 4000 + 110;  pub const SYS_vhangup: ::c_long = 4000 + 111;  pub const SYS_idle: ::c_long = 4000 + 112; @@ -645,7 +639,6 @@ pub const SYS_writev: ::c_long = 4000 + 146;  pub const SYS_cacheflush: ::c_long = 4000 + 147;  pub const SYS_cachectl: ::c_long = 4000 + 148;  pub const SYS_sysmips: ::c_long = 4000 + 149; -pub const SYS_unused150: ::c_long = 4000 + 150;  pub const SYS_getsid: ::c_long = 4000 + 151;  pub const SYS_fdatasync: ::c_long = 4000 + 152;  pub const SYS__sysctl: ::c_long = 4000 + 153; @@ -714,7 +707,6 @@ pub const SYS_mincore: ::c_long = 4000 + 217;  pub const SYS_madvise: ::c_long = 4000 + 218;  pub const SYS_getdents64: ::c_long = 4000 + 219;  pub const SYS_fcntl64: ::c_long = 4000 + 220; -pub const SYS_reserved221: ::c_long = 4000 + 221;  pub const SYS_gettid: ::c_long = 4000 + 222;  pub const SYS_readahead: ::c_long = 4000 + 223;  pub const SYS_setxattr: ::c_long = 4000 + 224; diff --git a/libc/src/unix/notbsd/linux/musl/b32/x86.rs b/libc/src/unix/notbsd/linux/musl/b32/x86.rs index b6ea8c1..8bfb60b 100644 --- a/libc/src/unix/notbsd/linux/musl/b32/x86.rs +++ b/libc/src/unix/notbsd/linux/musl/b32/x86.rs @@ -116,15 +116,6 @@ s! {          __private: [u32; 22]      } -    pub struct ucontext_t { -        pub uc_flags: ::c_ulong, -        pub uc_link: *mut ucontext_t, -        pub uc_stack: ::stack_t, -        pub uc_mcontext: mcontext_t, -        pub uc_sigmask: ::sigset_t, -        __private: [u8; 112], -    } -      pub struct siginfo_t {          pub si_signo: ::c_int,          pub si_errno: ::c_int, @@ -176,6 +167,62 @@ s! {      }  } +s_no_extra_traits!{ +    pub struct ucontext_t { +        pub uc_flags: ::c_ulong, +        pub uc_link: *mut ucontext_t, +        pub uc_stack: ::stack_t, +        pub uc_mcontext: mcontext_t, +        pub uc_sigmask: ::sigset_t, +        __private: [u8; 112], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for ucontext_t { +            fn eq(&self, other: &ucontext_t) -> bool { +                self.uc_flags == other.uc_flags +                    && self.uc_link == other.uc_link +                    && self.uc_stack == other.uc_stack +                    && self.uc_mcontext == other.uc_mcontext +                    && self.uc_sigmask == other.uc_sigmask +                    && self +                    .__private +                    .iter() +                    .zip(other.__private.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for ucontext_t {} + +        impl ::fmt::Debug for ucontext_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("ucontext_t") +                    .field("uc_flags", &self.uc_flags) +                    .field("uc_link", &self.uc_link) +                    .field("uc_stack", &self.uc_stack) +                    .field("uc_mcontext", &self.uc_mcontext) +                    .field("uc_sigmask", &self.uc_sigmask) +                // Ignore __private field +                    .finish() +            } +        } + +        impl ::hash::Hash for ucontext_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.uc_flags.hash(state); +                self.uc_link.hash(state); +                self.uc_stack.hash(state); +                self.uc_mcontext.hash(state); +                self.uc_sigmask.hash(state); +                self.__private.hash(state); +            } +        } +    } +} +  pub const SIGSTKSZ: ::size_t = 8192;  pub const MINSIGSTKSZ: ::size_t = 2048; diff --git a/libc/src/unix/notbsd/linux/musl/b64/x86_64.rs b/libc/src/unix/notbsd/linux/musl/b64/x86_64.rs index 0e0fcec..94c5d88 100644 --- a/libc/src/unix/notbsd/linux/musl/b64/x86_64.rs +++ b/libc/src/unix/notbsd/linux/musl/b64/x86_64.rs @@ -51,15 +51,6 @@ s! {          __private: [u64; 32],      } -    pub struct ucontext_t { -        pub uc_flags: ::c_ulong, -        pub uc_link: *mut ucontext_t, -        pub uc_stack: ::stack_t, -        pub uc_mcontext: mcontext_t, -        pub uc_sigmask: ::sigset_t, -        __private: [u8; 512], -    } -      pub struct ipc_perm {          pub __ipc_perm_key: ::key_t,          pub uid: ::uid_t, @@ -73,6 +64,62 @@ s! {      }  } +s_no_extra_traits!{ +    pub struct ucontext_t { +        pub uc_flags: ::c_ulong, +        pub uc_link: *mut ucontext_t, +        pub uc_stack: ::stack_t, +        pub uc_mcontext: mcontext_t, +        pub uc_sigmask: ::sigset_t, +        __private: [u8; 512], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for ucontext_t { +            fn eq(&self, other: &ucontext_t) -> bool { +                self.uc_flags == other.uc_flags +                    && self.uc_link == other.uc_link +                    && self.uc_stack == other.uc_stack +                    && self.uc_mcontext == other.uc_mcontext +                    && self.uc_sigmask == other.uc_sigmask +                    && self +                    .__private +                    .iter() +                    .zip(other.__private.iter()) +                    .all(|(a,b)| a == b) +            } +        } + +        impl Eq for ucontext_t {} + +        impl ::fmt::Debug for ucontext_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("ucontext_t") +                    .field("uc_flags", &self.uc_flags) +                    .field("uc_link", &self.uc_link) +                    .field("uc_stack", &self.uc_stack) +                    .field("uc_mcontext", &self.uc_mcontext) +                    .field("uc_sigmask", &self.uc_sigmask) +                // Ignore __private field +                    .finish() +            } +        } + +        impl ::hash::Hash for ucontext_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.uc_flags.hash(state); +                self.uc_link.hash(state); +                self.uc_stack.hash(state); +                self.uc_mcontext.hash(state); +                self.uc_sigmask.hash(state); +                self.__private.hash(state); +            } +        } +    } +} +  // Syscall table  pub const SYS_read: ::c_long = 0; diff --git a/libc/src/unix/notbsd/linux/musl/mod.rs b/libc/src/unix/notbsd/linux/musl/mod.rs index 5ab5d0f..4f4a3d8 100644 --- a/libc/src/unix/notbsd/linux/musl/mod.rs +++ b/libc/src/unix/notbsd/linux/musl/mod.rs @@ -37,7 +37,7 @@ s! {          pub sa_sigaction: ::sighandler_t,          pub sa_mask: ::sigset_t,          pub sa_flags: ::c_int, -        pub sa_restorer: ::dox::Option<extern fn()>, +        pub sa_restorer: ::Option<extern fn()>,      }      pub struct statvfs { @@ -78,7 +78,9 @@ s! {          pub l_len: ::off_t,          pub l_pid: ::pid_t,      } +} +s_no_extra_traits!{      pub struct sysinfo {          pub uptime: ::c_ulong,          pub loads: [::c_ulong; 3], @@ -97,6 +99,75 @@ s! {      }  } +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for sysinfo { +            fn eq(&self, other: &sysinfo) -> bool { +                self.uptime == other.uptime +                    && self.loads == other.loads +                    && self.totalram == other.totalram +                    && self.freeram == other.freeram +                    && self.sharedram == other.sharedram +                    && self.bufferram == other.bufferram +                    && self.totalswap == other.totalswap +                    && self.freeswap == other.freeswap +                    && self.procs == other.procs +                    && self.pad == other.pad +                    && self.totalhigh == other.totalhigh +                    && self.freehigh == other.freehigh +                    && self.mem_unit == other.mem_unit +                    && self +                        .__reserved +                        .iter() +                        .zip(other.__reserved.iter()) +                        .all(|(a,b)| a == b) +            } +        } + +        impl Eq for sysinfo {} + +        impl ::fmt::Debug for sysinfo { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sysinfo") +                    .field("uptime", &self.uptime) +                    .field("loads", &self.loads) +                    .field("totalram", &self.totalram) +                    .field("freeram", &self.freeram) +                    .field("sharedram", &self.sharedram) +                    .field("bufferram", &self.bufferram) +                    .field("totalswap", &self.totalswap) +                    .field("freeswap", &self.freeswap) +                    .field("procs", &self.procs) +                    .field("pad", &self.pad) +                    .field("totalhigh", &self.totalhigh) +                    .field("freehigh", &self.freehigh) +                    .field("mem_unit", &self.mem_unit) +                    // FIXME: .field("__reserved", &self.__reserved) +                    .finish() +            } +        } + +        impl ::hash::Hash for sysinfo { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.uptime.hash(state); +                self.loads.hash(state); +                self.totalram.hash(state); +                self.freeram.hash(state); +                self.sharedram.hash(state); +                self.bufferram.hash(state); +                self.totalswap.hash(state); +                self.freeswap.hash(state); +                self.procs.hash(state); +                self.pad.hash(state); +                self.totalhigh.hash(state); +                self.freehigh.hash(state); +                self.mem_unit.hash(state); +                self.__reserved.hash(state); +            } +        } +    } +} +  pub const SFD_CLOEXEC: ::c_int = 0x080000;  pub const NCCS: usize = 32; diff --git a/libc/src/unix/notbsd/linux/no_align.rs b/libc/src/unix/notbsd/linux/no_align.rs new file mode 100644 index 0000000..1f5f2ee --- /dev/null +++ b/libc/src/unix/notbsd/linux/no_align.rs @@ -0,0 +1,80 @@ +macro_rules! expand_align { +    () => { +        s! { +            pub struct pthread_mutexattr_t { +                #[cfg(any(target_arch = "x86_64", +                          target_arch = "powerpc64", +                          target_arch = "mips64", +                          target_arch = "s390x", +                          target_arch = "sparc64", +                          all(target_arch = "aarch64", +                              target_env = "musl")))] +                __align: [::c_int; 0], +                #[cfg(not(any(target_arch = "x86_64", +                              target_arch = "powerpc64", +                              target_arch = "mips64", +                              target_arch = "s390x", +                              target_arch = "sparc64", +                              all(target_arch = "aarch64", +                                  target_env = "musl"))))] +                __align: [::c_long; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            pub struct pthread_rwlockattr_t { +                #[cfg(target_env = "musl")] +                __align: [::c_int; 0], +                #[cfg(not(target_env = "musl"))] +                __align: [::c_long; 0], +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCKATTR_T], +            } + +            pub struct pthread_condattr_t { +                __align: [::c_int; 0], +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } + +        s_no_extra_traits! { +            pub struct pthread_cond_t { +                #[cfg(target_env = "musl")] +                __align: [*const ::c_void; 0], +                #[cfg(not(target_env = "musl"))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } + +            pub struct pthread_mutex_t { +                #[cfg(any(target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc", +                          all(target_arch = "x86_64", +                              target_pointer_width = "32")))] +                __align: [::c_long; 0], +                #[cfg(not(any(target_arch = "mips", +                              target_arch = "arm", +                              target_arch = "powerpc", +                              all(target_arch = "x86_64", +                                  target_pointer_width = "32"))))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            pub struct pthread_rwlock_t { +                #[cfg(any(target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc", +                          all(target_arch = "x86_64", +                              target_pointer_width = "32")))] +                __align: [::c_long; 0], +                #[cfg(not(any(target_arch = "mips", +                              target_arch = "arm", +                              target_arch = "powerpc", +                              all(target_arch = "x86_64", +                                  target_pointer_width = "32"))))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } +        } +    } +} diff --git a/libc/src/unix/notbsd/linux/other/align.rs b/libc/src/unix/notbsd/linux/other/align.rs new file mode 100644 index 0000000..4a0e074 --- /dev/null +++ b/libc/src/unix/notbsd/linux/other/align.rs @@ -0,0 +1,13 @@ +s! { +    // FIXME this is actually a union +    #[cfg_attr(target_pointer_width = "32", +               repr(align(4)))] +    #[cfg_attr(target_pointer_width = "64", +               repr(align(8)))] +    pub struct sem_t { +        #[cfg(target_pointer_width = "32")] +        __size: [::c_char; 16], +        #[cfg(target_pointer_width = "64")] +        __size: [::c_char; 32], +    } +} diff --git a/libc/src/unix/notbsd/linux/other/b32/arm.rs b/libc/src/unix/notbsd/linux/other/b32/arm.rs index a70af43..7f00d9a 100644 --- a/libc/src/unix/notbsd/linux/other/b32/arm.rs +++ b/libc/src/unix/notbsd/linux/other/b32/arm.rs @@ -136,9 +136,6 @@ pub const SO_RCVBUFFORCE: ::c_int = 33;  pub const FIOCLEX: ::c_ulong = 0x5451;  pub const FIONBIO: ::c_ulong = 0x5421; -pub const PTRACE_GETFPXREGS: ::c_uint = 18; -pub const PTRACE_SETFPXREGS: ::c_uint = 19; -  pub const MCL_CURRENT: ::c_int = 0x0001;  pub const MCL_FUTURE: ::c_int = 0x0002; diff --git a/libc/src/unix/notbsd/linux/other/b32/x86.rs b/libc/src/unix/notbsd/linux/other/b32/x86.rs index 6c41718..e7c3b9a 100644 --- a/libc/src/unix/notbsd/linux/other/b32/x86.rs +++ b/libc/src/unix/notbsd/linux/other/b32/x86.rs @@ -31,22 +31,6 @@ s! {          pub st_space: [::c_long; 20],      } -    pub struct user_fpxregs_struct { -        pub cwd: ::c_ushort, -        pub swd: ::c_ushort, -        pub twd: ::c_ushort, -        pub fop: ::c_ushort, -        pub fip: ::c_long, -        pub fcs: ::c_long, -        pub foo: ::c_long, -        pub fos: ::c_long, -        pub mxcsr: ::c_long, -        __reserved: ::c_long, -        pub st_space: [::c_long; 32], -        pub xmm_space: [::c_long; 32], -        padding: [::c_long; 56], -    } -      pub struct user_regs_struct {          pub ebx: ::c_long,          pub ecx: ::c_long, @@ -92,15 +76,6 @@ s! {          pub cr2: ::c_ulong,      } -    pub struct ucontext_t { -        pub uc_flags: ::c_ulong, -        pub uc_link: *mut ucontext_t, -        pub uc_stack: ::stack_t, -        pub uc_mcontext: mcontext_t, -        pub uc_sigmask: ::sigset_t, -        __private: [u8; 112], -    } -      pub struct ipc_perm {          pub __key: ::key_t,          pub uid: ::uid_t, @@ -213,6 +188,133 @@ s! {      }  } +s_no_extra_traits!{ +    pub struct user_fpxregs_struct { +        pub cwd: ::c_ushort, +        pub swd: ::c_ushort, +        pub twd: ::c_ushort, +        pub fop: ::c_ushort, +        pub fip: ::c_long, +        pub fcs: ::c_long, +        pub foo: ::c_long, +        pub fos: ::c_long, +        pub mxcsr: ::c_long, +        __reserved: ::c_long, +        pub st_space: [::c_long; 32], +        pub xmm_space: [::c_long; 32], +        padding: [::c_long; 56], +    } + +    pub struct ucontext_t { +        pub uc_flags: ::c_ulong, +        pub uc_link: *mut ucontext_t, +        pub uc_stack: ::stack_t, +        pub uc_mcontext: mcontext_t, +        pub uc_sigmask: ::sigset_t, +        __private: [u8; 112], +        __ssp: [::c_ulong; 4], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for user_fpxregs_struct { +            fn eq(&self, other: &user_fpxregs_struct) -> bool { +                self.cwd == other.cwd +                    && self.swd == other.swd +                    && self.twd == other.twd +                    && self.fop == other.fop +                    && self.fip == other.fip +                    && self.fcs == other.fcs +                    && self.foo == other.foo +                    && self.fos == other.fos +                    && self.mxcsr == other.mxcsr +                // Ignore __reserved field +                    && self.st_space == other.st_space +                    && self.xmm_space == other.xmm_space +                // Ignore padding field +            } +        } + +        impl Eq for user_fpxregs_struct {} + +        impl ::fmt::Debug for user_fpxregs_struct { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("user_fpxregs_struct") +                    .field("cwd", &self.cwd) +                    .field("swd", &self.swd) +                    .field("twd", &self.twd) +                    .field("fop", &self.fop) +                    .field("fip", &self.fip) +                    .field("fcs", &self.fcs) +                    .field("foo", &self.foo) +                    .field("fos", &self.fos) +                    .field("mxcsr", &self.mxcsr) +                // Ignore __reserved field +                    .field("st_space", &self.st_space) +                    .field("xmm_space", &self.xmm_space) +                // Ignore padding field +                    .finish() +            } +        } + +        impl ::hash::Hash for user_fpxregs_struct { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.cwd.hash(state); +                self.swd.hash(state); +                self.twd.hash(state); +                self.fop.hash(state); +                self.fip.hash(state); +                self.fcs.hash(state); +                self.foo.hash(state); +                self.fos.hash(state); +                self.mxcsr.hash(state); +                // Ignore __reserved field +                self.st_space.hash(state); +                self.xmm_space.hash(state); +                // Ignore padding field +            } +        } + +        impl PartialEq for ucontext_t { +            fn eq(&self, other: &ucontext_t) -> bool { +                self.uc_flags == other.uc_flags +                    && self.uc_link == other.uc_link +                    && self.uc_stack == other.uc_stack +                    && self.uc_mcontext == other.uc_mcontext +                    && self.uc_sigmask == other.uc_sigmask +                // Ignore __private field +            } +        } + +        impl Eq for ucontext_t {} + +        impl ::fmt::Debug for ucontext_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("ucontext_t") +                    .field("uc_flags", &self.uc_flags) +                    .field("uc_link", &self.uc_link) +                    .field("uc_stack", &self.uc_stack) +                    .field("uc_mcontext", &self.uc_mcontext) +                    .field("uc_sigmask", &self.uc_sigmask) +                // Ignore __private field +                    .finish() +            } +        } + +        impl ::hash::Hash for ucontext_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.uc_flags.hash(state); +                self.uc_link.hash(state); +                self.uc_stack.hash(state); +                self.uc_mcontext.hash(state); +                self.uc_sigmask.hash(state); +                // Ignore __private field +            } +        } +    } +} +  pub const O_DIRECT: ::c_int = 0x4000;  pub const O_DIRECTORY: ::c_int = 0x10000;  pub const O_NOFOLLOW: ::c_int = 0x20000; diff --git a/libc/src/unix/notbsd/linux/other/b64/aarch64.rs b/libc/src/unix/notbsd/linux/other/b64/aarch64.rs index d6e37ff..3bd2e02 100644 --- a/libc/src/unix/notbsd/linux/other/b64/aarch64.rs +++ b/libc/src/unix/notbsd/linux/other/b64/aarch64.rs @@ -786,7 +786,6 @@ pub const SYS_rt_tgsigqueueinfo: ::c_long = 240;  pub const SYS_perf_event_open: ::c_long = 241;  pub const SYS_accept4: ::c_long = 242;  pub const SYS_recvmmsg: ::c_long = 243; -pub const SYS_arch_specific_syscall: ::c_long = 244;  pub const SYS_wait4: ::c_long = 260;  pub const SYS_prlimit64: ::c_long = 261;  pub const SYS_fanotify_init: ::c_long = 262; @@ -818,7 +817,6 @@ pub const SYS_pwritev2: ::c_long = 287;  pub const SYS_pkey_mprotect: ::c_long = 288;  pub const SYS_pkey_alloc: ::c_long = 289;  pub const SYS_pkey_free: ::c_long = 290; -pub const SYS_syscalls: ::c_long = 291;  #[link(name = "util")]  extern { diff --git a/libc/src/unix/notbsd/linux/other/b64/sparc64.rs b/libc/src/unix/notbsd/linux/other/b64/sparc64.rs index 325c793..5d26865 100644 --- a/libc/src/unix/notbsd/linux/other/b64/sparc64.rs +++ b/libc/src/unix/notbsd/linux/other/b64/sparc64.rs @@ -495,7 +495,7 @@ pub const VEOL2: usize = 6;  pub const VMIN: usize = 4;  pub const IEXTEN: ::tcflag_t = 0x8000;  pub const TOSTOP: ::tcflag_t = 0x100; -pub const FLUSHO: ::tcflag_t = 0x2000; +pub const FLUSHO: ::tcflag_t = 0x1000;  pub const EXTPROC: ::tcflag_t = 0x10000;  pub const TCGETS: ::c_ulong = 0x40245408;  pub const TCSETS: ::c_ulong = 0x80245409; diff --git a/libc/src/unix/notbsd/linux/other/b64/x86_64.rs b/libc/src/unix/notbsd/linux/other/b64/x86_64.rs index 0d7137e..79f27e0 100644 --- a/libc/src/unix/notbsd/linux/other/b64/x86_64.rs +++ b/libc/src/unix/notbsd/linux/other/b64/x86_64.rs @@ -112,20 +112,6 @@ s! {          __private: [u64; 12],      } -    pub struct user_fpregs_struct { -        pub cwd: ::c_ushort, -        pub swd: ::c_ushort, -        pub ftw: ::c_ushort, -        pub fop: ::c_ushort, -        pub rip: ::c_ulonglong, -        pub rdp: ::c_ulonglong, -        pub mxcsr: ::c_uint, -        pub mxcr_mask: ::c_uint, -        pub st_space: [::c_uint; 32], -        pub xmm_space: [::c_uint; 64], -        padding: [::c_uint; 24], -    } -      pub struct user_regs_struct {          pub r15: ::c_ulonglong,          pub r14: ::c_ulonglong, @@ -184,15 +170,6 @@ s! {          __private: [u64; 8],      } -    pub struct ucontext_t { -        pub uc_flags: ::c_ulong, -        pub uc_link: *mut ucontext_t, -        pub uc_stack: ::stack_t, -        pub uc_mcontext: mcontext_t, -        pub uc_sigmask: ::sigset_t, -        __private: [u8; 512], -    } -      pub struct ipc_perm {          pub __key: ::key_t,          pub uid: ::uid_t, @@ -232,6 +209,127 @@ s! {      }  } +s_no_extra_traits! { +    pub struct user_fpregs_struct { +        pub cwd: ::c_ushort, +        pub swd: ::c_ushort, +        pub ftw: ::c_ushort, +        pub fop: ::c_ushort, +        pub rip: ::c_ulonglong, +        pub rdp: ::c_ulonglong, +        pub mxcsr: ::c_uint, +        pub mxcr_mask: ::c_uint, +        pub st_space: [::c_uint; 32], +        pub xmm_space: [::c_uint; 64], +        padding: [::c_uint; 24], +    } + +    pub struct ucontext_t { +        pub uc_flags: ::c_ulong, +        pub uc_link: *mut ucontext_t, +        pub uc_stack: ::stack_t, +        pub uc_mcontext: mcontext_t, +        pub uc_sigmask: ::sigset_t, +        __private: [u8; 512], +        __ssp: [::c_ulonglong; 4], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for user_fpregs_struct { +            fn eq(&self, other: &user_fpregs_struct) -> bool { +                self.cwd == other.cwd +                    && self.swd == other.swd +                    && self.ftw == other.ftw +                    && self.fop == other.fop +                    && self.rip == other.rip +                    && self.rdp == other.rdp +                    && self.mxcsr == other.mxcsr +                    && self.mxcr_mask == other.mxcr_mask +                    && self.st_space == other.st_space +                    && self +                    .xmm_space +                    .iter() +                    .zip(other.xmm_space.iter()) +                    .all(|(a,b)| a == b) +                // Ignore padding field +            } +        } + +        impl Eq for user_fpregs_struct {} + +        impl ::fmt::Debug for user_fpregs_struct { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("user_fpregs_struct") +                    .field("cwd", &self.cwd) +                    .field("ftw", &self.ftw) +                    .field("fop", &self.fop) +                    .field("rip", &self.rip) +                    .field("rdp", &self.rdp) +                    .field("mxcsr", &self.mxcsr) +                    .field("mxcr_mask", &self.mxcr_mask) +                    .field("st_space", &self.st_space) +                // FIXME: .field("xmm_space", &self.xmm_space) +                // Ignore padding field +                    .finish() +            } +        } + +        impl ::hash::Hash for user_fpregs_struct { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.cwd.hash(state); +                self.ftw.hash(state); +                self.fop.hash(state); +                self.rip.hash(state); +                self.rdp.hash(state); +                self.mxcsr.hash(state); +                self.mxcr_mask.hash(state); +                self.st_space.hash(state); +                self.xmm_space.hash(state); +                // Ignore padding field +            } +        } + +        impl PartialEq for ucontext_t { +            fn eq(&self, other: &ucontext_t) -> bool { +                self.uc_flags == other.uc_flags +                    && self.uc_link == other.uc_link +                    && self.uc_stack == other.uc_stack +                    && self.uc_mcontext == other.uc_mcontext +                    && self.uc_sigmask == other.uc_sigmask +                // Ignore __private field +            } +        } + +        impl Eq for ucontext_t {} + +        impl ::fmt::Debug for ucontext_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("ucontext_t") +                    .field("uc_flags", &self.uc_flags) +                    .field("uc_link", &self.uc_link) +                    .field("uc_stack", &self.uc_stack) +                    .field("uc_mcontext", &self.uc_mcontext) +                    .field("uc_sigmask", &self.uc_sigmask) +                // Ignore __private field +                    .finish() +            } +        } + +        impl ::hash::Hash for ucontext_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.uc_flags.hash(state); +                self.uc_link.hash(state); +                self.uc_stack.hash(state); +                self.uc_mcontext.hash(state); +                self.uc_sigmask.hash(state); +                // Ignore __private field +            } +        } +    } +} +  pub const TIOCGSOFTCAR: ::c_ulong = 0x5419;  pub const TIOCSSOFTCAR: ::c_ulong = 0x541A; diff --git a/libc/src/unix/notbsd/linux/other/mod.rs b/libc/src/unix/notbsd/linux/other/mod.rs index c1e3393..1a97d1c 100644 --- a/libc/src/unix/notbsd/linux/other/mod.rs +++ b/libc/src/unix/notbsd/linux/other/mod.rs @@ -29,49 +29,13 @@ s! {          pub tv_usec: ::int32_t,      } -    pub struct utmpx { -        pub ut_type: ::c_short, -        pub ut_pid: ::pid_t, -        pub ut_line: [::c_char; __UT_LINESIZE], -        pub ut_id: [::c_char; 4], - -        pub ut_user: [::c_char; __UT_NAMESIZE], -        pub ut_host: [::c_char; __UT_HOSTSIZE], -        pub ut_exit: __exit_status, - -        #[cfg(any(target_arch = "aarch64", -                  target_arch = "sparc64", -                  all(target_pointer_width = "32", -                      not(target_arch = "x86_64"))))] -        pub ut_session: ::c_long, -        #[cfg(any(target_arch = "aarch64", -                  target_arch = "sparc64", -                  all(target_pointer_width = "32", -                      not(target_arch = "x86_64"))))] -        pub ut_tv: ::timeval, - -        #[cfg(not(any(target_arch = "aarch64", -                      target_arch = "sparc64", -                      all(target_pointer_width = "32", -                          not(target_arch = "x86_64")))))] -        pub ut_session: ::int32_t, -        #[cfg(not(any(target_arch = "aarch64", -                      target_arch = "sparc64", -                      all(target_pointer_width = "32", -                          not(target_arch = "x86_64")))))] -        pub ut_tv: __timeval, - -        pub ut_addr_v6: [::int32_t; 4], -        __glibc_reserved: [::c_char; 20], -    } -      pub struct sigaction {          pub sa_sigaction: ::sighandler_t,          pub sa_mask: ::sigset_t,          #[cfg(target_arch = "sparc64")]          __reserved0: ::c_int,          pub sa_flags: ::c_int, -        pub sa_restorer: ::dox::Option<extern fn()>, +        pub sa_restorer: ::Option<extern fn()>,      }      pub struct stack_t { @@ -84,6 +48,12 @@ s! {          pub si_signo: ::c_int,          pub si_errno: ::c_int,          pub si_code: ::c_int, +        #[deprecated( +            since="0.2.54", +            note="Please leave a comment on \ +                https://github.com/rust-lang/libc/pull/1316 if you're using \ +                this field" +        )]          pub _pad: [::c_int; 29],          #[cfg(target_arch = "x86_64")]          _align: [u64; 0], @@ -157,20 +127,6 @@ s! {          pub l_pid: ::pid_t,      } -    // FIXME this is actually a union -    #[cfg_attr(all(feature = "align", target_pointer_width = "32"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", target_pointer_width = "64"), -               repr(align(8)))] -    pub struct sem_t { -        #[cfg(target_pointer_width = "32")] -        __size: [::c_char; 16], -        #[cfg(target_pointer_width = "64")] -        __size: [::c_char; 32], -        #[cfg(not(feature = "align"))] -        __align: [::c_long; 0], -    } -      pub struct mallinfo {          pub arena: ::c_int,          pub ordblks: ::c_int, @@ -244,6 +200,113 @@ s! {      }  } +impl siginfo_t { +    pub unsafe fn si_addr(&self) -> *mut ::c_void { +        #[repr(C)] +        struct siginfo_sigfault { +            _si_signo: ::c_int, +            _si_errno: ::c_int, +            _si_code: ::c_int, +            si_addr: *mut ::c_void +        } +        (*(self as *const siginfo_t as *const siginfo_sigfault)).si_addr +    } +} + +s_no_extra_traits! { +    pub struct utmpx { +        pub ut_type: ::c_short, +        pub ut_pid: ::pid_t, +        pub ut_line: [::c_char; __UT_LINESIZE], +        pub ut_id: [::c_char; 4], + +        pub ut_user: [::c_char; __UT_NAMESIZE], +        pub ut_host: [::c_char; __UT_HOSTSIZE], +        pub ut_exit: __exit_status, + +        #[cfg(any(target_arch = "aarch64", +                  all(target_pointer_width = "32", +                      not(target_arch = "x86_64"))))] +        pub ut_session: ::c_long, +        #[cfg(any(target_arch = "aarch64", +                  all(target_pointer_width = "32", +                      not(target_arch = "x86_64"))))] +        pub ut_tv: ::timeval, + +        #[cfg(not(any(target_arch = "aarch64", +                      all(target_pointer_width = "32", +                          not(target_arch = "x86_64")))))] +        pub ut_session: ::int32_t, +        #[cfg(not(any(target_arch = "aarch64", +                      all(target_pointer_width = "32", +                          not(target_arch = "x86_64")))))] +        pub ut_tv: __timeval, + +        pub ut_addr_v6: [::int32_t; 4], +        __glibc_reserved: [::c_char; 20], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for utmpx { +            fn eq(&self, other: &utmpx) -> bool { +                self.ut_type == other.ut_type +                    && self.ut_pid == other.ut_pid +                    && self.ut_line == other.ut_line +                    && self.ut_id == other.ut_id +                    && self.ut_user == other.ut_user +                    && self +                    .ut_host +                    .iter() +                    .zip(other.ut_host.iter()) +                    .all(|(a,b)| a == b) +                    && self.ut_exit == other.ut_exit +                    && self.ut_session == other.ut_session +                    && self.ut_tv == other.ut_tv +                    && self.ut_addr_v6 == other.ut_addr_v6 +                    && self.__glibc_reserved == other.__glibc_reserved +            } +        } + +        impl Eq for utmpx {} + +        impl ::fmt::Debug for utmpx { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utmpx") +                    .field("ut_type", &self.ut_type) +                    .field("ut_pid", &self.ut_pid) +                    .field("ut_line", &self.ut_line) +                    .field("ut_id", &self.ut_id) +                    .field("ut_user", &self.ut_user) +                // FIXME: .field("ut_host", &self.ut_host) +                    .field("ut_exit", &self.ut_exit) +                    .field("ut_session", &self.ut_session) +                    .field("ut_tv", &self.ut_tv) +                    .field("ut_addr_v6", &self.ut_addr_v6) +                    .field("__glibc_reserved", &self.__glibc_reserved) +                    .finish() +            } +        } + +        impl ::hash::Hash for utmpx { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ut_type.hash(state); +                self.ut_pid.hash(state); +                self.ut_line.hash(state); +                self.ut_id.hash(state); +                self.ut_user.hash(state); +                self.ut_host.hash(state); +                self.ut_exit.hash(state); +                self.ut_session.hash(state); +                self.ut_tv.hash(state); +                self.ut_addr_v6.hash(state); +                self.__glibc_reserved.hash(state); +            } +        } +    } +} +  pub const __UT_LINESIZE: usize = 32;  pub const __UT_NAMESIZE: usize = 32;  pub const __UT_HOSTSIZE: usize = 256; @@ -273,7 +336,6 @@ pub const SOL_PNPIPE: ::c_int = 275;  pub const SOL_RDS: ::c_int = 276;  pub const SOL_IUCV: ::c_int = 277;  pub const SOL_CAIF: ::c_int = 278; -pub const SOL_ALG: ::c_int = 279;  pub const SOL_NFC: ::c_int = 280;  pub const SOL_XDP: ::c_int = 283; @@ -622,24 +684,10 @@ pub const NFPROTO_INET: ::c_int = 1;  pub const NFPROTO_NETDEV: ::c_int = 5;  // linux/netfilter/nf_tables.h -cfg_if!{ -    if #[cfg(any(target_arch = "arm", target_arch = "powerpc", -                 target_arch = "powerpc64", target_arch = "aarch64"))] { -        pub const NFT_TABLE_MAXNAMELEN: ::c_int = 32; -        pub const NFT_CHAIN_MAXNAMELEN: ::c_int = 32; -        pub const NFT_SET_MAXNAMELEN: ::c_int = 32; -        pub const NFT_OBJ_MAXNAMELEN: ::c_int = 32; -    } else if #[cfg(target_arch = "sparc64")] { -        pub const NFT_TABLE_MAXNAMELEN: ::c_int = 32; -        pub const NFT_CHAIN_MAXNAMELEN: ::c_int = 32; -        pub const NFT_SET_MAXNAMELEN: ::c_int = 32; -    } else { -        pub const NFT_TABLE_MAXNAMELEN: ::c_int = 256; -        pub const NFT_CHAIN_MAXNAMELEN: ::c_int = 256; -        pub const NFT_SET_MAXNAMELEN: ::c_int = 256; -        pub const NFT_OBJ_MAXNAMELEN: ::c_int = 256; -    } -} +pub const NFT_TABLE_MAXNAMELEN: ::c_int = 256; +pub const NFT_CHAIN_MAXNAMELEN: ::c_int = 256; +pub const NFT_SET_MAXNAMELEN: ::c_int = 256; +pub const NFT_OBJ_MAXNAMELEN: ::c_int = 256;  pub const NFT_USERDATA_MAXLEN: ::c_int = 256;  pub const NFT_REG_VERDICT: ::c_int = 0; @@ -698,11 +746,9 @@ cfg_if! {          pub const NFT_MSG_GETOBJ: ::c_int = 19;          pub const NFT_MSG_DELOBJ: ::c_int = 20;          pub const NFT_MSG_GETOBJ_RESET: ::c_int = 21; -        pub const NFT_MSG_MAX: ::c_int = 22; -    } else { -        pub const NFT_MSG_MAX: ::c_int = 18;      }  } +pub const NFT_MSG_MAX: ::c_int = 25;  pub const NFT_SET_ANONYMOUS: ::c_int = 0x1;  pub const NFT_SET_CONSTANT: ::c_int = 0x2; @@ -879,7 +925,7 @@ extern {                       sz: ::c_int) -> ::c_int;      pub fn glob64(pattern: *const ::c_char,                    flags: ::c_int, -                  errfunc: ::dox::Option<extern fn(epath: *const ::c_char, +                  errfunc: ::Option<extern fn(epath: *const ::c_char,                                                     errno: ::c_int)                                                     -> ::c_int>,                    pglob: *mut glob64_t) -> ::c_int; @@ -939,3 +985,13 @@ cfg_if! {          // Unknown target_arch      }  } + +cfg_if! { +    if #[cfg(libc_align)] { +        mod align; +        pub use self::align::*; +    } else { +        mod no_align; +        pub use self::no_align::*; +    } +} diff --git a/libc/src/unix/notbsd/linux/other/no_align.rs b/libc/src/unix/notbsd/linux/other/no_align.rs new file mode 100644 index 0000000..e32bf67 --- /dev/null +++ b/libc/src/unix/notbsd/linux/other/no_align.rs @@ -0,0 +1,10 @@ +s! { +    // FIXME this is actually a union +    pub struct sem_t { +        #[cfg(target_pointer_width = "32")] +        __size: [::c_char; 16], +        #[cfg(target_pointer_width = "64")] +        __size: [::c_char; 32], +        __align: [::c_long; 0], +    } +} diff --git a/libc/src/unix/notbsd/linux/s390x/align.rs b/libc/src/unix/notbsd/linux/s390x/align.rs new file mode 100644 index 0000000..21e2190 --- /dev/null +++ b/libc/src/unix/notbsd/linux/s390x/align.rs @@ -0,0 +1,10 @@ +s! { +    // FIXME this is actually a union +    #[cfg_attr(target_pointer_width = "32", +               repr(align(4)))] +    #[cfg_attr(target_pointer_width = "64", +               repr(align(8)))] +    pub struct sem_t { +        __size: [::c_char; 32], +    } +} diff --git a/libc/src/unix/notbsd/linux/s390x.rs b/libc/src/unix/notbsd/linux/s390x/mod.rs index 9e3814f..d4cf956 100644 --- a/libc/src/unix/notbsd/linux/s390x.rs +++ b/libc/src/unix/notbsd/linux/s390x/mod.rs @@ -1,4 +1,4 @@ -use pthread_mutex_t; +use ::pthread_mutex_t;  pub type blkcnt_t = i64;  pub type blksize_t = i64; @@ -92,7 +92,7 @@ s! {          pub sa_sigaction: ::sighandler_t,          __glibc_reserved0: ::c_int,          pub sa_flags: ::c_int, -        pub sa_restorer: ::dox::Option<extern fn()>, +        pub sa_restorer: ::Option<extern fn()>,          pub sa_mask: sigset_t,      } @@ -246,28 +246,11 @@ s! {          pub l_pid: ::pid_t,      } -    // FIXME this is actually a union -    #[cfg_attr(all(feature = "align", target_pointer_width = "32"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", target_pointer_width = "64"), -               repr(align(8)))] -    pub struct sem_t { -        __size: [::c_char; 32], -        #[cfg(not(feature = "align"))] -        __align: [::c_long; 0], -    } -      pub struct __psw_t {          pub mask: u64,          pub addr: u64,      } -    // FIXME: This is actually a union. -    pub struct fpreg_t { -        pub d: ::c_double, -        // f: ::c_float, -    } -      pub struct fpregset_t {          pub fpc: u32,          __pad: u32, @@ -334,6 +317,41 @@ s! {      }  } +s_no_extra_traits!{ +    // FIXME: This is actually a union. +    pub struct fpreg_t { +        pub d: ::c_double, +        // f: ::c_float, +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for fpreg_t { +            fn eq(&self, other: &fpreg_t) -> bool { +                self.d == other.d +            } +        } + +        impl Eq for fpreg_t {} + +        impl ::fmt::Debug for fpreg_t { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("fpreg_t") +                    .field("d", &self.d) +                    .finish() +            } +        } + +        impl ::hash::Hash for fpreg_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                let d: u64 = unsafe { ::mem::transmute(self.d) }; +                d.hash(state); +            } +        } +    } +} +  pub const SFD_CLOEXEC: ::c_int = 0x080000;  pub const NCCS: usize = 32; @@ -764,10 +782,6 @@ pub const PTRACE_POKEUSER: ::c_uint = 6;  pub const PTRACE_CONT: ::c_uint = 7;  pub const PTRACE_KILL: ::c_uint = 8;  pub const PTRACE_SINGLESTEP: ::c_uint = 9; -pub const PTRACE_GETREGS: ::c_uint = 12; -pub const PTRACE_SETREGS: ::c_uint = 13; -pub const PTRACE_GETFPREGS: ::c_uint = 14; -pub const PTRACE_SETFPREGS: ::c_uint = 15;  pub const PTRACE_ATTACH: ::c_uint = 16;  pub const PTRACE_DETACH: ::c_uint = 17;  pub const PTRACE_SYSCALL: ::c_uint = 24; @@ -1304,7 +1318,7 @@ extern {                       sz: ::c_int) -> ::c_int;      pub fn glob64(pattern: *const ::c_char,                    flags: ::c_int, -                  errfunc: ::dox::Option<extern fn(epath: *const ::c_char, +                  errfunc: ::Option<extern fn(epath: *const ::c_char,                                                     errno: ::c_int)                                                     -> ::c_int>,                    pglob: *mut glob64_t) -> ::c_int; @@ -1334,3 +1348,13 @@ extern {      pub fn swapcontext(uocp: *mut ucontext_t,                         ucp: *const ucontext_t) -> ::c_int;  } + +cfg_if! { +    if #[cfg(libc_align)] { +        mod align; +        pub use self::align::*; +    } else { +        mod no_align; +        pub use self::no_align::*; +    } +} diff --git a/libc/src/unix/notbsd/linux/s390x/no_align.rs b/libc/src/unix/notbsd/linux/s390x/no_align.rs new file mode 100644 index 0000000..8909114 --- /dev/null +++ b/libc/src/unix/notbsd/linux/s390x/no_align.rs @@ -0,0 +1,7 @@ +s! { +    // FIXME this is actually a union +    pub struct sem_t { +        __size: [::c_char; 32], +        __align: [::c_long; 0], +    } +} diff --git a/libc/src/unix/notbsd/mod.rs b/libc/src/unix/notbsd/mod.rs index 668c25f..d0905e1 100644 --- a/libc/src/unix/notbsd/mod.rs +++ b/libc/src/unix/notbsd/mod.rs @@ -1,5 +1,3 @@ -use dox::mem; -  pub type sa_family_t = u16;  pub type pthread_key_t = ::c_uint;  pub type speed_t = ::c_uint; @@ -8,9 +6,23 @@ pub type clockid_t = ::c_int;  pub type key_t = ::c_int;  pub type id_t = ::c_uint; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum timezone {} +impl ::Copy for timezone {} +impl ::Clone for timezone { +    fn clone(&self) -> timezone { *self } +}  s! { +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } + +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } +      pub struct sockaddr {          pub sa_family: sa_family_t,          pub sa_data: [::c_char; 14], @@ -31,20 +43,6 @@ s! {          pub sin6_scope_id: u32,      } -    pub struct sockaddr_un { -        pub sun_family: sa_family_t, -        pub sun_path: [::c_char; 108] -    } - -    pub struct sockaddr_storage { -        pub ss_family: sa_family_t, -        __ss_align: ::size_t, -        #[cfg(target_pointer_width = "32")] -        __ss_pad2: [u8; 128 - 2 * 4], -        #[cfg(target_pointer_width = "64")] -        __ss_pad2: [u8; 128 - 2 * 8], -    } -      pub struct addrinfo {          pub ai_flags: ::c_int,          pub ai_family: ::c_int, @@ -118,25 +116,6 @@ s! {          pub dli_saddr: *mut ::c_void,      } -    #[cfg_attr(any(all(target_arch = "x86", -                       not(target_env = "musl"), -                       not(target_os = "android")), -                   target_arch = "x86_64"), -               repr(packed))] -    pub struct epoll_event { -        pub events: ::uint32_t, -        pub u64: ::uint64_t, -    } - -    pub struct utsname { -        pub sysname: [::c_char; 65], -        pub nodename: [::c_char; 65], -        pub release: [::c_char; 65], -        pub version: [::c_char; 65], -        pub machine: [::c_char; 65], -        pub domainname: [::c_char; 65] -    } -      pub struct lconv {          pub decimal_point: *mut ::c_char,          pub thousands_sep: *mut ::c_char, @@ -228,6 +207,195 @@ s! {          pub ar_pln: u8,          pub ar_op: u16,      } + +    pub struct mmsghdr { +        pub msg_hdr: ::msghdr, +        pub msg_len: ::c_uint, +    } +} + +s_no_extra_traits!{ +    #[cfg_attr( +        any( +            all( +                target_arch = "x86", +                not(target_env = "musl"), +                not(target_os = "android")), +            target_arch = "x86_64"), +        repr(packed))] +    pub struct epoll_event { +        pub events: ::uint32_t, +        pub u64: ::uint64_t, +    } + +    pub struct sockaddr_un { +        pub sun_family: sa_family_t, +        pub sun_path: [::c_char; 108] +    } + +    pub struct sockaddr_storage { +        pub ss_family: sa_family_t, +        __ss_align: ::size_t, +        #[cfg(target_pointer_width = "32")] +        __ss_pad2: [u8; 128 - 2 * 4], +        #[cfg(target_pointer_width = "64")] +        __ss_pad2: [u8; 128 - 2 * 8], +    } + +    pub struct utsname { +        pub sysname: [::c_char; 65], +        pub nodename: [::c_char; 65], +        pub release: [::c_char; 65], +        pub version: [::c_char; 65], +        pub machine: [::c_char; 65], +        pub domainname: [::c_char; 65] +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for epoll_event { +            fn eq(&self, other: &epoll_event) -> bool { +                self.events == other.events +                    && self.u64 == other.u64 +            } +        } +        impl Eq for epoll_event {} +        impl ::fmt::Debug for epoll_event { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                let events = self.events; +                let u64 = self.u64; +                f.debug_struct("epoll_event") +                    .field("events", &events) +                    .field("u64", &u64) +                    .finish() +            } +        } +        impl ::hash::Hash for epoll_event { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                let events = self.events; +                let u64 = self.u64; +                events.hash(state); +                u64.hash(state); +            } +        } + +        impl PartialEq for sockaddr_un { +            fn eq(&self, other: &sockaddr_un) -> bool { +                self.sun_family == other.sun_family +                    && self +                    .sun_path +                    .iter() +                    .zip(other.sun_path.iter()) +                    .all(|(a, b)| a == b) +            } +        } +        impl Eq for sockaddr_un {} +        impl ::fmt::Debug for sockaddr_un { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_un") +                    .field("sun_family", &self.sun_family) +                // FIXME: .field("sun_path", &self.sun_path) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_un { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sun_family.hash(state); +                self.sun_path.hash(state); +            } +        } + +        impl PartialEq for sockaddr_storage { +            fn eq(&self, other: &sockaddr_storage) -> bool { +                self.ss_family == other.ss_family +                    && self +                    .__ss_pad2 +                    .iter() +                    .zip(other.__ss_pad2.iter()) +                    .all(|(a, b)| a == b) +            } +        } + +        impl Eq for sockaddr_storage {} + +        impl ::fmt::Debug for sockaddr_storage { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_storage") +                    .field("ss_family", &self.ss_family) +                    .field("__ss_align", &self.__ss_align) +                // FIXME: .field("__ss_pad2", &self.__ss_pad2) +                    .finish() +            } +        } + +        impl ::hash::Hash for sockaddr_storage { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ss_family.hash(state); +                self.__ss_pad2.hash(state); +            } +        } + +        impl PartialEq for utsname { +            fn eq(&self, other: &utsname) -> bool { +                self.sysname +                    .iter() +                    .zip(other.sysname.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .nodename +                    .iter() +                    .zip(other.nodename.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .release +                    .iter() +                    .zip(other.release.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .version +                    .iter() +                    .zip(other.version.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .machine +                    .iter() +                    .zip(other.machine.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .domainname +                    .iter() +                    .zip(other.domainname.iter()) +                    .all(|(a, b)| a == b) +            } +        } + +        impl Eq for utsname {} + +        impl ::fmt::Debug for utsname { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utsname") +                // FIXME: .field("sysname", &self.sysname) +                // FIXME: .field("nodename", &self.nodename) +                // FIXME: .field("release", &self.release) +                // FIXME: .field("version", &self.version) +                // FIXME: .field("machine", &self.machine) +                // FIXME: .field("domainname", &self.domainname) +                    .finish() +            } +        } + +        impl ::hash::Hash for utsname { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sysname.hash(state); +                self.nodename.hash(state); +                self.release.hash(state); +                self.version.hash(state); +                self.machine.hash(state); +                self.domainname.hash(state); +            } +        } +    }  }  // intentionally not public, only used for fd_set @@ -514,6 +682,7 @@ pub const SOL_DCCP: ::c_int = 269;  pub const SOL_NETLINK: ::c_int = 270;  pub const SOL_TIPC: ::c_int = 271;  pub const SOL_BLUETOOTH: ::c_int = 274; +pub const SOL_ALG: ::c_int = 279;  pub const AF_UNSPEC: ::c_int = 0;  pub const AF_UNIX: ::c_int = 1; @@ -985,60 +1154,48 @@ pub const ARPHRD_IEEE802154: u16 = 804;  pub const ARPHRD_VOID: u16 = 0xFFFF;  pub const ARPHRD_NONE: u16 = 0xFFFE; +fn CMSG_ALIGN(len: usize) -> usize { +    len + ::mem::size_of::<usize>() - 1 & !(::mem::size_of::<usize>() - 1) +} +  f! {      pub fn CMSG_FIRSTHDR(mhdr: *const msghdr) -> *mut cmsghdr { -        if (*mhdr).msg_controllen as usize >= mem::size_of::<cmsghdr>() { +        if (*mhdr).msg_controllen as usize >= ::mem::size_of::<cmsghdr>() {              (*mhdr).msg_control as *mut cmsghdr          } else {              0 as *mut cmsghdr          }      } -    pub fn CMSG_NXTHDR(mhdr: *const msghdr, -                       cmsg: *const cmsghdr) -> *mut cmsghdr { -        if cmsg.is_null() { -            return CMSG_FIRSTHDR(mhdr); -        }; -        let pad = mem::align_of::<cmsghdr>() - 1; -        let next = cmsg as usize + (*cmsg).cmsg_len as usize + pad & !pad; -        let max = (*mhdr).msg_control as usize -            + (*mhdr).msg_controllen as usize; -        if next < max { -            next as *mut cmsghdr -        } else { -            0 as *mut cmsghdr -        } -    } -      pub fn CMSG_DATA(cmsg: *const cmsghdr) -> *mut ::c_uchar {          cmsg.offset(1) as *mut ::c_uchar      }      pub fn CMSG_SPACE(length: ::c_uint) -> ::c_uint { -        let pad = mem::align_of::<cmsghdr>() as ::c_uint - 1; -        mem::size_of::<cmsghdr>() as ::c_uint + ((length + pad) & !pad) +        (CMSG_ALIGN(length as usize) + CMSG_ALIGN(::mem::size_of::<cmsghdr>())) +            as ::c_uint      }      pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint { -        mem::size_of::<cmsghdr>() as ::c_uint + length +        CMSG_ALIGN(::mem::size_of::<cmsghdr>()) as ::c_uint + length      }      pub fn FD_CLR(fd: ::c_int, set: *mut fd_set) -> () {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          (*set).fds_bits[fd / size] &= !(1 << (fd % size));          return      }      pub fn FD_ISSET(fd: ::c_int, set: *mut fd_set) -> bool {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          return ((*set).fds_bits[fd / size] & (1 << (fd % size))) != 0      }      pub fn FD_SET(fd: ::c_int, set: *mut fd_set) -> () {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          (*set).fds_bits[fd / size] |= 1 << (fd % size);          return      } @@ -1103,6 +1260,12 @@ f! {  }  extern { +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int; +      pub fn fdatasync(fd: ::c_int) -> ::c_int;      pub fn mincore(addr: *mut ::c_void, len: ::size_t,                     vec: *mut ::c_uchar) -> ::c_int; @@ -1220,6 +1383,11 @@ extern {                  name: *mut ::c_char,                  termp: *const termios,                  winp: *const ::winsize) -> ::c_int; +    pub fn forkpty(amaster: *mut ::c_int, +                name: *mut ::c_char, +                termp: *const termios, +                winp: *const ::winsize) -> ::pid_t; +    pub fn login_tty(fd: ::c_int) -> ::c_int;      pub fn execvpe(file: *const ::c_char, argv: *const *const ::c_char,                     envp: *const *const ::c_char) -> ::c_int;      pub fn fexecve(fd: ::c_int, argv: *const *const ::c_char, @@ -1259,7 +1427,3 @@ cfg_if! {          // Unknown target_os      }  } -    // pub fn forkpty(amaster: *mut ::c_int, -    //             name: *mut ::c_char, -    //             termp: *const termios, -    //             winp: *const ::winsize) -> ::pid_t; diff --git a/libc/src/unix/redox/mod.rs b/libc/src/unix/redox/mod.rs new file mode 100644 index 0000000..4bb1ab4 --- /dev/null +++ b/libc/src/unix/redox/mod.rs @@ -0,0 +1,588 @@ +pub type c_char = i8; +pub type c_long = i64; +pub type c_ulong = u64; +pub type wchar_t = i32; + +pub type blkcnt_t = ::c_ulong; +pub type blksize_t = ::c_long; +pub type clock_t = ::c_long; +pub type clockid_t = ::c_int; +pub type dev_t = ::c_long; +pub type fsblkcnt_t = ::c_ulong; +pub type fsfilcnt_t = ::c_ulong; +pub type ino_t = ::c_ulong; +pub type mode_t = ::c_int; +pub type nfds_t = ::c_ulong; +pub type nlink_t = ::c_ulong; +pub type off_t = ::c_long; +pub type pthread_t = *mut ::c_void; +pub type pthread_attr_t = *mut ::c_void; +pub type pthread_cond_t = *mut ::c_void; +pub type pthread_condattr_t = *mut ::c_void; +// Must be usize due to libstd/sys_common/thread_local.rs, +// should technically be *mut ::c_void +pub type pthread_key_t = usize; +pub type pthread_mutex_t = *mut ::c_void; +pub type pthread_mutexattr_t = *mut ::c_void; +pub type pthread_rwlock_t = *mut ::c_void; +pub type pthread_rwlockattr_t = *mut ::c_void; +pub type rlim_t = ::c_ulonglong; +pub type sa_family_t = u16; +pub type sem_t = *mut ::c_void; +pub type sigset_t = ::c_ulong; +pub type socklen_t = u32; +pub type speed_t = u32; +pub type suseconds_t = ::c_int; +pub type tcflag_t = u32; +pub type time_t = ::c_long; + +s! { +    pub struct addrinfo { +        pub ai_flags: ::c_int, +        pub ai_family: ::c_int, +        pub ai_socktype: ::c_int, +        pub ai_protocol: ::c_int, +        pub ai_addrlen: ::size_t, +        pub ai_canonname: *mut ::c_char, +        pub ai_addr: *mut ::sockaddr, +        pub ai_next: *mut ::addrinfo, +    } + +    pub struct dirent { +        pub d_ino: ::ino_t, +        pub d_off: ::off_t, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } + +    pub struct Dl_info { +        pub dli_fname: *const ::c_char, +        pub dli_fbase: *mut ::c_void, +        pub dli_sname: *const ::c_char, +        pub dli_saddr: *mut ::c_void, +    } + +    pub struct epoll_event { +        pub events: u32, +        pub u64: u64, +        pub _pad: u64, +    } + +    pub struct fd_set { +        fds_bits: [::c_ulong; ::FD_SETSIZE / ULONG_SIZE], +    } + +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } + +    pub struct ip_mreq { +        pub imr_multiaddr: ::in_addr, +        pub imr_interface: ::in_addr, +    } + +    pub struct lconv { +        pub currency_symbol: *const ::c_char, +        pub decimal_point: *const ::c_char, +        pub frac_digits: ::c_char, +        pub grouping: *const ::c_char, +        pub int_curr_symbol: *const ::c_char, +        pub int_frac_digits: ::c_char, +        pub mon_decimal_point: *const ::c_char, +        pub mon_grouping: *const ::c_char, +        pub mon_thousands_sep: *const ::c_char, +        pub negative_sign: *const ::c_char, +        pub n_cs_precedes: ::c_char, +        pub n_sep_by_space: ::c_char, +        pub n_sign_posn: ::c_char, +        pub positive_sign: *const ::c_char, +        pub p_cs_precedes: ::c_char, +        pub p_sep_by_space: ::c_char, +        pub p_sign_posn: ::c_char, +        pub thousands_sep: *const ::c_char, +    } + +    pub struct passwd { +        pub pw_name: *mut ::c_char, +        pub pw_passwd: *mut ::c_char, +        pub pw_uid: ::uid_t, +        pub pw_gid: ::gid_t, +        pub pw_gecos: *mut ::c_char, +        pub pw_dir: *mut ::c_char, +        pub pw_shell: *mut ::c_char, +    } + +    pub struct sigaction { +        pub sa_handler: ::sighandler_t, +        pub sa_flags: ::c_ulong, +        pub sa_restorer: ::Option<extern fn()>, +        pub sa_mask: ::sigset_t, +    } + +    pub struct sockaddr { +        pub sa_family: ::sa_family_t, +        pub sa_data: [::c_char; 14], +    } + +    pub struct sockaddr_in { +        pub sin_family: ::sa_family_t, +        pub sin_port: ::in_port_t, +        pub sin_addr: ::in_addr, +        pub sin_zero: [::c_char; 8], +    } + +    pub struct sockaddr_in6 { +        pub sin6_family: ::sa_family_t, +        pub sin6_port: ::in_port_t, +        pub sin6_flowinfo: u32, +        pub sin6_addr: ::in6_addr, +        pub sin6_scope_id: u32, +    } + +    pub struct sockaddr_storage { +        pub ss_family: ::sa_family_t, +        __ss_padding: [ +            u8; +            128 - +            ::core::mem::size_of::<sa_family_t>() - +            ::core::mem::size_of::<c_ulong>() +        ], +        __ss_align: ::c_ulong, +    } + +    pub struct sockaddr_un { +        pub sun_family: ::sa_family_t, +        pub sun_path: [::c_char; 108] +    } + +    pub struct stat { +        pub st_dev: ::dev_t, +        pub st_ino: ::ino_t, +        pub st_nlink: ::nlink_t, +        pub st_mode: ::mode_t, +        pub st_uid: ::uid_t, +        pub st_gid: ::gid_t, +        pub st_rdev: ::dev_t, +        pub st_size: ::off_t, +        pub st_blksize: ::blksize_t, +        pub st_blocks: ::blkcnt_t, +        pub st_atime: ::time_t, +        pub st_atime_nsec: ::c_long, +        pub st_mtime: ::time_t, +        pub st_mtime_nsec: ::c_long, +        pub st_ctime: ::time_t, +        pub st_ctime_nsec: ::c_long, +        _pad: [::c_char; 24], +    } + +    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_flag: ::c_ulong, +        pub f_namemax: ::c_ulong, +    } + +    pub struct termios { +        pub c_iflag: ::tcflag_t, +        pub c_oflag: ::tcflag_t, +        pub c_cflag: ::tcflag_t, +        pub c_lflag: ::tcflag_t, +        pub c_line: ::cc_t, +        pub c_cc: [::cc_t; ::NCCS], +        pub c_ispeed: ::speed_t, +        pub c_ospeed: ::speed_t, +    } + +    pub struct tm { +        pub tm_sec: ::c_int, +        pub tm_min: ::c_int, +        pub tm_hour: ::c_int, +        pub tm_mday: ::c_int, +        pub tm_mon: ::c_int, +        pub tm_year: ::c_int, +        pub tm_wday: ::c_int, +        pub tm_yday: ::c_int, +        pub tm_isdst: ::c_int, +        pub tm_gmtoff: ::c_long, +        pub tm_zone: *const ::c_char, +    } +} + +// TODO: relibc { +    pub const RTLD_DEFAULT: *mut ::c_void = 0i64 as *mut ::c_void; +// } + +// dlfcn.h + +pub const RTLD_LAZY: ::c_int = 0x0001; +pub const RTLD_NOW: ::c_int = 0x0002; +pub const RTLD_GLOBAL: ::c_int = 0x0100; +pub const RTLD_LOCAL: ::c_int = 0x0000; + +// errno.h +pub const EPERM: ::c_int = 1; +pub const ENOENT: ::c_int = 2; +pub const ESRCH: ::c_int = 3; +pub const EINTR: ::c_int = 4; +pub const EIO: ::c_int = 5; +pub const ENXIO: ::c_int = 6; +pub const E2BIG: ::c_int = 7; +pub const ENOEXEC: ::c_int = 8; +pub const EBADF: ::c_int = 9; +pub const ECHILD: ::c_int = 10; +pub const EAGAIN: ::c_int = 11; +pub const ENOMEM: ::c_int = 12; +pub const EACCES: ::c_int = 13; +pub const EFAULT: ::c_int = 14; +pub const ENOTBLK: ::c_int = 15; +pub const EBUSY: ::c_int = 16; +pub const EEXIST: ::c_int = 17; +pub const EXDEV: ::c_int = 18; +pub const ENODEV: ::c_int = 19; +pub const ENOTDIR: ::c_int = 20; +pub const EISDIR: ::c_int = 21; +pub const EINVAL: ::c_int = 22; +pub const ENFILE: ::c_int = 23; +pub const EMFILE: ::c_int = 24; +pub const ENOTTY: ::c_int = 25; +pub const ETXTBSY: ::c_int = 26; +pub const EFBIG: ::c_int = 27; +pub const ENOSPC: ::c_int = 28; +pub const ESPIPE: ::c_int = 29; +pub const EROFS: ::c_int = 30; +pub const EMLINK: ::c_int = 31; +pub const EPIPE: ::c_int = 32; +pub const EDOM: ::c_int = 33; +pub const ERANGE: ::c_int = 34; +pub const EDEADLK: ::c_int = 35; +pub const ENOSYS: ::c_int = 38; +pub const EWOULDBLOCK: ::c_int = 41; +pub const EADDRINUSE: ::c_int = 98; +pub const EADDRNOTAVAIL: ::c_int = 99; +pub const ECONNABORTED: ::c_int = 103; +pub const ECONNRESET: ::c_int = 104; +pub const ENOTCONN: ::c_int = 107; +pub const ETIMEDOUT: ::c_int = 110; +pub const ECONNREFUSED: ::c_int = 111; +pub const EINPROGRESS: ::c_int = 115; + +// fcntl.h +pub const F_DUPFD: ::c_int = 0; +pub const F_GETFD: ::c_int = 1; +pub const F_SETFD: ::c_int = 2; +pub const F_GETFL: ::c_int = 3; +pub const F_SETFL: ::c_int = 4; +// TODO: relibc { +    pub const F_DUPFD_CLOEXEC: ::c_int = ::F_DUPFD; +// } +pub const FD_CLOEXEC: ::c_int = 0x0100_0000; +pub const O_RDONLY: ::c_int = 0x0001_0000; +pub const O_WRONLY: ::c_int = 0x0002_0000; +pub const O_RDWR: ::c_int = 0x0003_0000; +pub const O_ACCMODE: ::c_int = 0x0003_0000; +pub const O_NONBLOCK: ::c_int = 0x0004_0000; +pub const O_APPEND: ::c_int = 0x0008_0000; +pub const O_SHLOCK: ::c_int = 0x0010_0000; +pub const O_EXLOCK: ::c_int = 0x0020_0000; +pub const O_ASYNC: ::c_int = 0x0040_0000; +pub const O_FSYNC: ::c_int = 0x0080_0000; +pub const O_CLOEXEC: ::c_int = 0x0100_0000; +pub const O_CREAT: ::c_int = 0x0200_0000; +pub const O_TRUNC: ::c_int = 0x0400_0000; +pub const O_EXCL: ::c_int = 0x0800_0000; +pub const O_DIRECTORY: ::c_int = 0x1000_0000; +pub const O_PATH: ::c_int = 0x2000_0000; +pub const O_SYMLINK: ::c_int = 0x4000_0000; +// Negative to allow it to be used as int +// TODO: Fix negative values missing from includes +pub const O_NOFOLLOW: ::c_int = -0x8000_0000; + +// netdb.h +pub const EAI_SYSTEM: ::c_int = -11; + +// netinet/in.h +// TODO: relibc { +    pub const IP_TTL: ::c_int = 2; +    pub const IPV6_UNICAST_HOPS: ::c_int = 16; +    pub const IPV6_MULTICAST_IF: ::c_int = 17; +    pub const IPV6_MULTICAST_HOPS: ::c_int = 18; +    pub const IPV6_MULTICAST_LOOP: ::c_int = 19; +    pub const IPV6_ADD_MEMBERSHIP: ::c_int = 20; +    pub const IPV6_DROP_MEMBERSHIP: ::c_int = 21; +    pub const IPV6_V6ONLY: ::c_int = 26; +    pub const IP_MULTICAST_IF: ::c_int = 32; +    pub const IP_MULTICAST_TTL: ::c_int = 33; +    pub const IP_MULTICAST_LOOP: ::c_int = 34; +    pub const IP_ADD_MEMBERSHIP: ::c_int = 35; +    pub const IP_DROP_MEMBERSHIP: ::c_int = 36; +// } + +// netinet/tcp.h +pub const TCP_NODELAY: ::c_int = 1; +// TODO: relibc { +    pub const TCP_KEEPIDLE: ::c_int = 1; +// } + +// poll.h +pub const POLLIN: ::c_short = 0x001; +pub const POLLPRI: ::c_short = 0x002; +pub const POLLOUT: ::c_short = 0x004; +pub const POLLERR: ::c_short = 0x008; +pub const POLLHUP: ::c_short = 0x010; +pub const POLLNVAL: ::c_short = 0x020; + +// pthread.h +pub const PTHREAD_MUTEX_NORMAL: ::c_int = 0; +pub const PTHREAD_MUTEX_RECURSIVE: ::c_int = 1; +pub const PTHREAD_MUTEX_INITIALIZER: ::pthread_mutex_t = -1isize as *mut _; +pub const PTHREAD_COND_INITIALIZER: ::pthread_cond_t = -1isize as *mut _; +pub const PTHREAD_RWLOCK_INITIALIZER: ::pthread_rwlock_t = -1isize as *mut _; +pub const PTHREAD_STACK_MIN : ::size_t = 4096; + +// signal.h +pub const SIG_BLOCK: ::c_int = 0; +pub const SIG_UNBLOCK: ::c_int = 1; +pub const SIG_SETMASK: ::c_int = 2; +pub const SIGHUP: ::c_int = 1; +pub const SIGINT: ::c_int = 2; +pub const SIGQUIT: ::c_int = 3; +pub const SIGILL: ::c_int = 4; +pub const SIGTRAP: ::c_int = 5; +pub const SIGABRT: ::c_int = 6; +pub const SIGBUS: ::c_int = 7; +pub const SIGFPE: ::c_int = 8; +pub const SIGKILL: ::c_int = 9; +pub const SIGUSR1: ::c_int = 10; +pub const SIGSEGV: ::c_int = 11; +pub const SIGUSR2: ::c_int = 12; +pub const SIGPIPE: ::c_int = 13; +pub const SIGALRM: ::c_int = 14; +pub const SIGTERM: ::c_int = 15; +pub const SIGSTKFLT: ::c_int = 16; +pub const SIGCHLD: ::c_int = 17; +pub const SIGCONT: ::c_int = 18; +pub const SIGSTOP: ::c_int = 19; +pub const SIGTSTP: ::c_int = 20; +pub const SIGTTIN: ::c_int = 21; +pub const SIGTTOU: ::c_int = 22; +pub const SIGURG: ::c_int = 23; +pub const SIGXCPU: ::c_int = 24; +pub const SIGXFSZ: ::c_int = 25; +pub const SIGVTALRM: ::c_int = 26; +pub const SIGPROF: ::c_int = 27; +pub const SIGWINCH: ::c_int = 28; +pub const SIGIO: ::c_int = 29; +pub const SIGPWR: ::c_int = 30; +pub const SIGSYS: ::c_int = 31; +pub const NSIG: ::c_int = 32; + +// sys/epoll.h +pub const EPOLL_CLOEXEC: ::c_int = 0x0100_0000; +pub const EPOLL_CTL_ADD: ::c_int = 1; +pub const EPOLL_CTL_DEL: ::c_int = 2; +pub const EPOLL_CTL_MOD: ::c_int = 3; +pub const EPOLLIN: ::c_int = 1; +pub const EPOLLPRI: ::c_int = 0; +pub const EPOLLOUT: ::c_int = 2; +pub const EPOLLRDNORM: ::c_int = 0; +pub const EPOLLNVAL: ::c_int = 0; +pub const EPOLLRDBAND: ::c_int = 0; +pub const EPOLLWRNORM: ::c_int = 0; +pub const EPOLLWRBAND: ::c_int = 0; +pub const EPOLLMSG: ::c_int = 0; +pub const EPOLLERR: ::c_int = 0; +pub const EPOLLHUP: ::c_int = 0; +pub const EPOLLRDHUP: ::c_int = 0; +pub const EPOLLEXCLUSIVE: ::c_int = 0; +pub const EPOLLWAKEUP: ::c_int = 0; +pub const EPOLLONESHOT: ::c_int = 0; +pub const EPOLLET: ::c_int = 0; + +// sys/stat.h +pub const S_IFMT: ::c_int = 0o0_170_000; +pub const S_IFDIR: ::c_int = 0o040_000; +pub const S_IFCHR: ::c_int = 0o020_000; +pub const S_IFBLK: ::c_int = 0o060_000; +pub const S_IFREG: ::c_int = 0o100_000; +pub const S_IFIFO: ::c_int = 0o010_000; +pub const S_IFLNK: ::c_int = 0o120_000; +pub const S_IFSOCK: ::c_int = 0o140_000; +pub const S_IRWXU: ::c_int = 0o0_700; +pub const S_IRUSR: ::c_int = 0o0_400; +pub const S_IWUSR: ::c_int = 0o0_200; +pub const S_IXUSR: ::c_int = 0o0_100; +pub const S_IRWXG: ::c_int = 0o0_070; +pub const S_IRGRP: ::c_int = 0o0_040; +pub const S_IWGRP: ::c_int = 0o0_020; +pub const S_IXGRP: ::c_int = 0o0_010; +pub const S_IRWXO: ::c_int = 0o0_007; +pub const S_IROTH: ::c_int = 0o0_004; +pub const S_IWOTH: ::c_int = 0o0_002; +pub const S_IXOTH: ::c_int = 0o0_001; + +// stdlib.h +pub const EXIT_SUCCESS: ::c_int = 0; +pub const EXIT_FAILURE: ::c_int = 1; + +// sys/ioctl.h +// TODO: relibc { +    pub const FIONBIO: ::c_ulong = 0x5421; +    pub const FIOCLEX: ::c_ulong = 0x5451; +// } +pub const TCGETS: ::c_ulong = 0x5401; +pub const TCSETS: ::c_ulong = 0x5402; +pub const TCFLSH: ::c_ulong = 0x540B; +pub const TIOCGPGRP: ::c_ulong = 0x540F; +pub const TIOCSPGRP: ::c_ulong = 0x5410; +pub const TIOCGWINSZ: ::c_ulong = 0x5413; +pub const TIOCSWINSZ: ::c_ulong = 0x5414; + +// sys/select.h +pub const FD_SETSIZE: usize = 1024; + +// sys/socket.h +pub const AF_UNIX: ::c_int = 1; +pub const AF_INET: ::c_int = 2; +pub const AF_INET6: ::c_int = 10; +pub const MSG_PEEK: ::c_int = 2; +pub const SHUT_RD: ::c_int = 0; +pub const SHUT_WR: ::c_int = 1; +pub const SHUT_RDWR: ::c_int = 2; +pub const SO_REUSEADDR: ::c_int = 2; +pub const SO_ERROR: ::c_int = 4; +pub const SO_BROADCAST: ::c_int = 6; +pub const SO_SNDBUF: ::c_int = 7; +pub const SO_RCVBUF: ::c_int = 8; +pub const SO_KEEPALIVE: ::c_int = 9; +pub const SO_LINGER: ::c_int = 13; +pub const SO_REUSEPORT: ::c_int = 15; +pub const SO_RCVTIMEO: ::c_int = 20; +pub const SO_SNDTIMEO: ::c_int = 21; +pub const SOCK_STREAM: ::c_int = 1; +pub const SOCK_DGRAM: ::c_int = 2; +pub const SOL_SOCKET: ::c_int = 1; + +// sys/wait.h +pub const WNOHANG: ::c_int = 1; + +// termios.h +pub const NCCS: usize = 32; + +// time.h +pub const CLOCK_REALTIME: ::c_int = 1; +pub const CLOCK_MONOTONIC: ::c_int = 4; + +// unistd.h +pub const _SC_PAGESIZE: ::c_int = 30; +pub const SEEK_SET: ::c_int = 0; +pub const SEEK_CUR: ::c_int = 1; +pub const SEEK_END: ::c_int = 2; +pub const STDIN_FILENO: ::c_int = 0; +pub const STDOUT_FILENO: ::c_int = 1; +pub const STDERR_FILENO: ::c_int = 2; + +// wait.h +pub fn WIFSTOPPED(status: ::c_int) -> bool { +    (status & 0xff) == 0x7f +} + +pub fn WSTOPSIG(status: ::c_int) -> ::c_int { +    (status >> 8) & 0xff +} + +pub fn WIFCONTINUED(status: ::c_int) -> bool { +    status == 0xffff +} + +pub fn WIFSIGNALED(status: ::c_int) -> bool { +    ((status & 0x7f) + 1) as i8 >= 2 +} + +pub fn WTERMSIG(status: ::c_int) -> ::c_int { +    status & 0x7f +} + +pub fn WIFEXITED(status: ::c_int) -> bool { +    (status & 0x7f) == 0 +} + +pub fn WEXITSTATUS(status: ::c_int) -> ::c_int { +    (status >> 8) & 0xff +} + +pub fn WCOREDUMP(status: ::c_int) -> bool { +    (status & 0x80) != 0 +} + +// intentionally not public, only used for fd_set +cfg_if! { +    if #[cfg(target_pointer_width = "32")] { +        const ULONG_SIZE: usize = 32; +    } else if #[cfg(target_pointer_width = "64")] { +        const ULONG_SIZE: usize = 64; +    } else { +        // Unknown target_pointer_width +    } +} + +extern { +    // malloc.h +    pub fn memalign(align: ::size_t, size: ::size_t) -> *mut ::c_void; + +    // pthread.h +    pub fn pthread_atfork(prepare: ::Option<unsafe extern fn()>, +                          parent: ::Option<unsafe extern fn()>, +                          child: ::Option<unsafe extern fn()>) -> ::c_int; +    pub fn pthread_create(tid: *mut ::pthread_t, +                          attr: *const ::pthread_attr_t, +                          start: extern fn(*mut ::c_void) -> *mut ::c_void, +                          arg: *mut ::c_void) -> ::c_int; +    pub fn pthread_condattr_setclock(attr: *mut pthread_condattr_t, +                                     clock_id: ::clockid_t) -> ::c_int; + +    // signal.h +    pub fn pthread_sigmask(how: ::c_int, +                           set: *const ::sigset_t, +                           oldset: *mut ::sigset_t) -> ::c_int; + +    // sys/epoll.h +    pub fn epoll_create(size: ::c_int) -> ::c_int; +    pub fn epoll_create1(flags: ::c_int) -> ::c_int; +    pub fn epoll_wait(epfd: ::c_int, +                      events: *mut ::epoll_event, +                      maxevents: ::c_int, +                      timeout: ::c_int) -> ::c_int; +    pub fn epoll_ctl(epfd: ::c_int, +                     op: ::c_int, +                     fd: ::c_int, +                     event: *mut ::epoll_event) -> ::c_int; + +    // sys/ioctl.h +    pub fn ioctl(fd: ::c_int, request: ::c_ulong, ...) -> ::c_int; + +    // sys/socket.h +    pub fn bind(socket: ::c_int, address: *const ::sockaddr, +                address_len: ::socklen_t) -> ::c_int; +    pub fn recvfrom(socket: ::c_int, buf: *mut ::c_void, len: ::size_t, +                    flags: ::c_int, addr: *mut ::sockaddr, +                    addrlen: *mut ::socklen_t) -> ::ssize_t; + +    // sys/uio.h +    pub fn readv(fd: ::c_int, +                 iov: *const ::iovec, +                 iovcnt: ::c_int) -> ::ssize_t; +    pub fn writev(fd: ::c_int, +                  iov: *const ::iovec, +                  iovcnt: ::c_int) -> ::ssize_t; + +    // time.h +    pub fn clock_gettime(clk_id: ::clockid_t, tp: *mut ::timespec) -> ::c_int; +} diff --git a/libc/src/unix/solarish/compat.rs b/libc/src/unix/solarish/compat.rs new file mode 100644 index 0000000..8631d60 --- /dev/null +++ b/libc/src/unix/solarish/compat.rs @@ -0,0 +1,21 @@ +// Common functions that are unfortunately missing on illumos and +// Solaris, but often needed by other crates. + +use unix::solarish::*; + +pub unsafe fn cfmakeraw(termios: *mut ::termios) { +    let mut t = *termios as ::termios; +    t.c_iflag &= !(IMAXBEL|IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON); +    t.c_oflag &= !OPOST; +    t.c_lflag &= !(ECHO|ECHONL|ICANON|ISIG|IEXTEN); +    t.c_cflag &= !(CSIZE|PARENB); +    t.c_cflag |= CS8; +} + +pub unsafe fn cfsetspeed(termios: *mut ::termios, speed: ::speed_t) -> ::c_int { +    // Neither of these functions on illumos or Solaris actually ever +    // return an error +    ::cfsetispeed(termios, speed); +    ::cfsetospeed(termios, speed); +    0 +} diff --git a/libc/src/unix/solaris/mod.rs b/libc/src/unix/solarish/mod.rs index c991e62..1092d15 100644 --- a/libc/src/unix/solaris/mod.rs +++ b/libc/src/unix/solarish/mod.rs @@ -1,5 +1,3 @@ -use dox::{mem, Option}; -  pub type c_char = i8;  pub type c_long = i64;  pub type c_ulong = u64; @@ -36,9 +34,23 @@ pub type nl_item = ::c_int;  pub type id_t = ::c_int;  pub type idtype_t = ::c_uint; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum timezone {} +impl ::Copy for timezone {} +impl ::Clone for timezone { +    fn clone(&self) -> timezone { *self } +}  s! { +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } + +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } +      pub struct sockaddr {          pub sa_family: sa_family_t,          pub sa_data: [::c_char; 14], @@ -60,11 +72,6 @@ s! {          pub __sin6_src_id: u32      } -    pub struct sockaddr_un { -        pub sun_family: sa_family_t, -        pub sun_path: [c_char; 108] -    } -      pub struct passwd {          pub pw_name: *mut ::c_char,          pub pw_passwd: *mut ::c_char, @@ -99,15 +106,7 @@ s! {          pub tm_isdst: ::c_int      } -    pub struct utsname { -        pub sysname: [::c_char; 257], -        pub nodename: [::c_char; 257], -        pub release: [::c_char; 257], -        pub version: [::c_char; 257], -        pub machine: [::c_char; 257], -    } - -    pub struct msghdr { +     pub struct msghdr {          pub msg_name: *mut ::c_void,          pub msg_namelen: ::socklen_t,          pub msg_iov: *mut ::iovec, @@ -123,13 +122,6 @@ s! {          pub cmsg_type: ::c_int,      } -    pub struct fd_set { -        #[cfg(target_pointer_width = "64")] -        fds_bits: [i64; FD_SETSIZE / 64], -        #[cfg(target_pointer_width = "32")] -        fds_bits: [i32; FD_SETSIZE / 32], -    } -      pub struct pthread_attr_t {          __pthread_attrp: *mut ::c_void      } @@ -195,13 +187,6 @@ s! {          __unused10: *mut ::c_void,      } -    pub struct sockaddr_storage { -        pub ss_family: ::sa_family_t, -        __ss_pad1: [u8; 6], -        __ss_align: i64, -        __ss_pad2: [u8; 240], -    } -      pub struct addrinfo {          pub ai_flags: ::c_int,          pub ai_family: ::c_int, @@ -219,21 +204,21 @@ s! {          bits: [u32; 4],      } -    pub struct siginfo_t { -        pub si_signo: ::c_int, -        pub si_code: ::c_int, -        pub si_errno: ::c_int, -        pub si_pad: ::c_int, -        pub si_addr: *mut ::c_void, -        __pad: [u8; 232], -    } -      pub struct sigaction {          pub sa_flags: ::c_int,          pub sa_sigaction: ::sighandler_t,          pub sa_mask: sigset_t,      } +    pub struct sigevent { +        pub sigev_notify: ::c_int, +        pub sigev_signo: ::c_int, +        pub sigev_value: ::sigval, +        pub ss_sp: *mut ::c_void, +        pub sigev_notify_attributes: *const ::pthread_attr_t, +        __sigev_pad2: ::c_int, +    } +      pub struct stack_t {          pub ss_sp: *mut ::c_void,          pub ss_size: ::size_t, @@ -353,12 +338,296 @@ s! {          pub portev_object: ::uintptr_t,          pub portev_user: *mut ::c_void,      } +} +s_no_extra_traits! {      #[cfg_attr(any(target_arch = "x86", target_arch = "x86_64"), repr(packed))]      pub struct epoll_event {          pub events: ::uint32_t,          pub u64: ::uint64_t,      } + +    pub struct sockaddr_un { +        pub sun_family: sa_family_t, +        pub sun_path: [c_char; 108] +    } + +    pub struct utsname { +        pub sysname: [::c_char; 257], +        pub nodename: [::c_char; 257], +        pub release: [::c_char; 257], +        pub version: [::c_char; 257], +        pub machine: [::c_char; 257], +    } + +    pub struct fd_set { +        #[cfg(target_pointer_width = "64")] +        fds_bits: [i64; FD_SETSIZE / 64], +        #[cfg(target_pointer_width = "32")] +        fds_bits: [i32; FD_SETSIZE / 32], +    } + +    pub struct sockaddr_storage { +        pub ss_family: ::sa_family_t, +        __ss_pad1: [u8; 6], +        __ss_align: i64, +        __ss_pad2: [u8; 240], +    } + +    pub struct siginfo_t { +        pub si_signo: ::c_int, +        pub si_code: ::c_int, +        pub si_errno: ::c_int, +        pub si_pad: ::c_int, +        pub si_addr: *mut ::c_void, +        __pad: [u8; 232], +    } + +    pub struct sockaddr_dl { +        pub sdl_family: ::c_ushort, +        pub sdl_index: ::c_ushort, +        pub sdl_type: ::c_uchar, +        pub sdl_nlen: ::c_uchar, +        pub sdl_alen: ::c_uchar, +        pub sdl_slen: ::c_uchar, +        pub sdl_data: [::c_char; 244], +    } +} + +cfg_if! { +    if #[cfg(feature = "extra_traits")] { +        impl PartialEq for epoll_event { +            fn eq(&self, other: &epoll_event) -> bool { +                self.events == other.events +                    && self.u64 == other.u64 +            } +        } +        impl Eq for epoll_event {} +        impl ::fmt::Debug for epoll_event { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                let events = self.events; +                let u64 = self.u64; +                f.debug_struct("epoll_event") +                    .field("events", &events) +                    .field("u64", &u64) +                    .finish() +            } +        } +        impl ::hash::Hash for epoll_event { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                let events = self.events; +                let u64 = self.u64; +                events.hash(state); +                u64.hash(state); +            } +        } + +        impl PartialEq for sockaddr_un { +            fn eq(&self, other: &sockaddr_un) -> bool { +                self.sun_family == other.sun_family +                    && self +                    .sun_path +                    .iter() +                    .zip(other.sun_path.iter()) +                    .all(|(a, b)| a == b) +            } +        } +        impl Eq for sockaddr_un {} +        impl ::fmt::Debug for sockaddr_un { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_un") +                    .field("sun_family", &self.sun_family) +                    // FIXME: .field("sun_path", &self.sun_path) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_un { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sun_family.hash(state); +                self.sun_path.hash(state); +            } +        } + +        impl PartialEq for utsname { +            fn eq(&self, other: &utsname) -> bool { +                self.sysname +                    .iter() +                    .zip(other.sysname.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .nodename +                    .iter() +                    .zip(other.nodename.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .release +                    .iter() +                    .zip(other.release.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .version +                    .iter() +                    .zip(other.version.iter()) +                    .all(|(a, b)| a == b) +                    && self +                    .machine +                    .iter() +                    .zip(other.machine.iter()) +                    .all(|(a, b)| a == b) +            } +        } +        impl Eq for utsname {} +        impl ::fmt::Debug for utsname { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("utsname") +                    // FIXME: .field("sysname", &self.sysname) +                    // FIXME: .field("nodename", &self.nodename) +                    // FIXME: .field("release", &self.release) +                    // FIXME: .field("version", &self.version) +                    // FIXME: .field("machine", &self.machine) +                    .finish() +            } +        } +        impl ::hash::Hash for utsname { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sysname.hash(state); +                self.nodename.hash(state); +                self.release.hash(state); +                self.version.hash(state); +                self.machine.hash(state); +            } +        } + +        impl PartialEq for fd_set { +            fn eq(&self, other: &fd_set) -> bool { +                self.fds_bits +                    .iter() +                    .zip(other.fds_bits.iter()) +                    .all(|(a, b)| a == b) +            } +        } +        impl Eq for fd_set {} +        impl ::fmt::Debug for fd_set { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("fd_set") +                    // FIXME: .field("fds_bits", &self.fds_bits) +                    .finish() +            } +        } +        impl ::hash::Hash for fd_set { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.fds_bits.hash(state); +            } +        } + +        impl PartialEq for sockaddr_storage { +            fn eq(&self, other: &sockaddr_storage) -> bool { +                self.ss_family == other.ss_family +                    && self.__ss_pad1 == other.__ss_pad1 +                    && self.__ss_align == other.__ss_align +                    && self +                    .__ss_pad2 +                    .iter() +                    .zip(other.__ss_pad2.iter()) +                    .all(|(a, b)| a == b) +            } +        } +        impl Eq for sockaddr_storage {} +        impl ::fmt::Debug for sockaddr_storage { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_storage") +                    .field("ss_family", &self.ss_family) +                    .field("__ss_pad1", &self.__ss_pad1) +                    .field("__ss_align", &self.__ss_align) +                    // FIXME: .field("__ss_pad2", &self.__ss_pad2) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_storage { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.ss_family.hash(state); +                self.__ss_pad1.hash(state); +                self.__ss_align.hash(state); +                self.__ss_pad2.hash(state); +            } +        } + +        impl PartialEq for siginfo_t { +            fn eq(&self, other: &siginfo_t) -> bool { +                self.si_signo == other.si_signo +                    && self.si_code == other.si_code +                    && self.si_errno == other.si_errno +                    && self.si_addr == other.si_addr +                    && self +                    .__pad +                    .iter() +                    .zip(other.__pad.iter()) +                    .all(|(a, b)| a == b) +            } +        } +        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_code", &self.si_code) +                    .field("si_errno", &self.si_errno) +                    .field("si_addr", &self.si_addr) +                    // FIXME: .field("__pad", &self.__pad) +                    .finish() +            } +        } +        impl ::hash::Hash for siginfo_t { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.si_signo.hash(state); +                self.si_code.hash(state); +                self.si_errno.hash(state); +                self.si_addr.hash(state); +                self.__pad.hash(state); +            } +        } + +        impl PartialEq for sockaddr_dl { +            fn eq(&self, other: &sockaddr_dl) -> bool { +                self.sdl_family == other.sdl_family +                    && self.sdl_index == other.sdl_index +                    && self.sdl_type == other.sdl_type +                    && self.sdl_nlen == other.sdl_nlen +                    && self.sdl_alen == other.sdl_alen +                    && self.sdl_slen == other.sdl_slen +                    && self +                    .sdl_data +                    .iter() +                    .zip(other.sdl_data.iter()) +                    .all(|(a,b)| a == b) +            } +        } +        impl Eq for sockaddr_dl {} +        impl ::fmt::Debug for sockaddr_dl { +            fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { +                f.debug_struct("sockaddr_dl") +                    .field("sdl_family", &self.sdl_family) +                    .field("sdl_index", &self.sdl_index) +                    .field("sdl_type", &self.sdl_type) +                    .field("sdl_nlen", &self.sdl_nlen) +                    .field("sdl_alen", &self.sdl_alen) +                    .field("sdl_slen", &self.sdl_slen) +                    // FIXME: .field("sdl_data", &self.sdl_data) +                    .finish() +            } +        } +        impl ::hash::Hash for sockaddr_dl { +            fn hash<H: ::hash::Hasher>(&self, state: &mut H) { +                self.sdl_family.hash(state); +                self.sdl_index.hash(state); +                self.sdl_type.hash(state); +                self.sdl_nlen.hash(state); +                self.sdl_alen.hash(state); +                self.sdl_slen.hash(state); +                self.sdl_data.hash(state); +            } +        } +    }  }  pub const LC_CTYPE: ::c_int = 0; @@ -475,6 +744,10 @@ pub const SIG_BLOCK: ::c_int = 1;  pub const SIG_UNBLOCK: ::c_int = 2;  pub const SIG_SETMASK: ::c_int = 3; +pub const SIGEV_NONE: ::c_int = 1; +pub const SIGEV_SIGNAL: ::c_int =2; +pub const SIGEV_THREAD: ::c_int = 3; +  pub const IPV6_UNICAST_HOPS: ::c_int = 0x5;  pub const IPV6_MULTICAST_IF: ::c_int = 0x6;  pub const IPV6_MULTICAST_HOPS: ::c_int = 0x7; @@ -513,13 +786,16 @@ pub const TMP_MAX: ::c_uint = 17576;  pub const O_RDONLY: ::c_int = 0;  pub const O_WRONLY: ::c_int = 1;  pub const O_RDWR: ::c_int = 2; -pub const O_SEARCH: ::c_int = 0x200000; -pub const O_EXEC: ::c_int = 0x400000; +pub const O_NDELAY: ::c_int = 0x04;  pub const O_APPEND: ::c_int = 8; +pub const O_DSYNC: ::c_int = 0x40;  pub const O_CREAT: ::c_int = 256;  pub const O_EXCL: ::c_int = 1024;  pub const O_NOCTTY: ::c_int = 2048;  pub const O_TRUNC: ::c_int = 512; +pub const O_NOFOLLOW: ::c_int = 0x200000; +pub const O_SEARCH: ::c_int = 0x200000; +pub const O_EXEC: ::c_int = 0x400000;  pub const O_CLOEXEC: ::c_int = 0x800000;  pub const O_ACCMODE: ::c_int = 0x600003;  pub const S_IFIFO: mode_t = 4096; @@ -602,17 +878,29 @@ pub const WNOWAIT: ::c_int = 0x80;  pub const AT_FDCWD: ::c_int = 0xffd19553;  pub const AT_SYMLINK_NOFOLLOW: ::c_int = 0x1000; -// Solaris defines a great many more of these; we only expose the -// standardized ones.  pub const P_PID: idtype_t = 0; +pub const P_PPID: idtype_t = 1;  pub const P_PGID: idtype_t = 2; +pub const P_SID: idtype_t = 3; +pub const P_CID: idtype_t = 4; +pub const P_UID: idtype_t = 5; +pub const P_GID: idtype_t = 6;  pub const P_ALL: idtype_t = 7; +pub const P_LWPID: idtype_t = 8; +pub const P_TASKID: idtype_t = 9; +pub const P_PROJID: idtype_t = 10; +pub const P_POOLID: idtype_t = 11; +pub const P_ZONEID: idtype_t = 12; +pub const P_CTID: idtype_t = 13; +pub const P_CPUID: idtype_t = 14; +pub const P_PSETID: idtype_t = 15;  pub const PROT_NONE: ::c_int = 0;  pub const PROT_READ: ::c_int = 1;  pub const PROT_WRITE: ::c_int = 2;  pub const PROT_EXEC: ::c_int = 4; +pub const MAP_FILE: ::c_int = 0;  pub const MAP_SHARED: ::c_int = 0x0001;  pub const MAP_PRIVATE: ::c_int = 0x0002;  pub const MAP_FIXED: ::c_int = 0x0010; @@ -754,6 +1042,7 @@ pub const EHOSTUNREACH: ::c_int = 148;  pub const EWOULDBLOCK: ::c_int = EAGAIN;  pub const EALREADY: ::c_int = 149;  pub const EINPROGRESS: ::c_int = 150; +pub const ESTALE: ::c_int = 151;  pub const EAI_AGAIN: ::c_int = 2;  pub const EAI_BADFLAGS: ::c_int = 3; @@ -793,6 +1082,11 @@ pub const POLLOUT: ::c_short = 0x4;  pub const POLLERR: ::c_short = 0x8;  pub const POLLHUP: ::c_short = 0x10;  pub const POLLNVAL: ::c_short = 0x20; +pub const POLLNORM: ::c_short = 0x0040; +pub const POLLRDNORM: ::c_short = 0x0040; +pub const POLLWRNORM: ::c_short = 0x4; /* POLLOUT */ +pub const POLLRDBAND: ::c_short = 0x0080; +pub const POLLWRBAND: ::c_short = 0x0100;  pub const POSIX_MADV_NORMAL: ::c_int = 0;  pub const POSIX_MADV_RANDOM: ::c_int = 1; @@ -845,9 +1139,43 @@ pub const MADV_WILLNEED: ::c_int = 3;  pub const MADV_DONTNEED: ::c_int = 4;  pub const MADV_FREE: ::c_int = 5; +pub const AF_UNSPEC: ::c_int = 0; +pub const AF_UNIX: ::c_int = 1; +pub const AF_LOCAL: ::c_int = 0; +pub const AF_FILE: ::c_int = 0;  pub const AF_INET: ::c_int = 2; +pub const AF_IMPLINK: ::c_int = 3; +pub const AF_PUP: ::c_int = 4; +pub const AF_CHAOS: ::c_int = 5; +pub const AF_NS: ::c_int = 6; +pub const AF_NBS: ::c_int = 7; +pub const AF_ECMA: ::c_int = 8; +pub const AF_DATAKIT: ::c_int = 9; +pub const AF_CCITT: ::c_int = 10; +pub const AF_SNA: ::c_int = 11; +pub const AF_DECnet: ::c_int = 12; +pub const AF_DLI: ::c_int = 13; +pub const AF_LAT: ::c_int = 14; +pub const AF_HYLINK: ::c_int = 15; +pub const AF_APPLETALK: ::c_int = 16; +pub const AF_NIT: ::c_int = 17; +pub const AF_802: ::c_int = 18; +pub const AF_OSI: ::c_int = 19; +pub const AF_X25: ::c_int = 20; +pub const AF_OSINET: ::c_int = 21; +pub const AF_GOSIP: ::c_int = 22; +pub const AF_IPX: ::c_int = 23; +pub const AF_ROUTE: ::c_int = 24; +pub const AF_LINK: ::c_int = 25;  pub const AF_INET6: ::c_int = 26; -pub const AF_UNIX: ::c_int = 1; +pub const AF_KEY: ::c_int = 27; +pub const AF_NCA: ::c_int = 28; +pub const AF_POLICY: ::c_int = 29; +pub const AF_INET_OFFLOAD: ::c_int = 30; +pub const AF_TRILL: ::c_int = 31; +pub const AF_PACKET: ::c_int = 32; +pub const AF_LX_NETLINK: ::c_int = 33; +pub const AF_MAX: ::c_int = 33;  pub const SOCK_DGRAM: ::c_int = 1;  pub const SOCK_STREAM: ::c_int = 2;  pub const SOCK_RAW: ::c_int = 4; @@ -883,8 +1211,25 @@ pub const SO_SNDTIMEO: ::c_int = 0x1005;  pub const SO_RCVTIMEO: ::c_int = 0x1006;  pub const SO_ERROR: ::c_int = 0x1007;  pub const SO_TYPE: ::c_int = 0x1008; +pub const SO_TIMESTAMP: ::c_int = 0x1013; +pub const SCM_RIGHTS: ::c_int = 0x1010; +pub const SCM_UCRED: ::c_int = 0x1012; +pub const SCM_TIMESTAMP: ::c_int = SO_TIMESTAMP; + +pub const MSG_OOB: ::c_int = 0x1;  pub const MSG_PEEK: ::c_int = 0x2; +pub const MSG_DONTROUTE: ::c_int = 0x4; +pub const MSG_EOR: ::c_int = 0x8; +pub const MSG_CTRUNC: ::c_int = 0x10; +pub const MSG_TRUNC: ::c_int = 0x20; +pub const MSG_WAITALL: ::c_int = 0x40; +pub const MSG_DONTWAIT: ::c_int = 0x80; +pub const MSG_NOTIFICATION: ::c_int = 0x100; +pub const MSG_NOSIGNAL: ::c_int = 0x200; +pub const MSG_DUPCTRL: ::c_int = 0x800; +pub const MSG_XPG4_2: ::c_int = 0x8000; +pub const MSG_MAXIOVLEN: ::c_int = 16;  // https://docs.oracle.com/cd/E23824_01/html/821-1475/if-7p.html  pub const IFF_UP: ::c_int = 0x0000000001; // Address is up @@ -1137,9 +1482,6 @@ pub const NCCS: usize = 19;  pub const LOG_CRON: ::c_int = 15 << 3; -pub const SYS_epoll_create: ::c_long = 213; -pub const SYS_epoll_create1: ::c_long = 291; -  pub const PTHREAD_MUTEX_INITIALIZER: pthread_mutex_t = pthread_mutex_t {      __pthread_mutex_flag1: 0,      __pthread_mutex_flag2: 0, @@ -1195,8 +1537,80 @@ pub const PORT_SOURCE_FILE: ::c_int = 7;  pub const PORT_SOURCE_POSTWAIT: ::c_int = 8;  pub const PORT_SOURCE_SIGNAL: ::c_int = 9; -pub const TIOCGWINSZ: ::c_int = 0x5468; -pub const TIOCSWINSZ: ::c_int = 0x5467; +const _TIOC: ::c_int = ('T' as i32) << 8; +const tIOC: ::c_int = ('t' as i32) << 8; +pub const TCGETA: ::c_int = (_TIOC|1); +pub const TCSETA: ::c_int = (_TIOC|2); +pub const TCSETAW: ::c_int = (_TIOC|3); +pub const TCSETAF: ::c_int = (_TIOC|4); +pub const TCSBRK: ::c_int = (_TIOC|5); +pub const TCXONC: ::c_int = (_TIOC|6); +pub const TCFLSH: ::c_int = (_TIOC|7); +pub const TCDSET: ::c_int = (_TIOC|32); +pub const TCGETS: ::c_int = (_TIOC|13); +pub const TCSETS: ::c_int = (_TIOC|14); +pub const TCSANOW: ::c_int = (_TIOC|14); +pub const TCSETSW: ::c_int = (_TIOC|15); +pub const TCSADRAIN: ::c_int = (_TIOC|15); +pub const TCSETSF: ::c_int = (_TIOC|16); +pub const TCSAFLUSH: ::c_int = (_TIOC|16); +pub const TCIFLUSH: ::c_int = 0; +pub const TCOFLUSH: ::c_int = 1; +pub const TCIOFLUSH: ::c_int = 2; +pub const TCOOFF: ::c_int = 0; +pub const TCOON: ::c_int = 1; +pub const TCIOFF: ::c_int = 2; +pub const TCION: ::c_int = 3; +pub const TIOC: ::c_int = _TIOC; +pub const TIOCKBON: ::c_int = (_TIOC|8); +pub const TIOCKBOF: ::c_int = (_TIOC|9); +pub const TIOCGWINSZ: ::c_int = (_TIOC|104); +pub const TIOCSWINSZ: ::c_int = (_TIOC|103); +pub const TIOCGSOFTCAR: ::c_int = (_TIOC|105); +pub const TIOCSSOFTCAR: ::c_int = (_TIOC|106); +pub const TIOCSETLD: ::c_int = (_TIOC|123); +pub const TIOCGETLD: ::c_int = (_TIOC|124); +pub const TIOCGPPS: ::c_int = (_TIOC|125); +pub const TIOCSPPS: ::c_int = (_TIOC|126); +pub const TIOCGPPSEV: ::c_int = (_TIOC|127); +pub const TIOCGETD: ::c_int = (tIOC|0); +pub const TIOCSETD: ::c_int = (tIOC|1); +pub const TIOCHPCL: ::c_int = (tIOC|2); +pub const TIOCGETP: ::c_int = (tIOC|8); +pub const TIOCSETP: ::c_int = (tIOC|9); +pub const TIOCSETN: ::c_int = (tIOC|10); +pub const TIOCEXCL: ::c_int = (tIOC|13); +pub const TIOCNXCL: ::c_int = (tIOC|14); +pub const TIOCFLUSH: ::c_int = (tIOC|16); +pub const TIOCSETC: ::c_int = (tIOC|17); +pub const TIOCGETC: ::c_int = (tIOC|18); +pub const TIOCLBIS: ::c_int = (tIOC|127); +pub const TIOCLBIC: ::c_int = (tIOC|126); +pub const TIOCLSET: ::c_int = (tIOC|125); +pub const TIOCLGET: ::c_int = (tIOC|124); +pub const TIOCSBRK: ::c_int = (tIOC|123); +pub const TIOCCBRK: ::c_int = (tIOC|122); +pub const TIOCSDTR: ::c_int = (tIOC|121); +pub const TIOCCDTR: ::c_int = (tIOC|120); +pub const TIOCSLTC: ::c_int = (tIOC|117); +pub const TIOCGLTC: ::c_int = (tIOC|116); +pub const TIOCOUTQ: ::c_int = (tIOC|115); +pub const TIOCNOTTY: ::c_int = (tIOC|113); +pub const TIOCSCTTY: ::c_int = (tIOC|132); +pub const TIOCSTOP: ::c_int = (tIOC|111); +pub const TIOCSTART: ::c_int = (tIOC|110); +pub const TIOCSILOOP: ::c_int = (tIOC|109); +pub const TIOCCILOOP: ::c_int = (tIOC|108); +pub const TIOCGPGRP: ::c_int = (tIOC|20); +pub const TIOCSPGRP: ::c_int = (tIOC|21); +pub const TIOCGSID: ::c_int = (tIOC|22); +pub const TIOCSTI: ::c_int = (tIOC|23); +pub const TIOCMSET: ::c_int = (tIOC|26); +pub const TIOCMBIS: ::c_int = (tIOC|27); +pub const TIOCMBIC: ::c_int = (tIOC|28); +pub const TIOCMGET: ::c_int = (tIOC|29); +pub const TIOCREMOTE: ::c_int = (tIOC|30); +pub const TIOCSIGNAL: ::c_int = (tIOC|31);  pub const EPOLLIN: ::c_int = 0x1;  pub const EPOLLPRI: ::c_int = 0x2; @@ -1217,22 +1631,116 @@ pub const EPOLL_CTL_ADD: ::c_int = 1;  pub const EPOLL_CTL_MOD: ::c_int = 3;  pub const EPOLL_CTL_DEL: ::c_int = 2; +/* termios */ +pub const B0: speed_t = 0; +pub const B50: speed_t = 1; +pub const B75: speed_t = 2; +pub const B110: speed_t = 3; +pub const B134: speed_t = 4; +pub const B150: speed_t = 5; +pub const B200: speed_t = 6; +pub const B300: speed_t = 7; +pub const B600: speed_t = 8; +pub const B1200: speed_t = 9; +pub const B1800: speed_t = 10; +pub const B2400: speed_t = 11; +pub const B4800: speed_t = 12; +pub const B9600: speed_t = 13; +pub const B19200: speed_t = 14; +pub const B38400: speed_t = 15; +pub const B57600: speed_t = 16; +pub const B76800: speed_t = 17; +pub const B115200: speed_t = 18; +pub const B153600: speed_t = 19; +pub const B230400: speed_t = 20; +pub const B307200: speed_t = 21; +pub const B460800: speed_t = 22; +pub const B921600: speed_t = 23; +pub const CSTART: ::tcflag_t = 021; +pub const CSTOP: ::tcflag_t = 023; +pub const CSWTCH: ::tcflag_t = 032; +pub const CSIZE: ::tcflag_t = 0o000060; +pub const CS5: ::tcflag_t = 0; +pub const CS6: ::tcflag_t = 0o000020; +pub const CS7: ::tcflag_t = 0o000040; +pub const CS8: ::tcflag_t = 0o000060; +pub const CSTOPB: ::tcflag_t = 0o000100; +pub const ECHO: ::tcflag_t = 0o000010; +pub const ECHOE: ::tcflag_t = 0o000020; +pub const ECHOK: ::tcflag_t = 0o000040; +pub const ECHONL: ::tcflag_t = 0o000100; +pub const ECHOCTL: ::tcflag_t = 0o001000; +pub const ECHOPRT: ::tcflag_t = 0o002000; +pub const ECHOKE: ::tcflag_t = 0o004000; +pub const EXTPROC: ::tcflag_t = 0o200000; +pub const IGNBRK: ::tcflag_t = 0o000001; +pub const BRKINT: ::tcflag_t = 0o000002; +pub const IGNPAR: ::tcflag_t = 0o000004; +pub const PARMRK: ::tcflag_t = 0o000010; +pub const INPCK: ::tcflag_t = 0o000020; +pub const ISTRIP: ::tcflag_t = 0o000040; +pub const INLCR: ::tcflag_t = 0o000100; +pub const IGNCR: ::tcflag_t = 0o000200; +pub const ICRNL: ::tcflag_t = 0o000400; +pub const IXON: ::tcflag_t = 0o002000; +pub const IXOFF: ::tcflag_t = 0o010000; +pub const IXANY: ::tcflag_t = 0o004000; +pub const IMAXBEL: ::tcflag_t = 0o020000; +pub const OPOST: ::tcflag_t = 0o000001; +pub const ONLCR: ::tcflag_t = 0o000004; +pub const OCRNL: ::tcflag_t = 0o000010; +pub const ONOCR: ::tcflag_t = 0o000020; +pub const ONLRET: ::tcflag_t = 0o000040; +pub const CREAD: ::tcflag_t = 0o000200; +pub const PARENB: ::tcflag_t = 0o000400; +pub const PARODD: ::tcflag_t = 0o001000; +pub const HUPCL: ::tcflag_t = 0o002000; +pub const CLOCAL: ::tcflag_t = 0o004000; +pub const CRTSCTS: ::tcflag_t = 0o20000000000; +pub const ISIG: ::tcflag_t = 0o000001; +pub const ICANON: ::tcflag_t = 0o000002; +pub const IEXTEN: ::tcflag_t = 0o100000; +pub const TOSTOP: ::tcflag_t = 0o000400; +pub const FLUSHO: ::tcflag_t = 0o020000; +pub const PENDIN: ::tcflag_t = 0o040000; +pub const NOFLSH: ::tcflag_t = 0o000200; +pub const VINTR: usize = 0; +pub const VQUIT: usize = 1; +pub const VERASE: usize = 2; +pub const VKILL: usize = 3; +pub const VEOF: usize = 4; +pub const VEOL: usize = 5; +pub const VEOL2: usize = 6; +pub const VMIN: usize = 4; +pub const VTIME: usize = 5; +pub const VSWTCH: usize = 7; +pub const VSTART: usize = 8; +pub const VSTOP: usize = 9; +pub const VSUSP: usize = 10; +pub const VDSUSP: usize = 11; +pub const VREPRINT: usize = 12; +pub const VDISCARD: usize = 13; +pub const VWERASE: usize = 14; +pub const VLNEXT: usize = 15; +pub const VSTATUS: usize = 16; +pub const VERASE2: usize = 17; +  f! {      pub fn FD_CLR(fd: ::c_int, set: *mut fd_set) -> () { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          (*set).fds_bits[fd / bits] &= !(1 << (fd % bits));          return      }      pub fn FD_ISSET(fd: ::c_int, set: *mut fd_set) -> bool { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          return ((*set).fds_bits[fd / bits] & (1 << (fd % bits))) != 0      }      pub fn FD_SET(fd: ::c_int, set: *mut fd_set) -> () { -        let bits = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let bits = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          let fd = fd as usize;          (*set).fds_bits[fd / bits] |= 1 << (fd % bits);          return @@ -1255,11 +1763,39 @@ f! {      pub fn WTERMSIG(status: ::c_int) -> ::c_int {          status & 0x7F      } + +    pub fn WIFCONTINUED(status: ::c_int) -> bool { +        (status & 0xffff) == 0xffff +    } + +    pub fn WSTOPSIG(status: ::c_int) -> ::c_int { +        (status & 0xff00) >> 8 +    } + +    pub fn WIFSIGNALED(status: ::c_int) -> bool { +        ((status & 0xff) > 0) && (status & 0xff00 == 0) +    } + +    pub fn WIFSTOPPED(status: ::c_int) -> bool { +        ((status & 0xff) == 0x7f) && ((status & 0xff00) != 0) +    } + +    pub fn WCOREDUMP(status: ::c_int) -> bool { +        (status & 0x80) != 0 +    }  }  extern { +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int; +      pub fn abs(i: ::c_int) -> ::c_int; +    pub fn acct(filename: *const ::c_char) -> ::c_int;      pub fn atof(s: *const ::c_char) -> ::c_double; +    pub fn dirfd(dirp: *mut ::DIR) -> ::c_int;      pub fn labs(i: ::c_long) -> ::c_long;      pub fn rand() -> ::c_int;      pub fn srand(seed: ::c_uint); @@ -1270,6 +1806,7 @@ extern {      pub fn stack_getbounds(sp: *mut ::stack_t) -> ::c_int;      pub fn mincore(addr: *const ::c_void, len: ::size_t,                     vec: *mut c_char) -> ::c_int; +    pub fn initgroups(name: *const ::c_char, basegid: ::gid_t) -> ::c_int;      pub fn setgroups(ngroups: ::c_int,                       ptr: *const ::gid_t) -> ::c_int;      pub fn ioctl(fildes: ::c_int, request: ::c_int, ...) -> ::c_int; @@ -1311,7 +1848,7 @@ extern {                     mode: ::mode_t, dev: dev_t) -> ::c_int;      pub fn mkfifoat(dirfd: ::c_int, pathname: *const ::c_char,                      mode: ::mode_t) -> ::c_int; -    pub fn sethostname(name: *mut ::c_char, len: ::c_int) -> ::c_int; +    pub fn sethostname(name: *const ::c_char, len: ::c_int) -> ::c_int;      pub fn if_nameindex() -> *mut if_nameindex;      pub fn if_freenameindex(ptr: *mut if_nameindex);      pub fn pthread_create(native: *mut ::pthread_t, @@ -1333,15 +1870,17 @@ extern {      pub fn glob(pattern: *const ::c_char,                  flags: ::c_int, -                errfunc: Option<extern fn(epath: *const ::c_char, +                errfunc: ::Option<extern fn(epath: *const ::c_char,                                            errno: ::c_int) -> ::c_int>,                  pglob: *mut ::glob_t) -> ::c_int;      pub fn globfree(pglob: *mut ::glob_t);      pub fn posix_madvise(addr: *mut ::c_void, len: ::size_t, advice: ::c_int) -                         -> ::c_int; +                    -> ::c_int; +    pub fn shm_open(name: *const ::c_char, oflag: ::c_int, mode: ::mode_t) +                    -> ::c_int;      pub fn shm_unlink(name: *const ::c_char) -> ::c_int;      pub fn seekdir(dirp: *mut ::DIR, loc: ::c_long); @@ -1364,6 +1903,7 @@ extern {                       times: *const ::timespec, flag: ::c_int) -> ::c_int;      pub fn nl_langinfo(item: ::nl_item) -> *mut ::c_char; +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_bind")]      pub fn bind(socket: ::c_int, address: *const ::sockaddr,                  address_len: ::socklen_t) -> ::c_int; @@ -1374,9 +1914,11 @@ extern {                   iov: *const ::iovec,                   iovcnt: ::c_int) -> ::ssize_t; +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_sendmsg")]      pub fn sendmsg(fd: ::c_int,                     msg: *const ::msghdr,                     flags: ::c_int) -> ::ssize_t; +    #[cfg_attr(target_os = "illumos", link_name = "__xnet_recvmsg")]      pub fn recvmsg(fd: ::c_int, msg: *mut ::msghdr, flags: ::c_int)                     -> ::ssize_t; @@ -1393,8 +1935,9 @@ extern {      pub fn fexecve(fd: ::c_int, argv: *const *const ::c_char,                     envp: *const *const ::c_char)                     -> ::c_int; -    #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrgid_r")] -    pub fn getgrgid_r(uid: ::uid_t, +    #[cfg_attr(any(target_os = "solaris", target_os = "illumos"), +               link_name = "__posix_getgrgid_r")] +    pub fn getgrgid_r(gid: ::gid_t,                        grp: *mut ::group,                        buf: *mut ::c_char,                        buflen: ::size_t, @@ -1404,11 +1947,16 @@ extern {      pub fn sem_close(sem: *mut sem_t) -> ::c_int;      pub fn getdtablesize() -> ::c_int; +    // The epoll functions are actually only present on illumos.  However, +    // there are things using epoll on illumos (built using the +    // x86_64-sun-solaris target) which would break until the illumos target is +    // present in rustc.      pub fn epoll_pwait(epfd: ::c_int,                         events: *mut ::epoll_event,                         maxevents: ::c_int,                         timeout: ::c_int,                         sigmask: *const ::sigset_t) -> ::c_int; +      pub fn epoll_create(size: ::c_int) -> ::c_int;      pub fn epoll_create1(flags: ::c_int) -> ::c_int;      pub fn epoll_wait(epfd: ::c_int, @@ -1420,7 +1968,8 @@ extern {                       fd: ::c_int,                       event: *mut ::epoll_event) -> ::c_int; -    #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrnam_r")] +    #[cfg_attr(any(target_os = "solaris", target_os = "illumos"), +               link_name = "__posix_getgrnam_r")]      pub fn getgrnam_r(name: *const ::c_char,                        grp: *mut ::group,                        buf: *mut ::c_char, @@ -1433,38 +1982,50 @@ extern {      pub fn pthread_kill(thread: ::pthread_t, sig: ::c_int) -> ::c_int;      pub fn sem_unlink(name: *const ::c_char) -> ::c_int;      pub fn daemon(nochdir: ::c_int, noclose: ::c_int) -> ::c_int; -    #[cfg_attr(target_os = "solaris", link_name = "__posix_getpwnam_r")] +    #[cfg_attr(any(target_os = "solaris", target_os = "illumos"), +               link_name = "__posix_getpwnam_r")]      pub fn getpwnam_r(name: *const ::c_char,                        pwd: *mut passwd,                        buf: *mut ::c_char,                        buflen: ::size_t,                        result: *mut *mut passwd) -> ::c_int; -    #[cfg_attr(target_os = "solaris", link_name = "__posix_getpwuid_r")] +    #[cfg_attr(any(target_os = "solaris", target_os = "illumos"), +               link_name = "__posix_getpwuid_r")]      pub fn getpwuid_r(uid: ::uid_t,                        pwd: *mut passwd,                        buf: *mut ::c_char,                        buflen: ::size_t,                        result: *mut *mut passwd) -> ::c_int; -    #[cfg_attr(target_os = "solaris", link_name = "__posix_getpwent_r")] +    #[cfg_attr(any(target_os = "solaris", target_os = "illumos"), +               link_name = "__posix_getpwent_r")]      pub fn getpwent_r(pwd: *mut passwd,                        buf: *mut ::c_char,                        buflen: ::size_t,                        result: *mut *mut passwd) -> ::c_int; -    #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrent_r")] +    #[cfg_attr(any(target_os = "solaris", target_os = "illumos"), +               link_name = "__posix_getgrent_r")]      pub fn getgrent_r(grp: *mut ::group,                        buf: *mut ::c_char,                        buflen: ::size_t,                        result: *mut *mut ::group) -> ::c_int; -    #[cfg_attr(target_os = "solaris", link_name = "__posix_sigwait")] +    #[cfg_attr(any(target_os = "solaris", target_os = "illumos"), +               link_name = "__posix_sigwait")]      pub fn sigwait(set: *const sigset_t,                     sig: *mut ::c_int) -> ::c_int; -    pub fn pthread_atfork(prepare: Option<unsafe extern fn()>, -                          parent: Option<unsafe extern fn()>, -                          child: Option<unsafe extern fn()>) -> ::c_int; +    pub fn pthread_atfork(prepare: ::Option<unsafe extern fn()>, +                          parent: ::Option<unsafe extern fn()>, +                          child: ::Option<unsafe extern fn()>) -> ::c_int;      pub fn getgrgid(gid: ::gid_t) -> *mut ::group; +    pub fn setgrent(); +    pub fn endgrent(); +    pub fn getgrent() -> *mut ::group;      pub fn popen(command: *const c_char,                   mode: *const c_char) -> *mut ::FILE;      pub fn dup3(src: ::c_int, dst: ::c_int, flags: ::c_int) -> ::c_int;      pub fn uname(buf: *mut ::utsname) -> ::c_int; +    pub fn pipe2(fds: *mut ::c_int, flags: ::c_int) -> ::c_int;  } + +mod compat; +pub use self::compat::*; diff --git a/libc/src/unix/uclibc/align.rs b/libc/src/unix/uclibc/align.rs new file mode 100644 index 0000000..3307c9d --- /dev/null +++ b/libc/src/unix/uclibc/align.rs @@ -0,0 +1,66 @@ +macro_rules! expand_align { +    () => { +        s! { +            #[cfg_attr(any(target_pointer_width = "32", +                           target_arch = "x86_64", +                           target_arch = "powerpc64", +                           target_arch = "mips64", +                           target_arch = "s390x", +                           target_arch = "sparc64"), +                       repr(align(4)))] +            #[cfg_attr(not(any(target_pointer_width = "32", +                               target_arch = "x86_64", +                               target_arch = "powerpc64", +                               target_arch = "mips64", +                               target_arch = "s390x", +                               target_arch = "sparc64")), +                       repr(align(8)))] +            pub struct pthread_mutexattr_t { +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            #[repr(align(4))] +            pub struct pthread_condattr_t { +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } + +        s_no_extra_traits! { +            #[repr(align(8))] +            #[allow(missing_debug_implementations)] +            pub struct pthread_cond_t { +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } + +            #[cfg_attr(all(target_pointer_width = "32", +                           any(target_arch = "mips", +                               target_arch = "arm", +                               target_arch = "powerpc")), +                       repr(align(4)))] +            #[cfg_attr(any(target_pointer_width = "64", +                           not(any(target_arch = "mips", +                                   target_arch = "arm", +                                   target_arch = "powerpc"))), +                       repr(align(8)))] +            #[allow(missing_debug_implementations)] +            pub struct pthread_mutex_t { +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            #[cfg_attr(all(target_pointer_width = "32", +                           any(target_arch = "mips", +                               target_arch = "arm", +                               target_arch = "powerpc")), +                       repr(align(4)))] +            #[cfg_attr(any(target_pointer_width = "64", +                           not(any(target_arch = "mips", +                                   target_arch = "arm", +                                   target_arch = "powerpc"))), +                       repr(align(8)))] +            #[allow(missing_debug_implementations)] +            pub struct pthread_rwlock_t { +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } +        } +    } +} diff --git a/libc/src/unix/uclibc/arm/align.rs b/libc/src/unix/uclibc/arm/align.rs new file mode 100644 index 0000000..4a0e074 --- /dev/null +++ b/libc/src/unix/uclibc/arm/align.rs @@ -0,0 +1,13 @@ +s! { +    // FIXME this is actually a union +    #[cfg_attr(target_pointer_width = "32", +               repr(align(4)))] +    #[cfg_attr(target_pointer_width = "64", +               repr(align(8)))] +    pub struct sem_t { +        #[cfg(target_pointer_width = "32")] +        __size: [::c_char; 16], +        #[cfg(target_pointer_width = "64")] +        __size: [::c_char; 32], +    } +} diff --git a/libc/src/unix/uclibc/arm/mod.rs b/libc/src/unix/uclibc/arm/mod.rs new file mode 100644 index 0000000..b250fb5 --- /dev/null +++ b/libc/src/unix/uclibc/arm/mod.rs @@ -0,0 +1,687 @@ +pub type c_char = u8; +pub type wchar_t = ::c_uint; +pub type c_long = i32; +pub type c_ulong = u32; +pub type time_t = ::c_long; + +pub type clock_t = ::c_long; +pub type fsblkcnt_t = ::c_ulong; +pub type fsfilcnt_t = ::c_ulong; +pub type ino_t = ::c_ulong; +pub type off_t = ::c_long; +pub type pthread_t = ::c_ulong; +pub type rlim_t = ::c_ulong; +pub type suseconds_t = ::c_long; + +pub type nlink_t = ::c_uint; +pub type blksize_t = ::c_long; +pub type blkcnt_t = ::c_long; + +s! { +    pub struct cmsghdr { +        pub cmsg_len: ::size_t, +        pub cmsg_level: ::c_int, +        pub cmsg_type: ::c_int, +    } + +    pub struct msghdr { +        pub msg_name: *mut ::c_void, +        pub msg_namelen: ::socklen_t, +        pub msg_iov: *mut ::iovec, +        pub msg_iovlen: ::c_int, +        pub msg_control: *mut ::c_void, +        pub msg_controllen: ::socklen_t, +        pub msg_flags: ::c_int, +    } + +    pub struct pthread_attr_t { +        __size: [::c_long; 9], +    } + +    pub struct stat { +        pub st_dev: ::c_ulonglong, +        pub __pad1: ::c_ushort, +        pub st_ino: ::ino_t, +        pub st_mode: ::mode_t, +        pub st_nlink: ::nlink_t, +        pub st_uid: ::uid_t, +        pub st_gid: ::gid_t, +        pub st_rdev: ::c_ulonglong, +        pub __pad2: ::c_ushort, +        pub st_size: ::off_t, +        pub st_blksize: ::blksize_t, +        pub st_blocks: ::blkcnt_t, +        pub st_atim: ::timespec, +        pub st_mtim: ::timespec, +        pub st_ctim: ::timespec, +        pub __unused4: ::c_ulong, +        pub __unused5: ::c_ulong, +    } + +    pub struct stat64 +    { +        pub st_dev: ::c_ulonglong, +        pub __pad1: ::c_uint, +        pub __st_ino: ::ino_t, +        pub st_mode: ::mode_t, +        pub st_nlink: ::nlink_t, +        pub st_uid: ::uid_t, +        pub st_gid: ::gid_t, +        pub st_rdev: ::c_ulonglong, +        pub __pad2: ::c_uint, +        pub st_size: ::off64_t, +        pub st_blksize: ::blksize_t, +        pub st_blocks: ::blkcnt64_t, +        pub st_atim: ::timespec, +        pub st_mtim: ::timespec, +        pub st_ctim: ::timespec, +        pub st_ino: ::ino64_t, +    } + +    pub struct flock { +        pub l_type: ::c_short, +        pub l_whence: ::c_short, +        pub l_start: ::off_t, +        pub l_len: ::off_t, +        pub l_pid: ::pid_t, +    } + +    pub struct statfs { +        pub f_type: ::c_int, +        pub f_bsize: ::c_int, +        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_fsid: ::fsid_t, +        pub f_namelen: ::c_int, +        pub f_frsize: ::c_int, +        pub f_spare: [::c_int; 5], +    } + +    pub struct sigset_t { +        __val: [::c_ulong; 2], +    } + +    pub struct sigaction { +        pub sa_sigaction: ::sighandler_t, +        // uClibc defines sa_flags as `unsigned long int`, +        // but nix crate expects `int` +        pub sa_flags: ::c_int, +        pub sa_restorer: *mut ::c_void, +        pub sa_mask: sigset_t, +    } + +    pub struct termios { +        pub c_iflag: ::tcflag_t, +        pub c_oflag: ::tcflag_t, +        pub c_cflag: ::tcflag_t, +        pub c_lflag: ::tcflag_t, +        pub c_line: ::cc_t, +        pub c_cc: [::cc_t; ::NCCS], +        pub c_ispeed: ::speed_t, +        pub c_ospeed: ::speed_t, +    } + +    pub struct siginfo_t { +        pub si_signo: ::c_int, +        pub si_errno: ::c_int, +        pub si_code: ::c_int, +        pub _pad: [::c_int; 29], +    } + +    pub struct stack_t { +        pub ss_sp: *mut ::c_void, +        ss_flags: ::c_int, +        ss_size: ::size_t, +    } + +    pub struct ipc_perm { +        pub __key: ::key_t, +        pub uid: ::uid_t, +        pub gid: ::gid_t, +        pub cuid: ::uid_t, +        pub cgid: ::gid_t, +        pub mode: ::c_ushort, +        pub __pad1: ::c_ushort, +        pub __seq: ::c_ushort, +        pub __pad2: ::c_ushort, +        pub __unused1: ::c_ulong, +        pub __unused2: ::c_ulong, +    } + +    pub struct msqid_ds { +        pub msg_perm: ::ipc_perm, +        pub msg_stime: ::time_t, +        pub __unused1: ::c_ulong, +        pub msg_rtime: ::time_t, +        pub __unused2: ::c_ulong, +        pub msg_ctime: ::time_t, +        pub __unused3: ::c_ulong, +        pub __msg_cbytes: ::c_ulong, +        pub msg_qnum: ::msgqnum_t, +        pub msg_qbytes: ::msglen_t, +        pub msg_lspid: ::pid_t, +        pub msg_lrpid: ::pid_t, +        pub __unused4: ::c_ulong, +        pub __unused5: ::c_ulong, +    } + +    pub struct shmid_ds { +        pub shm_perm: ::ipc_perm, +        pub shm_segsz: ::size_t, +        pub shm_atime: ::time_t, +        pub __unused1: ::c_ulong, +        pub shm_dtime: ::time_t, +        pub __unused2: ::c_ulong, +        pub shm_ctime: ::time_t, +        pub __unused3: ::c_ulong, +        pub shm_cpid: ::pid_t, +        pub shm_lpid: ::pid_t, +        pub shm_nattch: ::shmatt_t, +        pub __unused4: ::c_ulong, +        pub __unused5: ::c_ulong, +    } + +    pub struct ucred { +        pub pid: ::pid_t, +        pub uid: ::uid_t, +        pub gid: ::gid_t, +    } + +} + +pub const O_CLOEXEC: ::c_int = 0o2000000; +pub const RLIM_INFINITY: rlim_t = !0; +pub const __SIZEOF_PTHREAD_ATTR_T: usize = 36; +pub const __SIZEOF_PTHREAD_MUTEX_T: usize = 24; +pub const __SIZEOF_PTHREAD_MUTEXATTR_T: usize = 4; +pub const __SIZEOF_PTHREAD_COND_COMPAT_T: usize = 12; +pub const __SIZEOF_PTHREAD_CONDATTR_T: usize = 4; +pub const __SIZEOF_PTHREAD_RWLOCK_T: usize = 32; +pub const __SIZEOF_PTHREAD_RWLOCKATTR_T: usize = 8; +pub const __SIZEOF_PTHREAD_BARRIER_T: usize = 20; +pub const __SIZEOF_PTHREAD_BARRIERATTR_T: usize = 4; +pub const NCCS: usize = 32; + +// I wasn't able to find those constants +// in uclibc build environment for armv7 +pub const AIO_ALLDONE: ::c_int = 2; // from linux/mod.rs +pub const AIO_CANCELED: ::c_int = 0; // from linux/mod.rs +pub const AIO_NOTCANCELED: ::c_int = 1; // from linux/mod.rs +pub const CLONE_NEWCGROUP: ::c_int = 0x02000000; // from linux/mod.rs +pub const EPOLLEXCLUSIVE: ::c_int = 0x10000000; // from linux/mod.rs +pub const EPOLLWAKEUP: ::c_int = 0x20000000; // from linux/other/mod.rs +pub const EXTPROC: ::tcflag_t = 0o200000; // from asm-generic/termbits.h +pub const F_GETPIPE_SZ: ::c_int = 1032; // from notbsd/mod.rs +pub const F_SETPIPE_SZ: ::c_int = 1031; // from notbsd/mod.rs +pub const LIO_NOP: ::c_int = 2; // from linux/mod.rs +pub const LIO_NOWAIT: ::c_int = 1; // from linux/mod.rs +pub const LIO_READ: ::c_int = 0; // from linux/mod.rs +pub const LIO_WAIT: ::c_int = 0; // from linux/mod.rs +pub const LIO_WRITE: ::c_int = 1; // from linux/mod.rs +pub const MAP_HUGETLB: ::c_int = 0x040000; // from linux/other/mod.rs +pub const O_TMPFILE: ::c_int = 0o20000000 | O_DIRECTORY; +pub const RB_KEXEC: ::c_int = 0x45584543u32 as i32; // from linux/mod.rs +pub const RB_SW_SUSPEND: ::c_int = 0xd000fce2u32 as i32; // from linux/mod.rs +pub const SO_BUSY_POLL: ::c_int = 46; // from src/unix/notbsd/mod.rs +pub const SO_PEEK_OFF: ::c_int = 42; // from src/unix/notbsd/mod.rs +pub const SO_REUSEPORT: ::c_int = 15; // from src/unix/notbsd/mod.rs +pub const SOL_NETLINK: ::c_int = 270; // from src/unix/notbsd/mod.rs +pub const _POSIX_VDISABLE: ::cc_t = 0; // from linux/mod.rs +pub const AT_EMPTY_PATH: ::c_int = 0x1000; // from notbsd/mod.rs + +// autogenerated constants with hand tuned types +pub const AT_NO_AUTOMOUNT: ::c_int = 0x800; +pub const B0: ::speed_t = 0; +pub const B1000000: ::speed_t = 0x1008; +pub const B110: ::speed_t = 0x3; +pub const B115200: ::speed_t = 0x1002; +pub const B1152000: ::speed_t = 0x1009; +pub const B1200: ::speed_t = 0x9; +pub const B134: ::speed_t = 0x4; +pub const B150: ::speed_t = 0x5; +pub const B1500000: ::speed_t = 0x100a; +pub const B1800: ::speed_t = 0xa; +pub const B19200: ::speed_t = 0xe; +pub const B200: ::speed_t = 0x6; +pub const B2000000: ::speed_t = 0x100b; +pub const B230400: ::speed_t = 0x1003; +pub const B2400: ::speed_t = 0xb; +pub const B2500000: ::speed_t = 0x100c; +pub const B300: ::speed_t = 0x7; +pub const B3000000: ::speed_t = 0x100d; +pub const B3500000: ::speed_t = 0x100e; +pub const B38400: ::speed_t = 0xf; +pub const B4000000: ::speed_t = 0x100f; +pub const B460800: ::speed_t = 0x1004; +pub const B4800: ::speed_t = 0xc; +pub const B50: ::speed_t = 0x1; +pub const B500000: ::speed_t = 0x1005; +pub const B57600: ::speed_t = 0x1001; +pub const B576000: ::speed_t = 0x1006; +pub const B600: ::speed_t = 0x8; +pub const B75: ::speed_t = 0x2; +pub const B921600: ::speed_t = 0x1007; +pub const B9600: ::speed_t = 0xd; +pub const BS1: ::c_int = 0x2000; +pub const BSDLY: ::c_int = 0x2000; +pub const CBAUD: ::tcflag_t = 0x100f; +pub const CBAUDEX: ::tcflag_t = 0x1000; +pub const CIBAUD: ::tcflag_t = 0x100f0000; +pub const CLOCAL: ::tcflag_t = 0x800; +pub const CMSPAR: ::tcflag_t = 0x40000000; +pub const CPU_SETSIZE: ::c_int = 0x400; +pub const CR1: ::c_int = 0x200; +pub const CR2: ::c_int = 0x400; +pub const CR3: ::c_int = 0x600; +pub const CRDLY: ::c_int = 0x600; +pub const CREAD: ::tcflag_t = 0x80; +pub const CS6: ::tcflag_t = 0x10; +pub const CS7: ::tcflag_t = 0x20; +pub const CS8: ::tcflag_t = 0x30; +pub const CSIZE: ::tcflag_t = 0x30; +pub const CSTOPB: ::tcflag_t = 0x40; +pub const EADDRINUSE: ::c_int = 0x62; +pub const EADDRNOTAVAIL: ::c_int = 0x63; +pub const EADV: ::c_int = 0x44; +pub const EAFNOSUPPORT: ::c_int = 0x61; +pub const EALREADY: ::c_int = 0x72; +pub const EBADE: ::c_int = 0x34; +pub const EBADFD: ::c_int = 0x4d; +pub const EBADMSG: ::c_int = 0x4a; +pub const EBADR: ::c_int = 0x35; +pub const EBADRQC: ::c_int = 0x38; +pub const EBADSLT: ::c_int = 0x39; +pub const EBFONT: ::c_int = 0x3b; +pub const ECANCELED: ::c_int = 0x7d; +pub const ECHOCTL: ::tcflag_t = 0x200; +pub const ECHOE: ::tcflag_t = 0x10; +pub const ECHOK: ::tcflag_t = 0x20; +pub const ECHOKE: ::tcflag_t = 0x800; +pub const ECHONL: ::tcflag_t = 0x40; +pub const ECHOPRT: ::tcflag_t = 0x400; +pub const ECHRNG: ::c_int = 0x2c; +pub const ECOMM: ::c_int = 0x46; +pub const ECONNABORTED: ::c_int = 0x67; +pub const ECONNREFUSED: ::c_int = 0x6f; +pub const ECONNRESET: ::c_int = 0x68; +pub const EDEADLK: ::c_int = 0x23; +pub const EDESTADDRREQ: ::c_int = 0x59; +pub const EDOTDOT: ::c_int = 0x49; +pub const EDQUOT: ::c_int = 0x7a; +pub const EFD_CLOEXEC: ::c_int = 0x80000; +pub const EFD_NONBLOCK: ::c_int = 0x800; +pub const EHOSTDOWN: ::c_int = 0x70; +pub const EHOSTUNREACH: ::c_int = 0x71; +pub const EHWPOISON: ::c_int = 0x85; +pub const EIDRM: ::c_int = 0x2b; +pub const EILSEQ: ::c_int = 0x54; +pub const EINPROGRESS: ::c_int = 0x73; +pub const EISCONN: ::c_int = 0x6a; +pub const EISNAM: ::c_int = 0x78; +pub const EKEYEXPIRED: ::c_int = 0x7f; +pub const EKEYREJECTED: ::c_int = 0x81; +pub const EKEYREVOKED: ::c_int = 0x80; +pub const EL2HLT: ::c_int = 0x33; +pub const EL2NSYNC: ::c_int = 0x2d; +pub const EL3HLT: ::c_int = 0x2e; +pub const EL3RST: ::c_int = 0x2f; +pub const ELIBACC: ::c_int = 0x4f; +pub const ELIBBAD: ::c_int = 0x50; +pub const ELIBEXEC: ::c_int = 0x53; +pub const ELIBMAX: ::c_int = 0x52; +pub const ELIBSCN: ::c_int = 0x51; +pub const ELNRNG: ::c_int = 0x30; +pub const ELOOP: ::c_int = 0x28; +pub const EMEDIUMTYPE: ::c_int = 0x7c; +pub const EMSGSIZE: ::c_int = 0x5a; +pub const EMULTIHOP: ::c_int = 0x48; +pub const ENAMETOOLONG: ::c_int = 0x24; +pub const ENAVAIL: ::c_int = 0x77; +pub const ENETDOWN: ::c_int = 0x64; +pub const ENETRESET: ::c_int = 0x66; +pub const ENETUNREACH: ::c_int = 0x65; +pub const ENOANO: ::c_int = 0x37; +pub const ENOBUFS: ::c_int = 0x69; +pub const ENOCSI: ::c_int = 0x32; +pub const ENODATA: ::c_int = 0x3d; +pub const ENOKEY: ::c_int = 0x7e; +pub const ENOLCK: ::c_int = 0x25; +pub const ENOLINK: ::c_int = 0x43; +pub const ENOMEDIUM: ::c_int = 0x7b; +pub const ENOMSG: ::c_int = 0x2a; +pub const ENONET: ::c_int = 0x40; +pub const ENOPKG: ::c_int = 0x41; +pub const ENOPROTOOPT: ::c_int = 0x5c; +pub const ENOSR: ::c_int = 0x3f; +pub const ENOSTR: ::c_int = 0x3c; +pub const ENOSYS: ::c_int = 0x26; +pub const ENOTCONN: ::c_int = 0x6b; +pub const ENOTEMPTY: ::c_int = 0x27; +pub const ENOTNAM: ::c_int = 0x76; +pub const ENOTRECOVERABLE: ::c_int = 0x83; +pub const ENOTSOCK: ::c_int = 0x58; +pub const ENOTUNIQ: ::c_int = 0x4c; +pub const EOPNOTSUPP: ::c_int = 0x5f; +pub const EOVERFLOW: ::c_int = 0x4b; +pub const EOWNERDEAD: ::c_int = 0x82; +pub const EPFNOSUPPORT: ::c_int = 0x60; +pub const EPOLL_CLOEXEC: ::c_int = 0x80000; +pub const EPROTO: ::c_int = 0x47; +pub const EPROTONOSUPPORT: ::c_int = 0x5d; +pub const EPROTOTYPE: ::c_int = 0x5b; +pub const EREMCHG: ::c_int = 0x4e; +pub const EREMOTE: ::c_int = 0x42; +pub const EREMOTEIO: ::c_int = 0x79; +pub const ERESTART: ::c_int = 0x55; +pub const ERFKILL: ::c_int = 0x84; +pub const ESHUTDOWN: ::c_int = 0x6c; +pub const ESOCKTNOSUPPORT: ::c_int = 0x5e; +pub const ESRMNT: ::c_int = 0x45; +pub const ESTALE: ::c_int = 0x74; +pub const ESTRPIPE: ::c_int = 0x56; +pub const ETIME: ::c_int = 0x3e; +pub const ETIMEDOUT: ::c_int = 0x6e; +pub const ETOOMANYREFS: ::c_int = 0x6d; +pub const EUCLEAN: ::c_int = 0x75; +pub const EUNATCH: ::c_int = 0x31; +pub const EUSERS: ::c_int = 0x57; +pub const EXFULL: ::c_int = 0x36; +pub const FF1: ::c_int = 0x8000; +pub const FFDLY: ::c_int = 0x8000; +pub const FIONBIO: ::c_ulong = 0x5421; +pub const FIOCLEX: ::c_ulong = 0x5451; +pub const FLUSHO: ::tcflag_t = 0x1000; +pub const F_GETLK: ::c_int = 0x5; +pub const F_SETLK: ::c_int = 0x6; +pub const F_SETLKW: ::c_int = 0x7; +pub const HUPCL: ::tcflag_t = 0x400; +pub const ICANON: ::tcflag_t = 0x2; +pub const IEXTEN: ::tcflag_t = 0x8000; +pub const IPV6_MULTICAST_HOPS: ::c_int = 0x12; +pub const IPV6_MULTICAST_IF: ::c_int = 0x11; +pub const IPV6_UNICAST_HOPS: ::c_int = 0x10; +pub const IP_MULTICAST_IF: ::c_int = 0x20; +pub const ISIG: ::tcflag_t = 0x1; +pub const IUTF8: ::tcflag_t = 0x4000; +pub const IXOFF: ::tcflag_t = 0x1000; +pub const IXON: ::tcflag_t = 0x400; +pub const MAP_ANON: ::c_int = 0x20; +pub const MAP_ANONYMOUS: ::c_int = 0x20; +pub const MAP_DENYWRITE: ::c_int = 0x800; +pub const MAP_EXECUTABLE: ::c_int = 0x1000; +pub const MAP_GROWSDOWN: ::c_int = 0x100; +pub const MAP_LOCKED: ::c_int = 0x2000; +pub const MAP_NONBLOCK: ::c_int = 0x10000; +pub const MAP_NORESERVE: ::c_int = 0x4000; +pub const MAP_POPULATE: ::c_int = 0x8000; +pub const MAP_STACK: ::c_int = 0x20000; +pub const MS_ACTIVE: u32 = 0x40000000; +pub const MS_DIRSYNC: u32 = 0x80; +pub const MS_I_VERSION: u32 = 0x800000; +pub const MS_KERNMOUNT: u32 = 0x400000; +pub const MS_MOVE: u32 = 0x2000; +pub const MS_POSIXACL: u32 = 0x10000; +pub const MS_PRIVATE: u32 = 0x40000; +pub const MS_REC: u32 = 0x4000; +pub const MS_RELATIME: u32 = 0x200000; +pub const MS_SHARED: u32 = 0x100000; +pub const MS_SILENT: u32 = 0x8000; +pub const MS_SLAVE: u32 = 0x80000; +pub const MS_STRICTATIME: u32 = 0x1000000; +pub const MS_UNBINDABLE: u32 = 0x20000; +pub const NLDLY: ::tcflag_t = 0x100; +pub const NOFLSH: ::tcflag_t = 0x80; +pub const OCRNL: ::c_int = 0x8; +pub const OFDEL: ::c_int = 0x80; +pub const OFILL: ::c_int = 0x40; +pub const OLCUC: ::tcflag_t = 0x2; +pub const ONLCR: ::tcflag_t = 0x4; +pub const ONLRET: ::tcflag_t = 0x20; +pub const ONOCR: ::tcflag_t = 0x10; +pub const O_ACCMODE: ::c_int = 0x3; +pub const O_APPEND: ::c_int = 0x400; +pub const O_CREAT: ::c_int = 0x40; +pub const O_DIRECT: ::c_int = 0x10000; +pub const O_DIRECTORY: ::c_int = 0x4000; +pub const O_DSYNC: ::c_int = 0x1000; +pub const O_EXCL: ::c_int = 0x80; +pub const O_NDELAY: ::c_int = 0x800; +pub const O_NOCTTY: ::c_int = 0x100; +pub const O_NOFOLLOW: ::c_int = 0x8000; +pub const O_NONBLOCK: ::c_int = 0x800; +pub const O_SYNC: ::c_int = 0o10000; +pub const O_TRUNC: ::c_int = 0x200; +pub const PARENB: ::tcflag_t = 0x100; +pub const PARODD: ::tcflag_t = 0x200; +pub const PENDIN: ::tcflag_t = 0x4000; +pub const POLLRDBAND: ::c_short = 0x80; +pub const POLLRDNORM: ::c_short = 0x40; +pub const POLLWRBAND: ::c_short = 0x200; +pub const POLLWRNORM: ::c_short = 0x100; +pub const QIF_ALL: ::uint32_t = 0x3f; +pub const QIF_BLIMITS: ::uint32_t = 0x1; +pub const QIF_BTIME: ::uint32_t = 0x10; +pub const QIF_ILIMITS: ::uint32_t = 0x4; +pub const QIF_INODES: ::uint32_t = 0x8; +pub const QIF_ITIME: ::uint32_t = 0x20; +pub const QIF_LIMITS: ::uint32_t = 0x5; +pub const QIF_SPACE: ::uint32_t = 0x2; +pub const QIF_TIMES: ::uint32_t = 0x30; +pub const QIF_USAGE: ::uint32_t = 0xa; +pub const SA_NOCLDSTOP: ::c_int = 0x1; +pub const SA_NOCLDWAIT: ::c_int = 0x2; +pub const SA_NODEFER: ::c_int = 0x40000000; +pub const SA_ONSTACK: ::c_int = 0x8000000; +pub const SA_RESETHAND: ::c_int = 0x80000000; +pub const SA_RESTART: ::c_int = 0x10000000; +pub const SA_SIGINFO: ::c_int = 0x4; +pub const SFD_CLOEXEC: ::c_int = 0x80000; +pub const SFD_NONBLOCK: ::c_int = 0x800; +pub const SIGBUS: ::c_int = 0x7; +pub const SIGCHLD: ::c_int = 0x11; +pub const SIGCONT: ::c_int = 0x12; +pub const SIGIO: ::c_int = 0x1d; +pub const SIGPROF: ::c_int = 0x1b; +pub const SIGPWR: ::c_int = 0x1e; +pub const SIGSTKFLT: ::c_int = 0x10; +pub const SIGSTOP: ::c_int = 0x13; +pub const SIGSYS: ::c_int = 0x1f; +pub const SIGTSTP: ::c_int = 0x14; +pub const SIGTTIN: ::c_int = 0x15; +pub const SIGTTOU: ::c_int = 0x16; +pub const SIGURG: ::c_int = 0x17; +pub const SIGUSR1: ::c_int = 0xa; +pub const SIGUSR2: ::c_int = 0xc; +pub const SIGVTALRM: ::c_int = 0x1a; +pub const SIGWINCH: ::c_int = 0x1c; +pub const SIGXCPU: ::c_int = 0x18; +pub const SIGXFSZ: ::c_int = 0x19; +pub const SIG_BLOCK: ::c_int = 0; +pub const SIG_SETMASK: ::c_int = 0x2; +pub const SIG_UNBLOCK: ::c_int = 0x1; +pub const SOCK_DGRAM: ::c_int = 0x2; +pub const SOCK_NONBLOCK: ::c_int = 0o0004000; +pub const SOCK_SEQPACKET: ::c_int = 0x5; +pub const SOCK_STREAM: ::c_int = 0x1; +pub const SOL_SOCKET: ::c_int = 0x1; +pub const SO_ACCEPTCONN: ::c_int = 0x1e; +pub const SO_BINDTODEVICE: ::c_int = 0x19; +pub const SO_BROADCAST: ::c_int = 0x6; +pub const SO_BSDCOMPAT: ::c_int = 0xe; +pub const SO_DOMAIN: ::c_int = 0x27; +pub const SO_DONTROUTE: ::c_int = 0x5; +pub const SO_ERROR: ::c_int = 0x4; +pub const SO_KEEPALIVE: ::c_int = 0x9; +pub const SO_LINGER: ::c_int = 0xd; +pub const SO_MARK: ::c_int = 0x24; +pub const SO_OOBINLINE: ::c_int = 0xa; +pub const SO_PASSCRED: ::c_int = 0x10; +pub const SO_PEERCRED: ::c_int = 0x11; +pub const SO_PRIORITY: ::c_int = 0xc; +pub const SO_PROTOCOL: ::c_int = 0x26; +pub const SO_RCVBUF: ::c_int = 0x8; +pub const SO_RCVLOWAT: ::c_int = 0x12; +pub const SO_RCVTIMEO: ::c_int = 0x14; +pub const SO_REUSEADDR: ::c_int = 0x2; +pub const SO_RXQ_OVFL: ::c_int = 0x28; +pub const SO_SNDBUF: ::c_int = 0x7; +pub const SO_SNDBUFFORCE: ::c_int = 0x20; +pub const SO_SNDLOWAT: ::c_int = 0x13; +pub const SO_SNDTIMEO: ::c_int = 0x15; +pub const SO_TIMESTAMP: ::c_int = 0x1d; +pub const SO_TYPE: ::c_int = 0x3; +pub const SYS_gettid: ::c_int = 0xe0; +pub const TAB1: ::c_int = 0x800; +pub const TAB2: ::c_int = 0x1000; +pub const TAB3: ::c_int = 0x1800; +pub const TABDLY: ::c_int = 0x1800; +pub const TCSADRAIN: ::c_int = 0x1; +pub const TCSAFLUSH: ::c_int = 0x2; +pub const TCSANOW: ::c_int = 0; +pub const TOSTOP: ::tcflag_t = 0x100; +pub const VDISCARD: usize = 0xd; +pub const VEOF: usize = 0x4; +pub const VEOL: usize = 0xb; +pub const VEOL2: usize = 0x10; +pub const VMIN: usize = 0x6; +pub const VREPRINT: usize = 0xc; +pub const VSTART: usize = 0x8; +pub const VSTOP: usize = 0x9; +pub const VSUSP: usize = 0xa; +pub const VSWTC: usize = 0x7; +pub const VT1: ::c_int = 0x4000; +pub const VTDLY: ::c_int = 0x4000; +pub const VTIME: usize = 0x5; +pub const VWERASE: usize = 0xe; +pub const XTABS: ::tcflag_t = 0x1800; +pub const _PC_2_SYMLINKS: ::c_int = 0x14; +pub const _PC_ALLOC_SIZE_MIN: ::c_int = 0x12; +pub const _PC_ASYNC_IO: ::c_int = 0xa; +pub const _PC_FILESIZEBITS: ::c_int = 0xd; +pub const _PC_PRIO_IO: ::c_int = 0xb; +pub const _PC_REC_INCR_XFER_SIZE: ::c_int = 0xe; +pub const _PC_REC_MAX_XFER_SIZE: ::c_int = 0xf; +pub const _PC_REC_MIN_XFER_SIZE: ::c_int = 0x10; +pub const _PC_REC_XFER_ALIGN: ::c_int = 0x11; +pub const _PC_SYMLINK_MAX: ::c_int = 0x13; +pub const _PC_SYNC_IO: ::c_int = 0x9; +pub const _SC_2_PBS: ::c_int = 0xa8; +pub const _SC_2_PBS_ACCOUNTING: ::c_int = 0xa9; +pub const _SC_2_PBS_CHECKPOINT: ::c_int = 0xaf; +pub const _SC_2_PBS_LOCATE: ::c_int = 0xaa; +pub const _SC_2_PBS_MESSAGE: ::c_int = 0xab; +pub const _SC_2_PBS_TRACK: ::c_int = 0xac; +pub const _SC_ADVISORY_INFO: ::c_int = 0x84; +pub const _SC_BARRIERS: ::c_int = 0x85; +pub const _SC_CLOCK_SELECTION: ::c_int = 0x89; +pub const _SC_CPUTIME: ::c_int = 0x8a; +pub const _SC_IPV6: ::c_int = 0xeb; +pub const _SC_MONOTONIC_CLOCK: ::c_int = 0x95; +pub const _SC_RAW_SOCKETS: ::c_int = 0xec; +pub const _SC_READER_WRITER_LOCKS: ::c_int = 0x99; +pub const _SC_REGEXP: ::c_int = 0x9b; +pub const _SC_SHELL: ::c_int = 0x9d; +pub const _SC_SPAWN: ::c_int = 0x9f; +pub const _SC_SPIN_LOCKS: ::c_int = 0x9a; +pub const _SC_SPORADIC_SERVER: ::c_int = 0xa0; +pub const _SC_SS_REPL_MAX: ::c_int = 0xf1; +pub const _SC_SYMLOOP_MAX: ::c_int = 0xad; +pub const _SC_THREAD_CPUTIME: ::c_int = 0x8b; +pub const _SC_THREAD_PROCESS_SHARED: ::c_int = 0x52; +pub const _SC_THREAD_ROBUST_PRIO_INHERIT: ::c_int = 0xf7; +pub const _SC_THREAD_ROBUST_PRIO_PROTECT: ::c_int = 0xf8; +pub const _SC_THREAD_SPORADIC_SERVER: ::c_int = 0xa1; +pub const _SC_TIMEOUTS: ::c_int = 0xa4; +pub const _SC_TRACE: ::c_int = 0xb5; +pub const _SC_TRACE_EVENT_FILTER: ::c_int = 0xb6; +pub const _SC_TRACE_EVENT_NAME_MAX: ::c_int = 0xf2; +pub const _SC_TRACE_INHERIT: ::c_int = 0xb7; +pub const _SC_TRACE_LOG: ::c_int = 0xb8; +pub const _SC_TRACE_NAME_MAX: ::c_int = 0xf3; +pub const _SC_TRACE_SYS_MAX: ::c_int = 0xf4; +pub const _SC_TRACE_USER_EVENT_MAX: ::c_int = 0xf5; +pub const _SC_TYPED_MEMORY_OBJECTS: ::c_int = 0xa5; +pub const _SC_V6_ILP32_OFF32: ::c_int = 0xb0; +pub const _SC_V6_ILP32_OFFBIG: ::c_int = 0xb1; +pub const _SC_V6_LP64_OFF64: ::c_int = 0xb2; +pub const _SC_V6_LPBIG_OFFBIG: ::c_int = 0xb3; +pub const _SC_XOPEN_STREAMS: ::c_int = 0xf6; + +fn CMSG_ALIGN(len: usize) -> usize { +    len + ::mem::size_of::<usize>() - 1 & !(::mem::size_of::<usize>() - 1) +} + +f! { +    pub fn CMSG_FIRSTHDR(mhdr: *const msghdr) -> *mut cmsghdr { +        if (*mhdr).msg_controllen as usize >= ::mem::size_of::<cmsghdr>() { +            (*mhdr).msg_control as *mut cmsghdr +        } else { +            0 as *mut cmsghdr +        } +    } + +    pub fn CMSG_DATA(cmsg: *const cmsghdr) -> *mut ::c_uchar { +        cmsg.offset(1) as *mut ::c_uchar +    } + +    pub fn CMSG_SPACE(length: ::c_uint) -> ::c_uint { +        (CMSG_ALIGN(length as usize) + CMSG_ALIGN(::mem::size_of::<cmsghdr>())) +            as ::c_uint +    } + +    pub fn CMSG_LEN(length: ::c_uint) -> ::c_uint { +        CMSG_ALIGN(::mem::size_of::<cmsghdr>()) as ::c_uint + length +    } + +    pub fn CMSG_NXTHDR(mhdr: *const msghdr, +                       cmsg: *const cmsghdr) -> *mut cmsghdr { +        if ((*cmsg).cmsg_len as usize) < ::mem::size_of::<cmsghdr>() { +            return 0 as *mut cmsghdr; +        }; +        let next = (cmsg as usize + +                    CMSG_ALIGN((*cmsg).cmsg_len as usize)) +            as *mut cmsghdr; +        let max = (*mhdr).msg_control as usize +            + (*mhdr).msg_controllen as usize; +        if (next.offset(1)) as usize > max || +            next as usize + CMSG_ALIGN((*next).cmsg_len as usize) > max +        { +            0 as *mut cmsghdr +        } else { +            next as *mut cmsghdr +        } +    } + +} + +extern { +    pub fn ioctl(fd: ::c_int, request: ::c_ulong, ...) -> ::c_int; +    pub fn openpty(amaster: *mut ::c_int, +                aslave: *mut ::c_int, +                name: *mut ::c_char, +                termp: *mut termios, +                winp: *mut ::winsize) -> ::c_int; +    pub fn setns(fd: ::c_int, nstype: ::c_int) -> ::c_int; +    pub fn pwritev(fd: ::c_int, +                   iov: *const ::iovec, +                   iovcnt: ::c_int, +                   offset: ::off_t) -> ::ssize_t; +    pub fn preadv(fd: ::c_int, +                  iov: *const ::iovec, +                  iovcnt: ::c_int, +                  offset: ::off_t) -> ::ssize_t; +} + +cfg_if! { +    if #[cfg(libc_align)] { +        mod align; +        pub use self::align::*; +    } else { +        mod no_align; +        pub use self::no_align::*; +    } +} diff --git a/libc/src/unix/uclibc/arm/no_align.rs b/libc/src/unix/uclibc/arm/no_align.rs new file mode 100644 index 0000000..e32bf67 --- /dev/null +++ b/libc/src/unix/uclibc/arm/no_align.rs @@ -0,0 +1,10 @@ +s! { +    // FIXME this is actually a union +    pub struct sem_t { +        #[cfg(target_pointer_width = "32")] +        __size: [::c_char; 16], +        #[cfg(target_pointer_width = "64")] +        __size: [::c_char; 32], +        __align: [::c_long; 0], +    } +} diff --git a/libc/src/unix/uclibc/mips/mips32/align.rs b/libc/src/unix/uclibc/mips/mips32/align.rs new file mode 100644 index 0000000..4a0e074 --- /dev/null +++ b/libc/src/unix/uclibc/mips/mips32/align.rs @@ -0,0 +1,13 @@ +s! { +    // FIXME this is actually a union +    #[cfg_attr(target_pointer_width = "32", +               repr(align(4)))] +    #[cfg_attr(target_pointer_width = "64", +               repr(align(8)))] +    pub struct sem_t { +        #[cfg(target_pointer_width = "32")] +        __size: [::c_char; 16], +        #[cfg(target_pointer_width = "64")] +        __size: [::c_char; 32], +    } +} diff --git a/libc/src/unix/uclibc/mips/mips32.rs b/libc/src/unix/uclibc/mips/mips32/mod.rs index dcbfcf8..410ab70 100644 --- a/libc/src/unix/uclibc/mips/mips32.rs +++ b/libc/src/unix/uclibc/mips/mips32/mod.rs @@ -220,20 +220,6 @@ s! {          pub mem_unit: ::c_uint,          pub _f: [::c_char; 8],      } - -    // FIXME this is actually a union -    #[cfg_attr(all(feature = "align", target_pointer_width = "32"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", target_pointer_width = "64"), -               repr(align(8)))] -    pub struct sem_t { -        #[cfg(target_pointer_width = "32")] -        __size: [::c_char; 16], -        #[cfg(target_pointer_width = "64")] -        __size: [::c_char; 32], -        #[cfg(not(feature = "align"))] -        __align: [::c_long; 0], -    }  }  pub const __SIZEOF_PTHREAD_CONDATTR_T: usize = 4; @@ -261,7 +247,6 @@ pub const SYS_mknod: ::c_long = 4000 +  14;  pub const SYS_chmod: ::c_long = 4000 +  15;  pub const SYS_lchown: ::c_long = 4000 +  16;  pub const SYS_break: ::c_long = 4000 +  17; -pub const SYS_unused18: ::c_long = 4000 +  18;  pub const SYS_lseek: ::c_long = 4000 +  19;  pub const SYS_getpid: ::c_long = 4000 +  20;  pub const SYS_mount: ::c_long = 4000 +  21; @@ -271,7 +256,6 @@ pub const SYS_getuid: ::c_long = 4000 +  24;  pub const SYS_stime: ::c_long = 4000 +  25;  pub const SYS_ptrace: ::c_long = 4000 +  26;  pub const SYS_alarm: ::c_long = 4000 +  27; -pub const SYS_unused28: ::c_long = 4000 +  28;  pub const SYS_pause: ::c_long = 4000 +  29;  pub const SYS_utime: ::c_long = 4000 +  30;  pub const SYS_stty: ::c_long = 4000 +  31; @@ -302,7 +286,6 @@ pub const SYS_fcntl: ::c_long = 4000 +  55;  pub const SYS_mpx: ::c_long = 4000 +  56;  pub const SYS_setpgid: ::c_long = 4000 +  57;  pub const SYS_ulimit: ::c_long = 4000 +  58; -pub const SYS_unused59: ::c_long = 4000 +  59;  pub const SYS_umask: ::c_long = 4000 +  60;  pub const SYS_chroot: ::c_long = 4000 +  61;  pub const SYS_ustat: ::c_long = 4000 +  62; @@ -325,9 +308,7 @@ pub const SYS_gettimeofday: ::c_long = 4000 +  78;  pub const SYS_settimeofday: ::c_long = 4000 +  79;  pub const SYS_getgroups: ::c_long = 4000 +  80;  pub const SYS_setgroups: ::c_long = 4000 +  81; -pub const SYS_reserved82: ::c_long = 4000 +  82;  pub const SYS_symlink: ::c_long = 4000 +  83; -pub const SYS_unused84: ::c_long = 4000 +  84;  pub const SYS_readlink: ::c_long = 4000 +  85;  pub const SYS_uselib: ::c_long = 4000 +  86;  pub const SYS_swapon: ::c_long = 4000 +  87; @@ -352,7 +333,6 @@ pub const SYS_getitimer: ::c_long = 4000 + 105;  pub const SYS_stat: ::c_long = 4000 + 106;  pub const SYS_lstat: ::c_long = 4000 + 107;  pub const SYS_fstat: ::c_long = 4000 + 108; -pub const SYS_unused109: ::c_long = 4000 + 109;  pub const SYS_iopl: ::c_long = 4000 + 110;  pub const SYS_vhangup: ::c_long = 4000 + 111;  pub const SYS_idle: ::c_long = 4000 + 112; @@ -393,7 +373,6 @@ pub const SYS_writev: ::c_long = 4000 + 146;  pub const SYS_cacheflush: ::c_long = 4000 + 147;  pub const SYS_cachectl: ::c_long = 4000 + 148;  pub const SYS_sysmips: ::c_long = 4000 + 149; -pub const SYS_unused150: ::c_long = 4000 + 150;  pub const SYS_getsid: ::c_long = 4000 + 151;  pub const SYS_fdatasync: ::c_long = 4000 + 152;  pub const SYS__sysctl: ::c_long = 4000 + 153; @@ -464,7 +443,6 @@ pub const SYS_mincore: ::c_long = 4000 + 217;  pub const SYS_madvise: ::c_long = 4000 + 218;  pub const SYS_getdents64: ::c_long = 4000 + 219;  pub const SYS_fcntl64: ::c_long = 4000 + 220; -pub const SYS_reserved221: ::c_long = 4000 + 221;  pub const SYS_gettid: ::c_long = 4000 + 222;  pub const SYS_readahead: ::c_long = 4000 + 223;  pub const SYS_setxattr: ::c_long = 4000 + 224; @@ -624,7 +602,7 @@ extern {                       sz: ::c_int) -> ::c_int;      pub fn glob64(pattern: *const ::c_char,                    flags: ::c_int, -                  errfunc: ::dox::Option<extern fn(epath: *const ::c_char, +                  errfunc: ::Option<extern fn(epath: *const ::c_char,                                                     errno: ::c_int)                                                     -> ::c_int>,                    pglob: *mut glob64_t) -> ::c_int; @@ -637,3 +615,13 @@ extern {                                         cpusetsize: ::size_t,                                         cpuset: *const ::cpu_set_t) -> ::c_int;  } + +cfg_if! { +    if #[cfg(libc_align)] { +        mod align; +        pub use self::align::*; +    } else { +        mod no_align; +        pub use self::no_align::*; +    } +} diff --git a/libc/src/unix/uclibc/mips/mips32/no_align.rs b/libc/src/unix/uclibc/mips/mips32/no_align.rs new file mode 100644 index 0000000..e32bf67 --- /dev/null +++ b/libc/src/unix/uclibc/mips/mips32/no_align.rs @@ -0,0 +1,10 @@ +s! { +    // FIXME this is actually a union +    pub struct sem_t { +        #[cfg(target_pointer_width = "32")] +        __size: [::c_char; 16], +        #[cfg(target_pointer_width = "64")] +        __size: [::c_char; 32], +        __align: [::c_long; 0], +    } +} diff --git a/libc/src/unix/uclibc/mips/mips64/align.rs b/libc/src/unix/uclibc/mips/mips64/align.rs new file mode 100644 index 0000000..21e2190 --- /dev/null +++ b/libc/src/unix/uclibc/mips/mips64/align.rs @@ -0,0 +1,10 @@ +s! { +    // FIXME this is actually a union +    #[cfg_attr(target_pointer_width = "32", +               repr(align(4)))] +    #[cfg_attr(target_pointer_width = "64", +               repr(align(8)))] +    pub struct sem_t { +        __size: [::c_char; 32], +    } +} diff --git a/libc/src/unix/uclibc/mips/mips64.rs b/libc/src/unix/uclibc/mips/mips64/mod.rs index e35938b..d80762e 100644 --- a/libc/src/unix/uclibc/mips/mips64.rs +++ b/libc/src/unix/uclibc/mips/mips64/mod.rs @@ -186,17 +186,6 @@ s! {          pub mem_unit: ::c_uint,          pub _f: [::c_char; 0],      } - -    // FIXME this is actually a union -    #[cfg_attr(all(feature = "align", target_pointer_width = "32"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", target_pointer_width = "64"), -               repr(align(8)))] -    pub struct sem_t { -        __size: [::c_char; 32], -        #[cfg(not(feature = "align"))] -        __align: [::c_long; 0], -    }  }  pub const __SIZEOF_PTHREAD_CONDATTR_T: usize = 4; @@ -212,3 +201,13 @@ pub const SYS_gettid: ::c_long = 5178;   // Valid for n64  extern {      pub fn ioctl(fd: ::c_int, request: ::c_ulong, ...) -> ::c_int;  } + +cfg_if! { +    if #[cfg(libc_align)] { +        mod align; +        pub use self::align::*; +    } else { +        mod no_align; +        pub use self::no_align::*; +    } +} diff --git a/libc/src/unix/uclibc/mips/mips64/no_align.rs b/libc/src/unix/uclibc/mips/mips64/no_align.rs new file mode 100644 index 0000000..ee57ea8 --- /dev/null +++ b/libc/src/unix/uclibc/mips/mips64/no_align.rs @@ -0,0 +1,8 @@ +s! { +    // FIXME this is actually a union +    pub struct sem_t { +        __size: [::c_char; 32], +        __align: [::c_long; 0], +    } +} + diff --git a/libc/src/unix/uclibc/mod.rs b/libc/src/unix/uclibc/mod.rs index c04c22a..e3baba0 100644 --- a/libc/src/unix/uclibc/mod.rs +++ b/libc/src/unix/uclibc/mod.rs @@ -1,5 +1,3 @@ -use dox::{mem, Option}; -  pub type sa_family_t = u16;  pub type pthread_key_t = ::c_uint;  pub type speed_t = ::c_uint; @@ -24,11 +22,30 @@ pub type nfds_t = ::c_ulong;  pub type nl_item = ::c_int;  pub type idtype_t = ::c_uint; +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum fpos64_t {} // TODO: fill this out with a struct +impl ::Copy for fpos64_t {} +impl ::Clone for fpos64_t { +    fn clone(&self) -> fpos64_t { *self } +} +#[cfg_attr(feature = "extra_traits", derive(Debug))]  pub enum timezone {} +impl ::Copy for timezone {} +impl ::Clone for timezone { +    fn clone(&self) -> timezone { *self } +}  s! { +    pub struct in_addr { +        pub s_addr: ::in_addr_t, +    } + +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } +      pub struct sockaddr {          pub sa_family: sa_family_t,          pub sa_data: [::c_char; 14], @@ -49,20 +66,6 @@ s! {          pub sin6_scope_id: u32,      } -    pub struct sockaddr_un { -        pub sun_family: sa_family_t, -        pub sun_path: [::c_char; 108] -    } - -    pub struct sockaddr_storage { -        pub ss_family: sa_family_t, -        __ss_align: ::size_t, -        #[cfg(target_pointer_width = "32")] -        __ss_pad2: [u8; 128 - 2 * 4], -        #[cfg(target_pointer_width = "64")] -        __ss_pad2: [u8; 128 - 2 * 8], -    } -      pub struct addrinfo {          pub ai_flags: ::c_int,          pub ai_family: ::c_int, @@ -123,23 +126,6 @@ s! {          pub dli_saddr: *mut ::c_void,      } -    #[cfg_attr(any(all(target_arch = "x86", -                   target_arch = "x86_64")), -               repr(packed))] -    pub struct epoll_event { -        pub events: ::uint32_t, -        pub u64: ::uint64_t, -    } - -    pub struct utsname { -        pub sysname: [::c_char; 65], -        pub nodename: [::c_char; 65], -        pub release: [::c_char; 65], -        pub version: [::c_char; 65], -        pub machine: [::c_char; 65], -        pub domainname: [::c_char; 65] -    } -      pub struct lconv {          pub decimal_point: *mut ::c_char,          pub thousands_sep: *mut ::c_char, @@ -180,22 +166,6 @@ s! {          __unused1: [::c_int; 12]      } -    pub struct dirent { -        pub d_ino: ::ino_t, -        pub d_off: ::off_t, -        pub d_reclen: ::c_ushort, -        pub d_type: ::c_uchar, -        pub d_name: [::c_char; 256], -    } - -    pub struct dirent64 { -        pub d_ino: ::ino64_t, -        pub d_off: ::off64_t, -        pub d_reclen: ::c_ushort, -        pub d_type: ::c_uchar, -        pub d_name: [::c_char; 256], -    } -      pub struct rlimit64 {          pub rlim_cur: rlim64_t,          pub rlim_max: rlim64_t, @@ -224,103 +194,11 @@ s! {          pub ifa_data: *mut ::c_void      } -    #[cfg_attr(all(feature = "align", -                   target_pointer_width = "32", -                   any(target_arch = "mips", -                       target_arch = "arm", -                       target_arch = "powerpc")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "64", -                       not(any(target_arch = "mips", -                               target_arch = "arm", -                               target_arch = "powerpc")))), -               repr(align(8)))] -    pub struct pthread_mutex_t { -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_long; 0], -        #[cfg(not(any(feature = "align", -                      target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEX_T], -    } - -    #[cfg_attr(all(feature = "align", -                   target_pointer_width = "32", -                   any(target_arch = "mips", -                       target_arch = "arm", -                       target_arch = "powerpc")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "64", -                       not(any(target_arch = "mips", -                               target_arch = "arm", -                               target_arch = "powerpc")))), -               repr(align(8)))] -    pub struct pthread_rwlock_t { -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_long; 0], -        #[cfg(not(any(feature = "align", -                      target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_RWLOCK_T], -    } - -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "32", -                       target_arch = "x86_64", target_arch = "powerpc64", -                       target_arch = "mips64", target_arch = "s390x", -                       target_arch = "sparc64")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   not(any(target_pointer_width = "32", -                           target_arch = "x86_64", target_arch = "powerpc64", -                           target_arch = "mips64", target_arch = "s390x", -                           target_arch = "sparc64"))), -               repr(align(8)))] -    pub struct pthread_mutexattr_t { -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "x86_64", target_arch = "powerpc64", -                      target_arch = "mips64", target_arch = "s390x", -                      target_arch = "sparc64")))] -        __align: [::c_int; 0], -        #[cfg(all(not(feature = "align"), -                  not(any(target_arch = "x86_64", target_arch = "powerpc64", -                          target_arch = "mips64", target_arch = "s390x", -                          target_arch = "sparc64"))))] -        __align: [::c_long; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEXATTR_T], -    } -      pub struct pthread_rwlockattr_t {          __lockkind: ::c_int,          __pshared: ::c_int,      } -    #[cfg_attr(feature = "align", repr(align(8)))] -    pub struct pthread_cond_t { -        #[cfg(not(feature = "align"))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_COND_T], -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_condattr_t { -        #[cfg(not(feature = "align"))] -        __align: [::c_int; 0], -        size: [u8; __SIZEOF_PTHREAD_CONDATTR_T], -    } -      pub struct passwd {          pub pw_name: *mut ::c_char,          pub pw_passwd: *mut ::c_char, @@ -436,6 +314,62 @@ s! {      }  } +s_no_extra_traits! { +    #[cfg_attr( +        any(target_arch = "x86", target_arch = "x86_64"), +        repr(packed) +    )] +    #[allow(missing_debug_implementations)] +    pub struct epoll_event { +        pub events: ::uint32_t, +        pub u64: ::uint64_t, +    } + +    #[allow(missing_debug_implementations)] +    pub struct sockaddr_un { +        pub sun_family: sa_family_t, +        pub sun_path: [::c_char; 108] +    } + +    #[allow(missing_debug_implementations)] +    pub struct sockaddr_storage { +        pub ss_family: sa_family_t, +        __ss_align: ::size_t, +        #[cfg(target_pointer_width = "32")] +        __ss_pad2: [u8; 128 - 2 * 4], +        #[cfg(target_pointer_width = "64")] +        __ss_pad2: [u8; 128 - 2 * 8], +    } + +    #[allow(missing_debug_implementations)] +    pub struct utsname { +        pub sysname: [::c_char; 65], +        pub nodename: [::c_char; 65], +        pub release: [::c_char; 65], +        pub version: [::c_char; 65], +        pub machine: [::c_char; 65], +        pub domainname: [::c_char; 65] +    } + +    #[allow(missing_debug_implementations)] +    pub struct dirent { +        pub d_ino: ::ino_t, +        pub d_off: ::off_t, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } + +    #[allow(missing_debug_implementations)] +    pub struct dirent64 { +        pub d_ino: ::ino64_t, +        pub d_off: ::off64_t, +        pub d_reclen: ::c_ushort, +        pub d_type: ::c_uchar, +        pub d_name: [::c_char; 256], +    } +} +  // intentionally not public, only used for fd_set  cfg_if! {      if #[cfg(target_pointer_width = "32")] { @@ -1459,20 +1393,20 @@ pub const AF_MAX: ::c_int = 39;  f! {      pub fn FD_CLR(fd: ::c_int, set: *mut fd_set) -> () {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          (*set).fds_bits[fd / size] &= !(1 << (fd % size));          return      }      pub fn FD_ISSET(fd: ::c_int, set: *mut fd_set) -> bool {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          return ((*set).fds_bits[fd / size] & (1 << (fd % size))) != 0      }      pub fn FD_SET(fd: ::c_int, set: *mut fd_set) -> () {          let fd = fd as usize; -        let size = mem::size_of_val(&(*set).fds_bits[0]) * 8; +        let size = ::mem::size_of_val(&(*set).fds_bits[0]) * 8;          (*set).fds_bits[fd / size] |= 1 << (fd % size);          return      } @@ -1522,21 +1456,23 @@ f! {      }      pub fn CPU_SET(cpu: usize, cpuset: &mut cpu_set_t) -> () { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc +        let size_in_bits +            = 8 * ::mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          cpuset.bits[idx] |= 1 << offset;          ()      }      pub fn CPU_CLR(cpu: usize, cpuset: &mut cpu_set_t) -> () { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc +        let size_in_bits +            = 8 * ::mem::size_of_val(&cpuset.bits[0]); // 32, 64 etc          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          cpuset.bits[idx] &= !(1 << offset);          ()      }      pub fn CPU_ISSET(cpu: usize, cpuset: &cpu_set_t) -> bool { -        let size_in_bits = 8 * mem::size_of_val(&cpuset.bits[0]); +        let size_in_bits = 8 * ::mem::size_of_val(&cpuset.bits[0]);          let (idx, offset) = (cpu / size_in_bits, cpu % size_in_bits);          0 != (cpuset.bits[idx] & (1 << offset))      } @@ -1551,6 +1487,12 @@ f! {  }  extern { +    pub fn sem_destroy(sem: *mut sem_t) -> ::c_int; +    pub fn sem_init(sem: *mut sem_t, +                    pshared: ::c_int, +                    value: ::c_uint) +                    -> ::c_int; +      pub fn abs(i: ::c_int) -> ::c_int;      pub fn atof(s: *const ::c_char) -> ::c_double;      pub fn labs(i: ::c_long) -> ::c_long; @@ -1857,7 +1799,7 @@ extern {      pub fn glob(pattern: *const c_char,                  flags: ::c_int, -                errfunc: Option<extern fn(epath: *const c_char, +                errfunc: ::Option<extern fn(epath: *const c_char,                                            errno: ::c_int) -> ::c_int>,                  pglob: *mut ::glob_t) -> ::c_int;      pub fn globfree(pglob: *mut ::glob_t); @@ -1895,7 +1837,7 @@ extern {      pub fn recvmsg(fd: ::c_int, msg: *mut ::msghdr, flags: ::c_int)                     -> ::ssize_t;      #[cfg_attr(target_os = "solaris", link_name = "__posix_getgrgid_r")] -    pub fn getgrgid_r(uid: ::uid_t, +    pub fn getgrgid_r(gid: ::gid_t,                        grp: *mut ::group,                        buf: *mut ::c_char,                        buflen: ::size_t, @@ -1941,9 +1883,9 @@ extern {      #[cfg_attr(target_os = "solaris", link_name = "__posix_sigwait")]      pub fn sigwait(set: *const sigset_t,                     sig: *mut ::c_int) -> ::c_int; -    pub fn pthread_atfork(prepare: Option<unsafe extern fn()>, -                          parent: Option<unsafe extern fn()>, -                          child: Option<unsafe extern fn()>) -> ::c_int; +    pub fn pthread_atfork(prepare: ::Option<unsafe extern fn()>, +                          parent: ::Option<unsafe extern fn()>, +                          child: ::Option<unsafe extern fn()>) -> ::c_int;      pub fn pthread_create(native: *mut ::pthread_t,                            attr: *const ::pthread_attr_t,                            f: extern fn(*mut ::c_void) -> *mut ::c_void, @@ -1963,8 +1905,22 @@ cfg_if! {      } else if #[cfg(target_arch = "x86_64")] {          mod x86_64;          pub use self::x86_64::*; +    } else if #[cfg(target_arch = "arm")] { +        mod arm; +        pub use self::arm::*;      } else {          pub use unsupported_target;      }  } +cfg_if! { +    if #[cfg(libc_align)] { +        #[macro_use] +        mod align; +    } else { +        #[macro_use] +        mod no_align; +    } +} + +expand_align!(); diff --git a/libc/src/unix/uclibc/no_align.rs b/libc/src/unix/uclibc/no_align.rs new file mode 100644 index 0000000..a73dbde --- /dev/null +++ b/libc/src/unix/uclibc/no_align.rs @@ -0,0 +1,53 @@ +macro_rules! expand_align { +    () => { +        s! { +            pub struct pthread_mutex_t { +                #[cfg(any(target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc"))] +                __align: [::c_long; 0], +                #[cfg(any(libc_align, +                          target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc"))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            pub struct pthread_rwlock_t { +                #[cfg(any(target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc"))] +                __align: [::c_long; 0], +                #[cfg(not(any( +                    target_arch = "mips", +                    target_arch = "arm", +                    target_arch = "powerpc")))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } + +            pub struct pthread_mutexattr_t { +                #[cfg(any(target_arch = "x86_64", target_arch = "powerpc64", +                          target_arch = "mips64", target_arch = "s390x", +                          target_arch = "sparc64"))] +                __align: [::c_int; 0], +                #[cfg(not(any(target_arch = "x86_64", target_arch = "powerpc64", +                              target_arch = "mips64", target_arch = "s390x", +                              target_arch = "sparc64")))] +                __align: [::c_long; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            pub struct pthread_cond_t { +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } + +            pub struct pthread_condattr_t { +                __align: [::c_int; 0], +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } +    } +} diff --git a/libc/src/unix/uclibc/x86_64/align.rs b/libc/src/unix/uclibc/x86_64/align.rs new file mode 100644 index 0000000..8d4bbd5 --- /dev/null +++ b/libc/src/unix/uclibc/x86_64/align.rs @@ -0,0 +1,77 @@ +macro_rules! expand_align { +    () => { +        s! { +            #[cfg_attr(target_pointer_width = "32", +                       repr(align(4)))] +            #[cfg_attr(target_pointer_width = "64", +                       repr(align(8)))] +            pub struct sem_t { // ToDo +                #[cfg(target_pointer_width = "32")] +                __size: [::c_char; 16], +                #[cfg(target_pointer_width = "64")] +                __size: [::c_char; 32], +            } + +            #[cfg_attr(any(target_pointer_width = "32", +                           target_arch = "x86_64", +                           target_arch = "powerpc64", +                           target_arch = "mips64", +                           target_arch = "s390x", +                           target_arch = "sparc64"), +                       repr(align(4)))] +            #[cfg_attr(not(any(target_pointer_width = "32", +                               target_arch = "x86_64", +                               target_arch = "powerpc64", +                               target_arch = "mips64", +                               target_arch = "s390x", +                               target_arch = "sparc64")), +                       repr(align(8)))] +            pub struct pthread_mutexattr_t { // ToDo +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            #[repr(align(4))] +            pub struct pthread_condattr_t { // ToDo +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } +        } + +        s_no_extra_traits! { +            #[cfg_attr(all(target_pointer_width = "32", +                           any(target_arch = "mips", +                               target_arch = "arm", +                               target_arch = "powerpc")), +                       repr(align(4)))] +            #[cfg_attr(all(any(target_pointer_width = "64", +                               not(any(target_arch = "mips", +                                       target_arch = "arm", +                                       target_arch = "powerpc")))), +                       repr(align(8)))] +            #[allow(missing_debug_implementations)] +            pub struct pthread_mutex_t { // ToDo +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            #[repr(align(8))] +            #[allow(missing_debug_implementations)] +            pub struct pthread_cond_t { // ToDo +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } + +            #[cfg_attr(all(target_pointer_width = "32", +                           any(target_arch = "mips", +                               target_arch = "arm", +                               target_arch = "powerpc")), +                       repr(align(4)))] +            #[cfg_attr(any(target_pointer_width = "64", +                           not(any(target_arch = "mips", +                                   target_arch = "arm", +                                   target_arch = "powerpc"))), +                       repr(align(8)))] +            #[allow(missing_debug_implementations)] +            pub struct pthread_rwlock_t { // ToDo +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } +        } +    } +} diff --git a/libc/src/unix/uclibc/x86_64/l4re.rs b/libc/src/unix/uclibc/x86_64/l4re.rs index 4f5811d..16ec0ef 100644 --- a/libc/src/unix/uclibc/x86_64/l4re.rs +++ b/libc/src/unix/uclibc/x86_64/l4re.rs @@ -27,6 +27,7 @@ s! {  }  #[cfg(target_os = "l4re")] +#[allow(missing_debug_implementations)]  pub struct pthread_attr_t {      pub __detachstate: ::c_int,      pub __schedpolicy: ::c_int, diff --git a/libc/src/unix/uclibc/x86_64/mod.rs b/libc/src/unix/uclibc/x86_64/mod.rs index bc6571a..a8bb079 100644 --- a/libc/src/unix/uclibc/x86_64/mod.rs +++ b/libc/src/unix/uclibc/x86_64/mod.rs @@ -1,5 +1,4 @@  //! Definitions for uclibc on 64bit systems -//!  pub type blkcnt_t = i64;  pub type blksize_t = i64;  pub type clock_t = i64; @@ -20,25 +19,7 @@ pub type suseconds_t = ::c_long;  pub type time_t = ::c_int;  pub type wchar_t = ::c_int; -pub type nfds_t = ::c_ulong; -  s! { -    pub struct dirent { -        pub d_ino: ::ino64_t, -        pub d_off: ::off64_t, -        pub d_reclen: u16, -        pub d_type: u8, -        pub d_name: [::c_char; 256], -    } - -    pub struct dirent64 { -        pub d_ino: ::ino64_t, -        pub d_off: ::off64_t, -        pub d_reclen: u16, -        pub d_type: u8, -        pub d_name: [::c_char; 256], -    } -      pub struct ipc_perm {          pub __key: ::key_t,          pub uid: ::uid_t, @@ -133,7 +114,7 @@ s! {  //  //    pub struct in6_addr {  //        pub s6_addr: [u8; 16], -//        #[cfg(not(feature = "align"))] +//        #[cfg(not(libc_align))]  //        __align: [u32; 0],  //    } @@ -205,111 +186,6 @@ s! {          pub c_cc: [::cc_t; ::NCCS],      } -    #[cfg_attr(all(feature = "align", target_pointer_width = "32"), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", target_pointer_width = "64"), -               repr(align(8)))] -    pub struct sem_t { // ToDo -        #[cfg(target_pointer_width = "32")] -        __size: [::c_char; 16], -        #[cfg(target_pointer_width = "64")] -        __size: [::c_char; 32], -        #[cfg(not(feature = "align"))] -        __align: [::c_long; 0], -    } - -    #[cfg_attr(all(feature = "align", -                   target_pointer_width = "32", -                   any(target_arch = "mips", -                       target_arch = "arm", -                       target_arch = "powerpc")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "64", -                       not(any(target_arch = "mips", -                               target_arch = "arm", -                               target_arch = "powerpc")))), -               repr(align(8)))] -    pub struct pthread_mutex_t { // ToDo -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_long; 0], -        #[cfg(not(any(feature = "align", -                      target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEX_T], -    } - -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "32", -                       target_arch = "x86_64", target_arch = "powerpc64", -                       target_arch = "mips64", target_arch = "s390x", -                       target_arch = "sparc64")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   not(any(target_pointer_width = "32", -                           target_arch = "x86_64", target_arch = "powerpc64", -                           target_arch = "mips64", target_arch = "s390x", -                           target_arch = "sparc64"))), -               repr(align(8)))] -    pub struct pthread_mutexattr_t { // ToDo -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "x86_64", target_arch = "powerpc64", -                      target_arch = "mips64", target_arch = "s390x", -                      target_arch = "sparc64")))] -        __align: [::c_int; 0], -        #[cfg(all(not(feature = "align"), -                  not(any(target_arch = "x86_64", target_arch = "powerpc64", -                          target_arch = "mips64", target_arch = "s390x", -                          target_arch = "sparc64"))))] -        __align: [::c_long; 0], -        size: [u8; __SIZEOF_PTHREAD_MUTEXATTR_T], -    } - -    #[cfg_attr(feature = "align", repr(align(8)))] -    pub struct pthread_cond_t { // ToDo -        #[cfg(not(feature = "align"))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_COND_T], -    } - -    #[cfg_attr(feature = "align", repr(align(4)))] -    pub struct pthread_condattr_t { // ToDo -        #[cfg(not(feature = "align"))] -        __align: [::c_int; 0], -        size: [u8; __SIZEOF_PTHREAD_CONDATTR_T], -    } - -    #[cfg_attr(all(feature = "align", -                   target_pointer_width = "32", -                   any(target_arch = "mips", -                       target_arch = "arm", -                       target_arch = "powerpc")), -               repr(align(4)))] -    #[cfg_attr(all(feature = "align", -                   any(target_pointer_width = "64", -                       not(any(target_arch = "mips", -                               target_arch = "arm", -                               target_arch = "powerpc")))), -               repr(align(8)))] -    pub struct pthread_rwlock_t { // ToDo -        #[cfg(all(not(feature = "align"), -                  any(target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_long; 0], -        #[cfg(not(any(feature = "align", -                      target_arch = "mips", -                      target_arch = "arm", -                      target_arch = "powerpc")))] -        __align: [::c_longlong; 0], -        size: [u8; __SIZEOF_PTHREAD_RWLOCK_T], -    } -      pub struct sigset_t { // ToDo          __val: [::c_ulong; 16],      } @@ -360,6 +236,25 @@ s! {      }  } +s_no_extra_traits! { +    #[allow(missing_debug_implementations)] +    pub struct dirent { +        pub d_ino: ::ino64_t, +        pub d_off: ::off64_t, +        pub d_reclen: u16, +        pub d_type: u8, +        pub d_name: [::c_char; 256], +    } +    #[allow(missing_debug_implementations)] +    pub struct dirent64 { +        pub d_ino: ::ino64_t, +        pub d_off: ::off64_t, +        pub d_reclen: u16, +        pub d_type: u8, +        pub d_name: [::c_char; 256], +    } +} +  // constants  pub const EADDRINUSE: ::c_int = 98; // Address already in use  pub const EADDRNOTAVAIL: ::c_int = 99; // Cannot assign requested address @@ -380,7 +275,6 @@ pub const O_NONBLOCK: ::c_int = 04000;  pub const O_TRUNC: ::c_int = 01000;  pub const NCCS: usize = 32;  pub const SIG_SETMASK: ::c_int = 2; // Set the set of blocked signals -pub const PTHREAD_STACK_MIN: usize = 16384;  pub const __SIZEOF_PTHREAD_MUTEX_T: usize = 40;  pub const __SIZEOF_PTHREAD_MUTEXATTR_T: usize = 4;  pub const SO_BROADCAST: ::c_int = 6; @@ -391,19 +285,11 @@ pub const SOL_SOCKET: ::c_int = 1;  pub const SO_RCVTIMEO: ::c_int = 20;  pub const SO_REUSEADDR: ::c_int = 2;  pub const SO_SNDTIMEO: ::c_int = 21; -pub const PTHREAD_MUTEX_NORMAL: ::c_int = 0; -pub const PTHREAD_MUTEX_RECURSIVE: ::c_int = 1; -pub const PTHREAD_MUTEX_ERRORCHECK: ::c_int = 2; -pub const PTHREAD_MUTEX_DEFAULT: ::c_int = PTHREAD_MUTEX_NORMAL;  pub const RLIM_INFINITY: u64 = 0xffffffffffffffff;  pub const __SIZEOF_PTHREAD_COND_T: usize = 48;  pub const __SIZEOF_PTHREAD_CONDATTR_T: usize = 4;  pub const __SIZEOF_PTHREAD_RWLOCK_T: usize = 56; -extern { -    pub fn memalign(align: ::size_t, size: ::size_t) -> *mut ::c_void; -} -  cfg_if! {      if #[cfg(target_os = "l4re")] {          mod l4re; @@ -414,3 +300,13 @@ cfg_if! {      }  } +cfg_if! { +    if #[cfg(libc_align)] { +        #[macro_use] +        mod align; +    } else { +        #[macro_use] +        mod no_align; +    } +} +expand_align!(); diff --git a/libc/src/unix/uclibc/x86_64/no_align.rs b/libc/src/unix/uclibc/x86_64/no_align.rs new file mode 100644 index 0000000..422d78f --- /dev/null +++ b/libc/src/unix/uclibc/x86_64/no_align.rs @@ -0,0 +1,59 @@ +macro_rules! expand_align { +    () => { +        s! { +            pub struct sem_t { // ToDo +                #[cfg(target_pointer_width = "32")] +                __size: [::c_char; 16], +                #[cfg(target_pointer_width = "64")] +                __size: [::c_char; 32], +                __align: [::c_long; 0], +            } + +            pub struct pthread_mutex_t { // ToDo +                #[cfg(any(target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc"))] +                __align: [::c_long; 0], +                #[cfg(not(any(target_arch = "mips", +                              target_arch = "arm", +                              target_arch = "powerpc")))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEX_T], +            } + +            pub struct pthread_mutexattr_t { // ToDo +                #[cfg(any(target_arch = "x86_64", target_arch = "powerpc64", +                          target_arch = "mips64", target_arch = "s390x", +                          target_arch = "sparc64"))] +                __align: [::c_int; 0], +                #[cfg(not(any(target_arch = "x86_64", target_arch = "powerpc64", +                              target_arch = "mips64", target_arch = "s390x", +                              target_arch = "sparc64")))] +                __align: [::c_long; 0], +                size: [u8; ::__SIZEOF_PTHREAD_MUTEXATTR_T], +            } + +            pub struct pthread_cond_t { // ToDo +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_COND_T], +            } + +            pub struct pthread_condattr_t { // ToDo +                __align: [::c_int; 0], +                size: [u8; ::__SIZEOF_PTHREAD_CONDATTR_T], +            } + +            pub struct pthread_rwlock_t { // ToDo +                #[cfg(any(target_arch = "mips", +                          target_arch = "arm", +                          target_arch = "powerpc"))] +                __align: [::c_long; 0], +                #[cfg(not(any(target_arch = "mips", +                              target_arch = "arm", +                              target_arch = "powerpc")))] +                __align: [::c_longlong; 0], +                size: [u8; ::__SIZEOF_PTHREAD_RWLOCK_T], +            } +        } +    } +} diff --git a/libc/src/unix/uclibc/x86_64/other.rs b/libc/src/unix/uclibc/x86_64/other.rs index 1cc521d..481577c 100644 --- a/libc/src/unix/uclibc/x86_64/other.rs +++ b/libc/src/unix/uclibc/x86_64/other.rs @@ -2,3 +2,4 @@  // separate module  pub type pthread_t = ::c_ulong; +pub const PTHREAD_STACK_MIN: usize = 16384; | 
