diff options
| author | Daniel Mueller <deso@posteo.net> | 2019-05-24 18:07:22 -0700 | 
|---|---|---|
| committer | Daniel Mueller <deso@posteo.net> | 2019-05-24 18:07:22 -0700 | 
| commit | 82cf43dd887801b8b22b8aae8c02854d921915d5 (patch) | |
| tree | b1bf3710bd07fe83e396a5db8563f3e6c5e85689 /libc/src/unix/uclibc/x86_64 | |
| parent | 06722702ea35434189d7de2b13a00209b2ebbd6d (diff) | |
| download | nitrocli-82cf43dd887801b8b22b8aae8c02854d921915d5.tar.gz nitrocli-82cf43dd887801b8b22b8aae8c02854d921915d5.tar.bz2 | |
Update libc crate to 0.2.55
This change updates the libc crate to version 0.2.55.
Import subrepo libc/:libc at caf17a0641d29dc624621177f5756804dd180c13
Diffstat (limited to 'libc/src/unix/uclibc/x86_64')
| -rw-r--r-- | libc/src/unix/uclibc/x86_64/align.rs | 77 | ||||
| -rw-r--r-- | libc/src/unix/uclibc/x86_64/l4re.rs | 1 | ||||
| -rw-r--r-- | libc/src/unix/uclibc/x86_64/mod.rs | 164 | ||||
| -rw-r--r-- | libc/src/unix/uclibc/x86_64/no_align.rs | 59 | ||||
| -rw-r--r-- | libc/src/unix/uclibc/x86_64/other.rs | 1 | 
5 files changed, 168 insertions, 134 deletions
| 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; | 
