diff options
Diffstat (limited to 'libc/src/vxworks')
| -rw-r--r-- | libc/src/vxworks/aarch64.rs | 3 | ||||
| -rw-r--r-- | libc/src/vxworks/arm.rs | 3 | ||||
| -rw-r--r-- | libc/src/vxworks/armv7.rs | 2 | ||||
| -rwxr-xr-x | libc/src/vxworks/mod.rs | 2319 | ||||
| -rw-r--r-- | libc/src/vxworks/powerpc.rs | 3 | ||||
| -rw-r--r-- | libc/src/vxworks/powerpc64.rs | 3 | ||||
| -rw-r--r-- | libc/src/vxworks/x86.rs | 3 | ||||
| -rw-r--r-- | libc/src/vxworks/x86_64.rs | 3 | 
8 files changed, 2339 insertions, 0 deletions
| diff --git a/libc/src/vxworks/aarch64.rs b/libc/src/vxworks/aarch64.rs new file mode 100644 index 0000000..577c8be --- /dev/null +++ b/libc/src/vxworks/aarch64.rs @@ -0,0 +1,3 @@ +pub type c_char = u8; +pub type c_long = i64; +pub type c_ulong = u64; diff --git a/libc/src/vxworks/arm.rs b/libc/src/vxworks/arm.rs new file mode 100644 index 0000000..cfdce82 --- /dev/null +++ b/libc/src/vxworks/arm.rs @@ -0,0 +1,3 @@ +pub type c_char = u8; +pub type c_long = i32; +pub type c_ulong = u32; diff --git a/libc/src/vxworks/armv7.rs b/libc/src/vxworks/armv7.rs new file mode 100644 index 0000000..9b0b338 --- /dev/null +++ b/libc/src/vxworks/armv7.rs @@ -0,0 +1,2 @@ +pub type c_long = i32; +pub type c_ulong = u32; diff --git a/libc/src/vxworks/mod.rs b/libc/src/vxworks/mod.rs new file mode 100755 index 0000000..19aa2b6 --- /dev/null +++ b/libc/src/vxworks/mod.rs @@ -0,0 +1,2319 @@ +//! Hacking together the definitions for VxWorks Bindings +use core::mem::size_of; +use core::ptr::null_mut; + +#[cfg_attr(feature = "extra_traits", derive(Debug))] +pub enum DIR {} +impl ::Copy for DIR {} +impl ::Clone for DIR { +    fn clone(&self) -> DIR { +        *self +    } +} + +pub type c_schar = i8; +pub type c_uchar = u8; +pub type c_short = i16; +pub type c_ushort = u16; +pub type c_int = i32; +pub type c_uint = u32; +pub type c_float = f32; +pub type c_double = f64; +pub type c_longlong = i64; +pub type c_ulonglong = u64; +pub type intmax_t = i64; +pub type uintmax_t = u64; + +pub type size_t = usize; +pub type ptrdiff_t = isize; +pub type intptr_t = isize; +pub type uintptr_t = usize; +pub type ssize_t = isize; + +pub type pid_t = i32; +pub type in_addr_t = u32; +pub type in_port_t = u16; +pub type sighandler_t = ::size_t; +pub type cc_t = ::c_uchar; + +pub type blkcnt_t = ::c_long; +pub type blksize_t = ::c_long; +pub type ino_t = ::c_ulong; +pub type ino32_t = u32; +pub type off_t = ::c_longlong; + +pub type rlim_t = ::c_ulonglong; +pub type suseconds_t = ::c_long; +pub type time_t = ::c_long; +pub type wchar_t = ::c_int; +pub type errno_t = ::c_int; + +pub type useconds_t = ::c_ulong; + +pub type socklen_t = ::c_int; + +pub type pthread_t = ::c_ulong; + +pub type clockid_t = ::c_int; + +//defined for the structs +pub type dev_t = ::c_ulong; +pub type mode_t = ::c_int; +pub type nlink_t = ::c_ulong; +pub type uid_t = ::c_ushort; +pub type gid_t = ::c_ushort; +pub type sigset_t = ::c_ulonglong; +pub type key_t = ::c_long; +pub type shmatt_t = ::c_ulong; + +pub type mqd_t = ::c_int; + +pub type nfds_t = ::c_uint; +pub type nl_item = ::c_int; +pub type stat64 = ::stat; + +pub type pthread_key_t = ::c_ulong; + +// From b_off_t.h +pub type off64_t = ::c_longlong; +pub type off_t64 = ::c_longlong; + +// From b_BOOL.h +pub type BOOL = ::c_int; // excuse me what + +//Straight from vxWind.h .. +pub type _Vx_OBJ_HANDLE = ::c_int; +pub type _Vx_TASK_ID = ::_Vx_OBJ_HANDLE; +pub type _Vx_MSG_Q_ID = ::_Vx_OBJ_HANDLE; +pub type _Vx_SEM_ID_KERNEL = ::_Vx_OBJ_HANDLE; +pub type _Vx_RTP_ID = ::_Vx_OBJ_HANDLE; +pub type _Vx_SD_ID = ::_Vx_OBJ_HANDLE; +pub type _Vx_CONDVAR_ID = ::_Vx_OBJ_HANDLE; +pub type _Vx_SEM_ID = *mut ::_Vx_semaphore; +pub type OBJ_HANDLE = ::_Vx_OBJ_HANDLE; +pub type TASK_ID = ::OBJ_HANDLE; +pub type MSG_Q_ID = ::OBJ_HANDLE; +pub type SEM_ID_KERNEL = ::OBJ_HANDLE; +pub type RTP_ID = ::OBJ_HANDLE; +pub type SD_ID = ::OBJ_HANDLE; +pub type CONDVAR_ID = ::OBJ_HANDLE; + +// From vxTypes.h +pub type _Vx_usr_arg_t = ::ssize_t; // c_int for LP32 +pub type _Vx_exit_code_t = ::ssize_t; // c_int for LP32 +pub type _Vx_ticks_t = ::c_uint; +pub type _Vx_ticks64_t = ::c_ulonglong; + +// From vxTypesBase.h +pub type va_list = *mut ::c_char; + +pub type sa_family_t = ::c_uchar; + +// structs that only exist in userspace +s! { +    // b_struct_vx_eventsResourceCb.h +    pub struct _Vx_EVENTS_RSRC { +        pub registered : ::c_uint, +        pub taskId     : ::c_int, +        pub options    : ::c_uchar, +        pub pad        : [::c_uchar; 3], +    } + +    // b_struct_vx_semaphore.h +    pub struct _Vx_semaphore { +        pub magic  : ::c_uint, +        pub semType: ::c_uint, +        pub options: ::c_uint, +        pub recurse: ::c_uint, +        pub owned_k: ::c_uint, // owned_k is volatile +        pub semId_k: ::_Vx_SEM_ID_KERNEL, +        pub state  : ::c_uint, //state is union of _Vx_UINT and _Vx_UINT +        pub events : ::_Vx_EVENTS_RSRC, +    } + +    // b_pthread_condattr_t.h +    pub struct pthread_condattr_t { +        pub condAttrStatus: ::c_int, +        pub condAttrPshared: ::c_int, +        pub _CondAttrClockId: ::clockid_t, +    } + +    // b_pthread_cond_t.h +    pub struct pthread_cond_t{ +        pub condSemId: ::_Vx_SEM_ID, +        pub condValid: ::c_int, +        pub condInitted: ::c_int, +        pub condRefCount: ::c_int, +        pub condMutex: *mut ::pthread_mutex_t, +        pub condAttr: ::pthread_condattr_t, +        pub condSemName: [::c_char; PTHREAD_SHARED_SEM_NAME_MAX] +    } + +    // b_pthread_rwlockattr_t.h +    pub struct pthread_rwlockattr_t { +        pub rwlockAttrStatus: ::c_int, +        pub rwlockAttrMaxReaders: ::c_uint, +    } + +    // b_pthread_rwlock_t.h +    pub struct pthread_rwlock_t { +        pub rwlockSemId: :: _Vx_SEM_ID, +        pub rwlockReadersRefCount: ::c_int, +        pub rwlockValid: ::c_int, +        pub rwlockInitted: ::c_int, +        pub rwlockAttr: ::pthread_rwlockattr_t, +        pub rwlockName: [::c_char; PTHREAD_SHARED_SEM_NAME_MAX] +    } + +    // b_struct_timeval.h +    pub struct timeval { +        pub tv_sec: ::time_t, +        pub tv_usec: ::suseconds_t, +    } + +    // socket.h +    pub struct sockaddr { +        pub sa_len    : ::c_uchar, +        pub sa_family : sa_family_t, +        pub sa_data   : [::c_char; 14], +    } + +    // socket.h +    pub struct sockaddr_storage { +        pub ss_len     : ::c_uchar, +        pub ss_family  : ::sa_family_t, +        pub __ss_pad1  : [::c_char; _SS_PAD1SIZE], +        pub __ss_align : i32, +        // pub __ss_pad2  : [::c_char; _SS_PAD2SIZE], +        pub __ss_pad2  : [::c_char; 32], +        pub __ss_pad3  : [::c_char; 32], +        pub __ss_pad4  : [::c_char; 32], +        pub __ss_pad5  : [::c_char; 32], +    } +    pub struct iovec { +        pub iov_base: *mut ::c_void, +        pub iov_len: ::size_t, +    } + +    // poll.h +    pub struct pollfd { +        pub fd      : ::c_int, +        pub events  : ::c_short, +        pub revents : ::c_short, +    } + +    // dirent.h +    pub struct dirent { +        pub d_ino  : ::ino_t, +        // pub d_name : [::c_char; (_PARM_NAME_MAX + 1)], +        pub d_name : [::c_char; 32], +        pub d_name1 : [::c_char; 32], +        pub d_name2 : [::c_char; 32], +        pub d_name3 : [::c_char; 32], +        pub d_name4 : [::c_char; 32], +        pub d_name5 : [::c_char; 32], +        pub d_name6 : [::c_char; 32], +        pub d_name7 : [::c_char; 32], +    } + +    pub struct dirent64 { +        pub d_ino    : ::ino_t, +        pub d_off    : ::off64_t, +        pub d_reclen : u16, +        pub d_type   : u8, +        // pub d_name   : [::c_char; 256], +        pub d_name   : [::c_char; 32], +        pub d_name1   : [::c_char; 32], +        pub d_name2   : [::c_char; 32], +        pub d_name3   : [::c_char; 32], +        pub d_name4   : [::c_char; 32], +        pub d_name5   : [::c_char; 32], +        pub d_name6   : [::c_char; 32], +        pub d_name7   : [::c_char; 32], +    } // Doesn't seem like it exists anymore + +    // resource.h +    pub struct rlimit { /* Is this really needed? Questionable ... */ +                           pub rlim_cur : ::size_t, +                           pub rlim_max : ::size_t, +    } + +    // stat.h +    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      : ::off64_t, +                         pub st_atime     : ::time_t, +                         pub st_mtime     : ::time_t, +                         pub st_ctime     : ::time_t, +                         pub st_blksize   : ::blksize_t, +                         pub st_blocks    : ::blkcnt_t, +                         pub st_attrib    : ::c_uchar, +                         pub st_reserved1 : ::c_int, +                         pub st_reserved2 : ::c_int, +                         pub st_reserved3 : ::c_int, +                         pub st_reserved4 : ::c_int, +    } + +    //b_struct__Timespec.h +    pub struct _Timespec { +        pub tv_sec  : ::time_t, +        pub tv_nsec : ::c_long, +    } + +    // b_struct__Sched_param.h +    pub struct _Sched_param { +        pub sched_priority: ::c_int, /* scheduling priority */ +        pub sched_ss_low_priority: ::c_int,    /* low scheduling priority */ +        pub sched_ss_repl_period: ::_Timespec, /* replenishment period */ +        pub sched_ss_init_budget: ::_Timespec, /* initial budget */ +        pub sched_ss_max_repl: ::c_int,        /* max pending replenishment */ + +    } + +    // b_pthread_attr_t.h +    pub struct pthread_attr_t { +        pub threadAttrStatus          : ::c_int, +        pub threadAttrStacksize       : ::size_t, +        pub threadAttrStackaddr       : *mut ::c_void, +        pub threadAttrGuardsize       : ::size_t, +        pub threadAttrDetachstate     : ::c_int, +        pub threadAttrContentionscope : ::c_int, +        pub threadAttrInheritsched    : ::c_int, +        pub threadAttrSchedpolicy     : ::c_int, +        pub threadAttrName            : *mut ::c_char, +        pub threadAttrOptions         : ::c_int, +        pub threadAttrSchedparam      : ::_Sched_param, +    } + +    // signal.h +    pub struct sigaction { // pulled from kernel side, +        pub sa_u     : ::size_t, +        // This is a union of two function pointers. +        // Under the assumption that function pointers are the same +        // size as other pointers, we can replace the union with size_t +        pub sa_mask  : ::sigset_t, +        pub sa_flags : ::c_int, +    } + +    // b_stack_t.h +    pub struct stack_t { +        pub ss_sp    : *mut ::c_void, +        pub ss_size  : ::size_t, +        pub ss_flags : ::c_int, +    } + +    // signal.h +    pub struct siginfo_t { +        pub si_signo : ::c_int, +        pub si_code  : ::c_int, +        // This field is a union of int and void * in vxworks +        // The size has been set to the larger of the two +        pub si_value : ::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 __seq : ::c_ushort, +    } + +    pub struct shmid_ds { +        pub shm_perm  : ipc_perm, +        pub shm_segsz : ::c_int, +    } + +    // pthread.h (krnl) +    // b_pthread_mutexattr_t.h (usr) +    pub struct pthread_mutexattr_t { +        mutexAttrStatus      : ::c_int, +        mutexAttrPshared     : ::c_int, +        mutexAttrProtocol    : ::c_int, +        mutexAttrPrioceiling : ::c_int, +        mutexAttrType        : ::c_int, +    } + +    // pthread.h (krnl) +    // b_pthread_mutex_t.h (usr) +    pub struct pthread_mutex_t  { +        pub mutexSemId: ::_Vx_SEM_ID, /*_Vx_SEM_ID ..*/ +        pub mutexValid: ::c_int, +        pub mutexInitted: ::c_int, +        pub mutexCondRefCount: ::c_int, +        pub mutexSavPriority: ::c_int, +        pub mutexAttr: ::pthread_mutexattr_t, +        pub mutexSemName: [::c_char; PTHREAD_SHARED_SEM_NAME_MAX], +    } + +    // b_struct_timespec.h +    pub struct timespec { +        pub tv_sec: ::time_t, +        pub tv_nsec: ::c_long, +    } + +    // in.h +    pub struct in_addr { +        pub s_addr: in_addr_t, +    } + +    // in.h +    pub struct ip_mreq { +        pub imr_multiaddr: in_addr, +        pub imr_interface: in_addr, +    } + +    // in6.h +    pub struct in6_addr { +        pub s6_addr: [u8; 16], +    } + +    // in6.h +    pub struct ipv6_mreq { +        pub ipv6mr_multiaddr: in6_addr, +        pub ipv6mr_interface: ::c_uint, +    } + +    // netdb.h +    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, +    } + +    // in.h +    pub struct sockaddr_in { +        pub sin_len   : u8, +        pub sin_family: u8, +        pub sin_port  : u16, +        pub sin_addr  : ::in_addr, +        pub sin_zero  : [::c_char; 8], +    } + +    // in6.h +    // There is a different implementation in ipv6.h in +    // krnl directory, but this seems to only happen +    // when the VSB is built for ipv6 only. +    pub struct sockaddr_in6 { +        pub sin6_len     : u8, +        pub sin6_family  : u8, +        pub sin6_port    : u16, +        pub sin6_flowinfo: u32, +        pub sin6_addr    : ::in6_addr, +        pub sin6_scope_id: u32, +    } + +    pub struct sockaddr_un { +        pub sun_family: sa_family_t, +        //pub sun_path: [::c_char; 108] +        pub sun_path: [::c_char; 32], +        pub sun_path1: [::c_char; 32], +        pub sun_path2: [::c_char; 32], +        pub sun_path3: [::c_char; 12], +    } + +    pub struct passwd { +        pub pw_name: *mut ::c_char, +        pub pw_uid: ::uid_t, +        pub pw_gid: ::gid_t, +        pub pw_dir: *mut ::c_char, +        pub pw_shell: *mut ::c_char, +    } + +    // rtpLibCommon.h +    pub struct RTP_DESC { +        pub status    : ::c_int, +        pub options   : u32, +        pub entrAddr  : *mut ::c_void, +        pub initTaskId: ::TASK_ID, +        pub parentId  : ::RTP_ID, +        //pub pathName  : [::c_char; (VX_RTP_NAME_LENGTH + 1)], +        pub pathName  : [::c_char; 32], +        pub pathName1  : [::c_char; 32], +        pub pathName2  : [::c_char; 32], +        pub pathName3  : [::c_char; 32], +        pub pathName4  : [::c_char; 32], +        pub pathName5  : [::c_char; 32], +        pub pathName6  : [::c_char; 32], +        pub pathName7  : [::c_char; 32], +        pub taskCnt   : u32, +        pub textStart : *mut ::c_void, +        pub textEnd   : *mut ::c_void, +    } + +    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 const STDIN_FILENO: ::c_int = 0; +pub const STDOUT_FILENO: ::c_int = 1; +pub const STDERR_FILENO: ::c_int = 2; + +pub const EXIT_SUCCESS: ::c_int = 0; +pub const EXIT_FAILURE: ::c_int = 1; + +pub const EAI_SERVICE: ::c_int = 9; +pub const EAI_SOCKTYPE: ::c_int = 10; +pub const EAI_SYSTEM: ::c_int = 11; + +pub const RTLD_DEFAULT: *mut ::c_void = 0i64 as *mut ::c_void; + +//Clock Lib Stuff +pub const CLOCK_REALTIME: ::c_int = 0x0; +pub const CLOCK_MONOTONIC: ::c_int = 0x1; +pub const CLOCK_PROCESS_CPUTIME_ID: ::c_int = 0x2; +pub const CLOCK_THREAD_CPUTIME_ID: ::c_int = 0x3; +pub const TIMER_ABSTIME: ::c_int = 0x1; +pub const TIME_RELTIME: ::c_int = 0xFFFFFFFE; + +// PTHREAD STUFF +pub const PTHREAD_INITIALIZED_OBJ: ::c_int = 0xF70990EF; +pub const PTHREAD_DESTROYED_OBJ: ::c_int = -1; +pub const PTHREAD_VALID_OBJ: ::c_int = 0xEC542A37; +pub const PTHREAD_INVALID_OBJ: ::c_int = -1; +pub const PTHREAD_UNUSED_YET_OBJ: ::c_int = -1; + +pub const PTHREAD_PRIO_NONE: ::c_int = 0; +pub const PTHREAD_PRIO_INHERIT: ::c_int = 1; +pub const PTHREAD_PRIO_PROTECT: ::c_int = 2; + +pub const PTHREAD_MUTEX_NORMAL: ::c_int = 0; +pub const PTHREAD_MUTEX_ERRORCHECK: ::c_int = 1; +pub const PTHREAD_MUTEX_RECURSIVE: ::c_int = 2; +pub const PTHREAD_MUTEX_DEFAULT: ::c_int = PTHREAD_MUTEX_NORMAL; +pub const PTHREAD_STACK_MIN: usize = 4096; +pub const PTHREAD_SHARED_SEM_NAME_MAX: usize = 30; + +pub const EFAULT: ::c_int = 14; +pub const EBUSY: ::c_int = 16; +pub const EEXIST: ::c_int = 17; +pub const ENODEV: ::c_int = 19; +pub const EINVAL: ::c_int = 22; +pub const EPIPE: ::c_int = 32; +pub const ERANGE: ::c_int = 34; + +// ERRNO STUFF +pub const EPERM: ::c_int = 1; /* Not owner */ +pub const ENOENT: ::c_int = 2; /* No such file or directory */ +pub const ESRCH: ::c_int = 3; /* No such process */ +pub const EINTR: ::c_int = 4; /* Interrupted system call */ +pub const EIOA: ::c_int = 5; /* I/O error */ +pub const ENXIO: ::c_int = 6; /* No such device or address */ +pub const E2BIG: ::c_int = 7; /* Arg list too long */ +pub const ENOEXEC: ::c_int = 8; /* Exec format error */ +pub const EBADF: ::c_int = 9; /* Bad file number */ +pub const CHILD: ::c_int = 10; /* No children */ +pub const EAGAIN: ::c_int = 11; /* No more processes */ +pub const ENOMEM: ::c_int = 12; /* Not enough core */ +pub const EACCES: ::c_int = 13; /* Permission denied */ +pub const EDEADLK: ::c_int = 33; +pub const EINPROGRESS: ::c_int = 68; +pub const EALREADY: ::c_int = 69; +pub const EWOULDBLOCK: ::c_int = 70; +pub const ENOSYS: ::c_int = 71; +pub const EDESTADDRREQ: ::c_int = 40; +pub const EPROTOTYPE: ::c_int = 41; +pub const ENOPROTOOPT: ::c_int = 42; +pub const EPROTONOSUPPORT: ::c_int = 43; +pub const ESOCKTNOSUPPORT: ::c_int = 44; +pub const EOPNOTSUPP: ::c_int = 45; +pub const EPFNOSUPPORT: ::c_int = 46; +pub const EAFNOSUPPORT: ::c_int = 47; +pub const EADDRINUSE: ::c_int = 48; +pub const EADDRNOTAVAIL: ::c_int = 49; +pub const ENOTSOCK: ::c_int = 50; +pub const ENETUNREACH: ::c_int = 51; +pub const ENETRESET: ::c_int = 52; +pub const ECONNABORTED: ::c_int = 53; +pub const ECONNRESET: ::c_int = 54; +pub const ENOBUFS: ::c_int = 55; +pub const EISCONN: ::c_int = 56; +pub const ENOTCONN: ::c_int = 57; +pub const ESHUTDOWN: ::c_int = 58; +pub const ETOOMANYREFS: ::c_int = 59; +pub const ETIMEDOUT: ::c_int = 60; +pub const ECONNREFUSED: ::c_int = 61; + +// NFS errnos: Refer to pkgs_v2/storage/fs/nfs/h/nfs/nfsCommon.h +const M_nfsStat: ::c_int = 48 << 16; +enum nfsstat { +    NFS_OK = 0, +    NFSERR_PERM = 1, +    NFSERR_NOENT = 2, +    NFSERR_IO = 5, +    NFSERR_NXIO = 6, +    NFSERR_ACCESS = 13, +    NFSERR_EXIST = 17, +    NFSERR_XDEV = 18, +    NFSERR_NODEV = 19, +    NFSERR_NOTDIR = 20, +    NFSERR_ISDIR = 21, +    NFSERR_INVAL = 22, +    NFSERR_FBIG = 27, +    NFSERR_NOSPC = 28, +    NFSERR_ROFS = 30, +    NFSERR_MLINK = 31, +    NFSERR_NAMETOOLONG = 63, +    NFSERR_NOTEMPTY = 66, +    NFSERR_DQUOT = 69, +    NFSERR_STALE = 70, +    NFSERR_REMOTE = 71, +    NFSERR_WFLUSH = 99, +    NFSERR_BADHANDLE = 10001, +    NFSERR_NOT_SYNC = 10002, +    NFSERR_BAD_COOKIE = 10003, +    NFSERR_NOTSUPP = 10004, +    NFSERR_TOOSMALL = 10005, +    NFSERR_SERVERFAULT = 10006, +    NFSERR_BADTYPE = 10007, +    NFSERR_JUKEBOX = 10008, +} + +pub const S_nfsLib_NFS_OK: ::c_int = M_nfsStat | nfsstat::NFS_OK as ::c_int; +pub const S_nfsLib_NFSERR_PERM: ::c_int = +    M_nfsStat | nfsstat::NFSERR_PERM as ::c_int; +pub const S_nfsLib_NFSERR_NOENT: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NOENT as ::c_int; +pub const S_nfsLib_NFSERR_IO: ::c_int = +    M_nfsStat | nfsstat::NFSERR_IO as ::c_int; +pub const S_nfsLib_NFSERR_NXIO: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NXIO as ::c_int; +pub const S_nfsLib_NFSERR_ACCESS: ::c_int = +    M_nfsStat | nfsstat::NFSERR_ACCESS as ::c_int; +pub const S_nfsLib_NFSERR_EXIST: ::c_int = +    M_nfsStat | nfsstat::NFSERR_EXIST as ::c_int; +pub const S_nfsLib_NFSERR_XDEV: ::c_int = +    M_nfsStat | nfsstat::NFSERR_XDEV as ::c_int; +pub const S_nfsLib_NFSERR_NODEV: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NODEV as ::c_int; +pub const S_nfsLib_NFSERR_NOTDIR: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NOTDIR as ::c_int; +pub const S_nfsLib_NFSERR_ISDIR: ::c_int = +    M_nfsStat | nfsstat::NFSERR_ISDIR as ::c_int; +pub const S_nfsLib_NFSERR_INVAL: ::c_int = +    M_nfsStat | nfsstat::NFSERR_INVAL as ::c_int; +pub const S_nfsLib_NFSERR_FBIG: ::c_int = +    M_nfsStat | nfsstat::NFSERR_FBIG as ::c_int; +pub const S_nfsLib_NFSERR_NOSPC: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NOSPC as ::c_int; +pub const S_nfsLib_NFSERR_ROFS: ::c_int = +    M_nfsStat | nfsstat::NFSERR_ROFS as ::c_int; +pub const S_nfsLib_NFSERR_MLINK: ::c_int = +    M_nfsStat | nfsstat::NFSERR_MLINK as ::c_int; +pub const S_nfsLib_NFSERR_NAMETOOLONG: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NAMETOOLONG as ::c_int; +pub const S_nfsLib_NFSERR_NOTEMPTY: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NOTEMPTY as ::c_int; +pub const S_nfsLib_NFSERR_DQUOT: ::c_int = +    M_nfsStat | nfsstat::NFSERR_DQUOT as ::c_int; +pub const S_nfsLib_NFSERR_STALE: ::c_int = +    M_nfsStat | nfsstat::NFSERR_STALE as ::c_int; +pub const S_nfsLib_NFSERR_WFLUSH: ::c_int = +    M_nfsStat | nfsstat::NFSERR_WFLUSH as ::c_int; +pub const S_nfsLib_NFSERR_REMOTE: ::c_int = +    M_nfsStat | nfsstat::NFSERR_REMOTE as ::c_int; +pub const S_nfsLib_NFSERR_BADHANDLE: ::c_int = +    M_nfsStat | nfsstat::NFSERR_BADHANDLE as ::c_int; +pub const S_nfsLib_NFSERR_NOT_SYNC: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NOT_SYNC as ::c_int; +pub const S_nfsLib_NFSERR_BAD_COOKIE: ::c_int = +    M_nfsStat | nfsstat::NFSERR_BAD_COOKIE as ::c_int; +pub const S_nfsLib_NFSERR_NOTSUPP: ::c_int = +    M_nfsStat | nfsstat::NFSERR_NOTSUPP as ::c_int; +pub const S_nfsLib_NFSERR_TOOSMALL: ::c_int = +    M_nfsStat | nfsstat::NFSERR_TOOSMALL as ::c_int; +pub const S_nfsLib_NFSERR_SERVERFAULT: ::c_int = +    M_nfsStat | nfsstat::NFSERR_SERVERFAULT as ::c_int; +pub const S_nfsLib_NFSERR_BADTYPE: ::c_int = +    M_nfsStat | nfsstat::NFSERR_BADTYPE as ::c_int; +pub const S_nfsLib_NFSERR_JUKEBOX: ::c_int = +    M_nfsStat | nfsstat::NFSERR_JUKEBOX as ::c_int; + +// IP Stuff? These are allll guesswork +pub const IPPROTO_IP: ::c_int = 0; +pub const IP_TTL: ::c_int = 4; // not sure if this is right +pub const IP_ADD_MEMBERSHIP: ::c_int = 11; +pub const IP_DROP_MEMBERSHIP: ::c_int = 12; +pub const IPV6_V6ONLY: ::c_int = 26; +pub const IP_MULTICAST_TTL: ::c_int = 33; +pub const IP_MULTICAST_LOOP: ::c_int = 34; +pub const IPV6_MULTICAST_LOOP: ::c_int = 19; +pub const IPPROTO_IPV6: ::c_int = 41; // or this one, for that matter + +// STAT Stuff +pub const S_IFMT: ::c_int = 0xf000; +pub const S_IFIFO: ::c_int = 0x1000; +pub const S_IFCHR: ::c_int = 0x2000; +pub const S_IFDIR: ::c_int = 0x4000; +pub const S_IFBLK: ::c_int = 0x6000; +pub const S_IFREG: ::c_int = 0x8000; +pub const S_IFLNK: ::c_int = 0xa000; +pub const S_IFSHM: ::c_int = 0xb000; +pub const S_IFDEVMEM: ::c_int = 0xd000; +pub const S_IFSOCK: ::c_int = 0xc000; +pub const S_ISUID: ::c_int = 0x0800; +pub const S_ISGID: ::c_int = 0x0400; +pub const S_ISTXT: ::c_int = 0x0200; +pub const S_IRUSR: ::c_int = 0x0100; +pub const S_IWUSR: ::c_int = 0x0080; +pub const S_IXUSR: ::c_int = 0x0040; +pub const S_IRWXU: ::c_int = 0x01c0; +pub const S_IRGRP: ::c_int = 0x0020; +pub const S_IWGRP: ::c_int = 0x0010; +pub const S_IXGRP: ::c_int = 0x0008; +pub const S_IRWXG: ::c_int = 0x0038; +pub const S_IROTH: ::c_int = 0x0004; +pub const S_IWOTH: ::c_int = 0x0002; +pub const S_IXOTH: ::c_int = 0x0001; +pub const S_IRWXO: ::c_int = 0x0007; + +pub const SOL_SOCKET: ::c_int = 0xffff; +pub const SO_BROADCAST: ::c_int = 0x001e; +pub const SO_SNDTIMEO: ::c_int = 0x1005; +pub const SO_RCVTIMEO: ::c_int = 0x1006; +pub const SOCK_STREAM: ::c_int = 1; +pub const SOCK_DGRAM: ::c_int = 2; +pub const SOCK_RAW: ::c_int = 3; +pub const SOCK_RDM: ::c_int = 4; +pub const SOCK_SEQPACKET: ::c_int = 5; +pub const SOCK_PACKET: ::c_int = 10; +pub const SO_DEBUG: ::c_int = 0x0001; +pub const SO_REUSEADDR: ::c_int = 0x0004; +pub const SO_KEEPALIVE: ::c_int = 0x0008; +pub const SO_DONTROUTE: ::c_int = 0x0010; +pub const SO_RCVLOWAT: ::c_int = 0x0012; + +pub const _SS_MAXSIZE: usize = 128; +pub const _SS_ALIGNSIZE: usize = size_of::<u32>(); +pub const _SS_PAD1SIZE: usize = +    (_SS_ALIGNSIZE - size_of::<::c_uchar>() - size_of::<::sa_family_t>()); +pub const _SS_PAD2SIZE: usize = (_SS_MAXSIZE +    - size_of::<::c_uchar>() +    - size_of::<::sa_family_t>() +    - _SS_PAD1SIZE +    - _SS_ALIGNSIZE); + +pub const MSG_OOB: ::c_int = 0x0001; +pub const MSG_PEEK: ::c_int = 0x0002; +pub const MSG_DONTROUTE: ::c_int = 0x0004; +pub const MSG_EOR: ::c_int = 0x0008; +pub const MSG_TRUNC: ::c_int = 0x0010; +pub const MSG_CTRUNC: ::c_int = 0x0020; +pub const MSG_WAITALL: ::c_int = 0x0040; +pub const MSG_DONTWAIT: ::c_int = 0x0080; +pub const MSG_EOF: ::c_int = 0x0100; +pub const MSG_EXP: ::c_int = 0x0200; +pub const MSG_MBUF: ::c_int = 0x0400; +pub const MSG_NOTIFICATION: ::c_int = 0x0800; +pub const MSG_COMPAT: ::c_int = 0x8000; + +pub const AF_UNSPEC: ::c_int = 0; +pub const AF_LOCAL: ::c_int = 1; +pub const AF_UNIX: ::c_int = AF_LOCAL; +pub const AF_INET: ::c_int = 2; +pub const AF_NETLINK: ::c_int = 16; +pub const AF_ROUTE: ::c_int = 17; +pub const AF_LINK: ::c_int = 18; +pub const AF_PACKET: ::c_int = 19; +pub const pseudo_AF_KEY: ::c_int = 27; +pub const AF_KEY: ::c_int = pseudo_AF_KEY; +pub const AF_INET6: ::c_int = 28; +pub const AF_SOCKDEV: ::c_int = 31; +pub const AF_TIPC: ::c_int = 33; +pub const AF_MIPC: ::c_int = 34; +pub const AF_MIPC_SAFE: ::c_int = 35; +pub const AF_MAX: ::c_int = 36; + +pub const SHUT_RD: ::c_int = 0; +pub const SHUT_WR: ::c_int = 1; +pub const SHUT_RDWR: ::c_int = 2; + +pub const IPPROTO_TCP: ::c_int = 6; +pub const TCP_NODELAY: ::c_int = 1; +pub const TCP_MAXSEG: ::c_int = 2; +pub const TCP_NOPUSH: ::c_int = 3; +pub const TCP_KEEPIDLE: ::c_int = 4; +pub const TCP_KEEPINTVL: ::c_int = 5; +pub const TCP_KEEPCNT: ::c_int = 6; +pub const SO_ERROR: ::c_int = 4; + +// IO Lib Definitions: + +pub const FIONREAD: ::c_int = 1; +pub const FIOFLUSH: ::c_int = 2; +pub const FIOOPTIONS: ::c_int = 3; +pub const FIOBAUDRATE: ::c_int = 4; +pub const FIODISKFORMAT: ::c_int = 5; +pub const FIODISKINIT: ::c_int = 6; +pub const FIOSEEK: ::c_int = 7; +pub const FIOWHERE: ::c_int = 8; +pub const FIODIRENTRY: ::c_int = 9; +pub const FIORENAME: ::c_int = 10; +pub const FIOREADYCHANGE: ::c_int = 11; +pub const FIOWRITE: ::c_int = 12; +pub const FIODISKCHANGE: ::c_int = 13; +pub const FIOCANCEL: ::c_int = 14; +pub const FIOSQUEEZE: ::c_int = 15; +pub const FIONBIO: ::c_int = -1878786032; // it goes on ... +pub const _POSIX_PATH_MAX: ::c_int = 256; + +// Some poll stuff +pub const POLLIN: ::c_short = 0x0001; +pub const POLLPRI: ::c_short = 0x0002; +pub const POLLOUT: ::c_short = 0x0004; +pub const POLLRDNORM: ::c_short = 0x0040; +pub const POLLWRNORM: ::c_short = POLLOUT; +pub const POLLRDBAND: ::c_short = 0x0080; +pub const POLLWRBAND: ::c_short = 0x0100; +pub const POLLER: ::c_short = 0x0008; +pub const POLLHUP: ::c_short = 0x0010; +pub const POLLNVAL: ::c_short = 0x0020; + +//Some Fcntlcom Stuff (look at fcntlcom.h to find definitions) +pub const FD_CLOEXEC: ::c_int = 1; +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; +pub const F_GETOWN: ::c_int = 5; +pub const F_SETOWN: ::c_int = 6; +pub const F_GETLK: ::c_int = 7; +pub const F_SETLK: ::c_int = 8; +pub const F_SETLKW: ::c_int = 9; +pub const F_DUPFD_CLOEXEC: ::c_int = 14; + +//Some Dirent.h stuff +pub const DT_UNKNOWN: ::c_uchar = 0x0; +pub const DT_FIFO: ::c_uchar = 0x1; +pub const DT_CHR: ::c_uchar = 0x2; +pub const DT_DIR: ::c_uchar = 0x4; +pub const DT_BLK: ::c_uchar = 0x6; +pub const DT_REG: ::c_uchar = 0x8; +pub const DT_LNK: ::c_uchar = 0xA; +pub const DT_SOCK: ::c_uchar = 0xC; +pub const DT_WHT: ::c_uchar = 0xE; + +// Other Random Stuff +pub const VXSIM_EWOULDBLOCK: ::c_int = 70; +pub const IPV6_ADD_MEMBERSHIP: ::c_int = 20; +pub const IPV6_DROP_MEMBERSHIP: ::c_int = 21; + +pub const SIG_DFL: sighandler_t = 0 as sighandler_t; +pub const SIG_IGN: sighandler_t = 1 as sighandler_t; +pub const SIG_ERR: sighandler_t = !0 as sighandler_t; + +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 SIGEMT: ::c_int = 7; +pub const SIGFPE: ::c_int = 8; +pub const SIGKILL: ::c_int = 9; +pub const SIGBUS: ::c_int = 10; +pub const SIGSEGV: ::c_int = 11; +pub const SIGFMT: ::c_int = 12; +pub const SIGPIPE: ::c_int = 13; +pub const SIGALRM: ::c_int = 14; +pub const SIGTERM: ::c_int = 15; +pub const SIGCNCL: ::c_int = 16; +pub const SIGSTOP: ::c_int = 17; +pub const SIGTSTP: ::c_int = 18; +pub const SIGCONT: ::c_int = 19; +pub const SIGCHLD: ::c_int = 20; +pub const SIGTTIN: ::c_int = 21; +pub const SIGTTOU: ::c_int = 22; + +pub const SIG_BLOCK: ::c_int = 1; +pub const SIG_UNBLOCK: ::c_int = 2; +pub const SIG_SETMASK: ::c_int = 3; + +pub const SI_SYNC: ::c_int = 0; +pub const SI_USER: ::c_int = -1; +pub const SI_QUEUE: ::c_int = -2; +pub const SI_TIMER: ::c_int = -3; +pub const SI_ASYNCIO: ::c_int = -4; +pub const SI_MESGQ: ::c_int = -5; +pub const SI_CHILD: ::c_int = -6; +pub const SI_KILL: ::c_int = SI_USER; + +// vxParams.h definitions +pub const _PARM_NAME_MAX: usize = 255; +pub const _PARM_PATH_MAX: usize = 1024; + +// WAIT STUFF +pub const WNOHANG: ::c_int = 0x01; +pub const WUNTRACED: ::c_int = 0x02; + +const PTHREAD_MUTEXATTR_INITIALIZER: pthread_mutexattr_t = +    pthread_mutexattr_t { +        mutexAttrStatus: PTHREAD_INITIALIZED_OBJ, +        mutexAttrProtocol: PTHREAD_PRIO_NONE, +        mutexAttrPrioceiling: 0, +        mutexAttrType: PTHREAD_MUTEX_DEFAULT, +        mutexAttrPshared: 1, +    }; +pub const PTHREAD_MUTEX_INITIALIZER: pthread_mutex_t = pthread_mutex_t { +    mutexSemId: null_mut(), +    mutexValid: PTHREAD_VALID_OBJ, +    mutexInitted: PTHREAD_UNUSED_YET_OBJ, +    mutexCondRefCount: 0, +    mutexSavPriority: 0, +    mutexAttr: PTHREAD_MUTEXATTR_INITIALIZER, +    mutexSemName: [0; PTHREAD_SHARED_SEM_NAME_MAX], +}; + +const PTHREAD_CONDATTR_INITIALIZER: pthread_condattr_t = pthread_condattr_t { +    condAttrStatus: 0, +    condAttrPshared: 0, +    _CondAttrClockId: CLOCK_REALTIME, +}; +pub const PTHREAD_COND_INITIALIZER: pthread_cond_t = pthread_cond_t { +    condSemId: null_mut(), +    condValid: PTHREAD_VALID_OBJ, +    condInitted: PTHREAD_UNUSED_YET_OBJ, +    condRefCount: 0, +    condMutex: null_mut(), +    condAttr: PTHREAD_CONDATTR_INITIALIZER, +    condSemName: [0; PTHREAD_SHARED_SEM_NAME_MAX], +}; + +const PTHREAD_RWLOCKATTR_INITIALIZER: pthread_rwlockattr_t = +    pthread_rwlockattr_t { +        rwlockAttrStatus: PTHREAD_INITIALIZED_OBJ, +        rwlockAttrMaxReaders: 0, +    }; +pub const PTHREAD_RWLOCK_INITIALIZER: pthread_rwlock_t = pthread_rwlock_t { +    rwlockSemId: null_mut(), +    rwlockReadersRefCount: 0, +    rwlockValid: PTHREAD_VALID_OBJ, +    rwlockInitted: PTHREAD_UNUSED_YET_OBJ, +    rwlockAttr: PTHREAD_RWLOCKATTR_INITIALIZER, +    rwlockName: [0; PTHREAD_SHARED_SEM_NAME_MAX], +}; + +pub const SEEK_SET: ::c_int = 0; +pub const SEEK_CUR: ::c_int = 1; +pub const SEEK_END: ::c_int = 2; + +// rtpLibCommon.h +pub const VX_RTP_NAME_LENGTH: usize = 255; + +//Some unsupported stuff +pub const _SC_GETPW_R_SIZE_MAX: ::c_int = -1; // Via unistd.h +pub const _SC_PAGESIZE: ::c_int = 64; +pub const O_ACCMODE: ::c_int = 3; +pub const O_CLOEXEC: ::c_int = 0x100000; // fcntlcom +pub const O_EXCL: ::c_int = 0x0800; +pub const O_CREAT: ::c_int = 0x0200; +pub const O_TRUNC: ::c_int = 0x0400; +pub const O_APPEND: ::c_int = 0x0008; +pub const O_RDWR: ::c_int = 2; +pub const O_WRONLY: ::c_int = 1; +pub const O_RDONLY: ::c_int = 0; +pub const O_NONBLOCK: ::c_int = 0x4; + +#[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; +    pub fn isalpha(c: c_int) -> c_int; +    pub fn iscntrl(c: c_int) -> c_int; +    pub fn isdigit(c: c_int) -> c_int; +    pub fn isgraph(c: c_int) -> c_int; +    pub fn islower(c: c_int) -> c_int; +    pub fn isprint(c: c_int) -> c_int; +    pub fn ispunct(c: c_int) -> c_int; +    pub fn isspace(c: c_int) -> c_int; +    pub fn isupper(c: c_int) -> c_int; +    pub fn isxdigit(c: c_int) -> c_int; +    pub fn tolower(c: c_int) -> c_int; +    pub fn toupper(c: c_int) -> c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "fopen$UNIX2003" +    )] +    pub fn fopen(filename: *const c_char, mode: *const c_char) -> *mut FILE; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "freopen$UNIX2003" +    )] +    pub fn freopen( +        filename: *const c_char, +        mode: *const c_char, +        file: *mut FILE, +    ) -> *mut FILE; +    pub fn fflush(file: *mut FILE) -> c_int; +    pub fn fclose(file: *mut FILE) -> c_int; +    pub fn remove(filename: *const c_char) -> c_int; +    pub fn rename(oldname: *const c_char, newname: *const c_char) -> c_int; +    pub fn tmpfile() -> *mut FILE; +    pub fn setvbuf( +        stream: *mut FILE, +        buffer: *mut c_char, +        mode: c_int, +        size: size_t, +    ) -> c_int; +    pub fn setbuf(stream: *mut FILE, buf: *mut c_char); +    pub fn getchar() -> c_int; +    pub fn putchar(c: c_int) -> c_int; +    pub fn fgetc(stream: *mut FILE) -> c_int; +    pub fn fgets(buf: *mut c_char, n: c_int, stream: *mut FILE) +        -> *mut c_char; +    pub fn fputc(c: c_int, stream: *mut FILE) -> c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "fputs$UNIX2003" +    )] +    pub fn fputs(s: *const c_char, stream: *mut FILE) -> c_int; +    pub fn puts(s: *const c_char) -> c_int; +    pub fn ungetc(c: c_int, stream: *mut FILE) -> c_int; +    pub fn fread( +        ptr: *mut c_void, +        size: size_t, +        nobj: size_t, +        stream: *mut FILE, +    ) -> size_t; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "fwrite$UNIX2003" +    )] +    pub fn fwrite( +        ptr: *const c_void, +        size: size_t, +        nobj: size_t, +        stream: *mut FILE, +    ) -> size_t; +    pub fn fseek(stream: *mut FILE, offset: c_long, whence: c_int) -> c_int; +    pub fn ftell(stream: *mut FILE) -> c_long; +    pub fn rewind(stream: *mut FILE); +    #[cfg_attr(target_os = "netbsd", link_name = "__fgetpos50")] +    pub fn fgetpos(stream: *mut FILE, ptr: *mut fpos_t) -> c_int; +    #[cfg_attr(target_os = "netbsd", link_name = "__fsetpos50")] +    pub fn fsetpos(stream: *mut FILE, ptr: *const fpos_t) -> c_int; +    pub fn feof(stream: *mut FILE) -> c_int; +    pub fn ferror(stream: *mut FILE) -> c_int; +    pub fn perror(s: *const c_char); +    pub fn atoi(s: *const c_char) -> c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "strtod$UNIX2003" +    )] +    pub fn strtod(s: *const c_char, endp: *mut *mut c_char) -> c_double; +    pub fn strtol( +        s: *const c_char, +        endp: *mut *mut c_char, +        base: c_int, +    ) -> c_long; +    pub fn strtoul( +        s: *const c_char, +        endp: *mut *mut c_char, +        base: c_int, +    ) -> c_ulong; +    pub fn calloc(nobj: size_t, size: size_t) -> *mut c_void; +    pub fn malloc(size: size_t) -> *mut c_void; +    pub fn realloc(p: *mut c_void, size: size_t) -> *mut c_void; +    pub fn free(p: *mut c_void); +    pub fn abort() -> !; +    pub fn exit(status: c_int) -> !; +    //    pub fn _exit(status: c_int) -> !; +    pub fn atexit(cb: extern fn()) -> c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "system$UNIX2003" +    )] +    pub fn system(s: *const c_char) -> c_int; +    pub fn getenv(s: *const c_char) -> *mut c_char; + +    pub fn strcpy(dst: *mut c_char, src: *const c_char) -> *mut c_char; +    pub fn strncpy( +        dst: *mut c_char, +        src: *const c_char, +        n: size_t, +    ) -> *mut c_char; +    pub fn strcat(s: *mut c_char, ct: *const c_char) -> *mut c_char; +    pub fn strncat( +        s: *mut c_char, +        ct: *const c_char, +        n: size_t, +    ) -> *mut c_char; +    pub fn strcmp(cs: *const c_char, ct: *const c_char) -> c_int; +    pub fn strncmp(cs: *const c_char, ct: *const c_char, n: size_t) -> c_int; +    pub fn strcoll(cs: *const c_char, ct: *const c_char) -> c_int; +    pub fn strchr(cs: *const c_char, c: c_int) -> *mut c_char; +    pub fn strrchr(cs: *const c_char, c: c_int) -> *mut c_char; +    pub fn strspn(cs: *const c_char, ct: *const c_char) -> size_t; +    pub fn strcspn(cs: *const c_char, ct: *const c_char) -> size_t; +    pub fn strdup(cs: *const c_char) -> *mut c_char; +    pub fn strpbrk(cs: *const c_char, ct: *const c_char) -> *mut c_char; +    pub fn strstr(cs: *const c_char, ct: *const c_char) -> *mut c_char; +    pub fn strcasecmp(s1: *const c_char, s2: *const c_char) -> c_int; +    pub fn strncasecmp( +        s1: *const c_char, +        s2: *const c_char, +        n: size_t, +    ) -> c_int; +    pub fn strlen(cs: *const c_char) -> size_t; +    pub fn strnlen(cs: *const c_char, maxlen: size_t) -> size_t; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "strerror$UNIX2003" +    )] +    pub fn strerror(n: c_int) -> *mut c_char; +    pub fn strtok(s: *mut c_char, t: *const c_char) -> *mut c_char; +    pub fn strxfrm(s: *mut c_char, ct: *const c_char, n: size_t) -> size_t; +    pub fn wcslen(buf: *const wchar_t) -> size_t; +    pub fn wcstombs( +        dest: *mut c_char, +        src: *const wchar_t, +        n: size_t, +    ) -> ::size_t; + +    pub fn memchr(cx: *const c_void, c: c_int, n: size_t) -> *mut c_void; +    pub fn memcmp(cx: *const c_void, ct: *const c_void, n: size_t) -> c_int; +    pub fn memcpy( +        dest: *mut c_void, +        src: *const c_void, +        n: size_t, +    ) -> *mut c_void; +    pub fn memmove( +        dest: *mut c_void, +        src: *const c_void, +        n: size_t, +    ) -> *mut c_void; +    pub fn memset(dest: *mut c_void, c: c_int, n: size_t) -> *mut c_void; +} + +extern { +    #[cfg_attr(target_os = "netbsd", link_name = "__getpwnam50")] +    pub fn getpwnam(name: *const ::c_char) -> *mut passwd; +    #[cfg_attr(target_os = "netbsd", link_name = "__getpwuid50")] +    pub fn getpwuid(uid: ::uid_t) -> *mut passwd; + +    pub fn fprintf( +        stream: *mut ::FILE, +        format: *const ::c_char, +        ... +    ) -> ::c_int; +    pub fn printf(format: *const ::c_char, ...) -> ::c_int; +    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; +    pub fn fscanf( +        stream: *mut ::FILE, +        format: *const ::c_char, +        ... +    ) -> ::c_int; +    pub fn scanf(format: *const ::c_char, ...) -> ::c_int; +    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; + +    pub fn stat(path: *const c_char, buf: *mut stat) -> ::c_int; + +    pub fn pclose(stream: *mut ::FILE) -> ::c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "fdopen$UNIX2003" +    )] +    pub fn fdopen(fd: ::c_int, mode: *const c_char) -> *mut ::FILE; +    pub fn fileno(stream: *mut ::FILE) -> ::c_int; + +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "open$UNIX2003" +    )] +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "creat$UNIX2003" +    )] +    pub fn creat(path: *const c_char, mode: mode_t) -> ::c_int; + +    pub fn fdopendir(fd: ::c_int) -> *mut ::DIR; + +    pub fn rewinddir(dirp: *mut ::DIR); + +    pub fn openat( +        dirfd: ::c_int, +        pathname: *const ::c_char, +        flags: ::c_int, +        ... +    ) -> ::c_int; +    pub fn fchmodat( +        dirfd: ::c_int, +        pathname: *const ::c_char, +        mode: ::mode_t, +        flags: ::c_int, +    ) -> ::c_int; +    pub fn fchown(fd: ::c_int, owner: ::uid_t, group: ::gid_t) -> ::c_int; +    pub fn fchownat( +        dirfd: ::c_int, +        pathname: *const ::c_char, +        owner: ::uid_t, +        group: ::gid_t, +        flags: ::c_int, +    ) -> ::c_int; +    #[cfg_attr(target_os = "macos", link_name = "fstatat$INODE64")] +    #[cfg_attr(target_os = "freebsd", link_name = "fstatat@FBSD_1.1")] +    pub fn fstatat( +        dirfd: ::c_int, +        pathname: *const ::c_char, +        buf: *mut stat, +        flags: ::c_int, +    ) -> ::c_int; +    pub fn linkat( +        olddirfd: ::c_int, +        oldpath: *const ::c_char, +        newdirfd: ::c_int, +        newpath: *const ::c_char, +        flags: ::c_int, +    ) -> ::c_int; +    pub fn mkdirat( +        dirfd: ::c_int, +        pathname: *const ::c_char, +        mode: ::mode_t, +    ) -> ::c_int; +    pub fn readlinkat( +        dirfd: ::c_int, +        pathname: *const ::c_char, +        buf: *mut ::c_char, +        bufsiz: ::size_t, +    ) -> ::ssize_t; +    pub fn renameat( +        olddirfd: ::c_int, +        oldpath: *const ::c_char, +        newdirfd: ::c_int, +        newpath: *const ::c_char, +    ) -> ::c_int; +    pub fn symlinkat( +        target: *const ::c_char, +        newdirfd: ::c_int, +        linkpath: *const ::c_char, +    ) -> ::c_int; + +    pub fn access(path: *const c_char, amode: ::c_int) -> ::c_int; +    pub fn alarm(seconds: ::c_uint) -> ::c_uint; +    pub fn fchdir(dirfd: ::c_int) -> ::c_int; +    pub fn chown(path: *const c_char, uid: uid_t, gid: gid_t) -> ::c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "lchown$UNIX2003" +    )] +    pub fn lchown(path: *const c_char, uid: uid_t, gid: gid_t) -> ::c_int; +    pub fn execl(path: *const c_char, arg0: *const c_char, ...) -> ::c_int; +    pub fn execle( +        path: *const ::c_char, +        arg0: *const ::c_char, +        ... +    ) -> ::c_int; +    pub fn execlp( +        file: *const ::c_char, +        arg0: *const ::c_char, +        ... +    ) -> ::c_int; +    pub fn execv(prog: *const c_char, argv: *const *const c_char) -> ::c_int; +    pub fn execve( +        prog: *const c_char, +        argv: *const *const c_char, +        envp: *const *const c_char, +    ) -> ::c_int; +    /* +    pub fn execvp(c: *const c_char, +    argv: *const *const c_char) -> ::c_int; +     */ +    //    pub fn fork() -> pid_t; +    pub fn fpathconf(filedes: ::c_int, name: ::c_int) -> c_long; +    pub fn getegid() -> gid_t; +    pub fn geteuid() -> uid_t; +    pub fn getgroups(ngroups_max: ::c_int, groups: *mut gid_t) -> ::c_int; +    pub fn getlogin() -> *mut c_char; +    pub fn getopt( +        argc: ::c_int, +        argv: *const *mut c_char, +        optstr: *const c_char, +    ) -> ::c_int; +    pub fn pathconf(path: *const c_char, name: ::c_int) -> c_long; +    pub fn pause() -> ::c_int; +    pub fn seteuid(uid: uid_t) -> ::c_int; +    pub fn setegid(gid: gid_t) -> ::c_int; +    pub fn setpgid(pid: pid_t, pgid: pid_t) -> ::c_int; +    pub fn setsid() -> pid_t; +    pub fn sleep(secs: ::c_uint) -> ::c_uint; +    pub fn tcgetpgrp(fd: ::c_int) -> pid_t; +    pub fn tcsetpgrp(fd: ::c_int, pgrp: ::pid_t) -> ::c_int; +    pub fn ttyname(fd: ::c_int) -> *mut c_char; +    pub fn wait(status: *mut ::c_int) -> pid_t; +    /* +    pub fn pread(fd: ::c_int, buf: *mut ::c_void, count: ::size_t, +    offset: off_t) -> ::ssize_t; +    #[cfg_attr(all(target_os = "macos", target_arch = "x86"), +    link_name = "pwrite$UNIX2003")] +    pub fn pwrite(fd: ::c_int, buf: *const ::c_void, count: ::size_t, +    offset: off_t) -> ::ssize_t; +     */ +    pub fn umask(mask: mode_t) -> mode_t; + +    //    #[cfg_attr(target_os = "netbsd", link_name = "__utime50")] +    //    pub fn utime(file: *const c_char, buf: *const utimbuf) -> ::c_int; + +    /* +    #[cfg_attr(all(target_os = "macos", target_arch = "x86"), +    link_name = "kill$UNIX2003")] +    pub fn kill(pid: pid_t, sig: ::c_int) -> ::c_int; +     */ +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "killpg$UNIX2003" +    )] +    pub fn killpg(pgrp: pid_t, sig: ::c_int) -> ::c_int; + +    pub fn mlock(addr: *const ::c_void, len: ::size_t) -> ::c_int; +    pub fn munlock(addr: *const ::c_void, len: ::size_t) -> ::c_int; +    pub fn mlockall(flags: ::c_int) -> ::c_int; +    pub fn munlockall() -> ::c_int; + +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "mmap$UNIX2003" +    )] +    pub fn mmap( +        addr: *mut ::c_void, +        len: ::size_t, +        prot: ::c_int, +        flags: ::c_int, +        fd: ::c_int, +        offset: off_t, +    ) -> *mut ::c_void; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "munmap$UNIX2003" +    )] +    pub fn munmap(addr: *mut ::c_void, len: ::size_t) -> ::c_int; + +    pub fn if_nametoindex(ifname: *const c_char) -> ::c_uint; +    pub fn if_indextoname( +        ifindex: ::c_uint, +        ifname: *mut ::c_char, +    ) -> *mut ::c_char; + +    pub fn truncate(path: *const c_char, length: off_t) -> ::c_int; + +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "getrlimit$UNIX2003" +    )] +    pub fn getrlimit(resource: ::c_int, rlim: *mut rlimit) -> ::c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "setrlimit$UNIX2003" +    )] +    pub fn setrlimit(resource: ::c_int, rlim: *const rlimit) -> ::c_int; +    //    #[cfg_attr(target_os = "netbsd", link_name = "__getrusage50")] +    //    pub fn getrusage(resource: ::c_int, usage: *mut rusage) -> ::c_int; + +    /* +    #[cfg_attr(any(target_os = "macos", target_os = "ios"), +    link_name = "realpath$DARWIN_EXTSN")] +    pub fn realpath(pathname: *const ::c_char, resolved: *mut ::c_char) +                    -> *mut ::c_char; +     */ +    pub fn flock(fd: ::c_int, operation: ::c_int) -> ::c_int; + +    #[cfg_attr(target_os = "netbsd", link_name = "__gettimeofday50")] +    pub fn gettimeofday(tp: *mut ::timeval, tz: *mut ::c_void) -> ::c_int; +    pub fn pthread_exit(value: *mut ::c_void); +    pub fn pthread_attr_setdetachstate( +        attr: *mut ::pthread_attr_t, +        state: ::c_int, +    ) -> ::c_int; + +    pub fn strerror_r( +        errnum: ::c_int, +        buf: *mut c_char, +        buflen: ::size_t, +    ) -> ::c_int; + +    pub fn sigaction( +        signum: ::c_int, +        act: *const sigaction, +        oldact: *mut sigaction, +    ) -> ::c_int; + +    #[cfg_attr(target_os = "netbsd", link_name = "__utimes50")] +    pub fn utimes( +        filename: *const ::c_char, +        times: *const ::timeval, +    ) -> ::c_int; +    pub fn dlopen(filename: *const ::c_char, flag: ::c_int) -> *mut ::c_void; +    pub fn dlerror() -> *mut ::c_char; +    pub fn dlsym( +        handle: *mut ::c_void, +        symbol: *const ::c_char, +    ) -> *mut ::c_void; +    pub fn dlclose(handle: *mut ::c_void) -> ::c_int; +    pub fn res_init() -> ::c_int; +    /* +    #[cfg_attr(target_os = "netbsd", link_name = "__gmtime_r50")] +    pub fn gmtime_r(time_p: *const time_t, result: *mut tm) -> *mut tm; +    #[cfg_attr(target_os = "netbsd", link_name = "__localtime_r50")] +    pub fn localtime_r(time_p: *const time_t, result: *mut tm) -> *mut tm; +    #[cfg_attr(all(target_os = "macos", target_arch = "x86"), +    link_name = "mktime$UNIX2003")] +    #[cfg_attr(target_os = "netbsd", link_name = "__mktime50")] +    pub fn mktime(tm: *mut tm) -> time_t; +    #[cfg_attr(target_os = "netbsd", link_name = "__time50")] +    pub fn time(time: *mut time_t) -> time_t; +    #[cfg_attr(target_os = "netbsd", link_name = "__gmtime50")] +    pub fn gmtime(time_p: *const time_t) -> *mut tm; +    #[cfg_attr(target_os = "netbsd", link_name = "__locatime50")] +    pub fn localtime(time_p: *const time_t) -> *mut tm; +     */ +    #[cfg_attr(target_os = "netbsd", link_name = "__difftime50")] +    pub fn difftime(time1: time_t, time0: time_t) -> ::c_double; + +    #[cfg_attr(target_os = "netbsd", link_name = "__mknod50")] +    #[cfg_attr(target_os = "freebsd", link_name = "mknod@FBSD_1.0")] +    pub fn mknod( +        pathname: *const ::c_char, +        mode: ::mode_t, +        dev: ::dev_t, +    ) -> ::c_int; +    pub fn gethostname(name: *mut ::c_char, len: ::size_t) -> ::c_int; +    //    pub fn getservbyname(name: *const ::c_char, +    //                         proto: *const ::c_char) -> *mut servent; +    //    pub fn getprotobyname(name: *const ::c_char) -> *mut protoent; +    //    pub fn getprotobynumber(proto: ::c_int) -> *mut protoent; +    pub fn chroot(name: *const ::c_char) -> ::c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "usleep$UNIX2003" +    )] +    pub fn usleep(secs: ::c_uint) -> ::c_int; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "putenv$UNIX2003" +    )] +    pub fn putenv(string: *mut c_char) -> ::c_int; +    #[cfg_attr(target_os = "netbsd", link_name = "__select50")] +    //    pub fn select(nfds: ::c_int, +    //                  readfs: *mut fd_set, +    //                  writefds: *mut fd_set, +    //                  errorfds: *mut fd_set, +    //                  timeout: *mut timeval) -> ::c_int; +    #[cfg_attr(target_os = "netbsd", link_name = "__setlocale50")] +    pub fn setlocale( +        category: ::c_int, +        locale: *const ::c_char, +    ) -> *mut ::c_char; +    //    pub fn localeconv() -> *mut lconv; + +    pub fn sigprocmask( +        how: ::c_int, +        set: *const sigset_t, +        oldset: *mut sigset_t, +    ) -> ::c_int; +    #[cfg_attr(target_os = "netbsd", link_name = "__sigpending14")] +    pub fn sigpending(set: *mut sigset_t) -> ::c_int; + +    pub fn getsid(pid: pid_t) -> pid_t; + +    pub fn mkfifo(path: *const c_char, mode: mode_t) -> ::c_int; + +    pub fn fseeko( +        stream: *mut ::FILE, +        offset: ::off_t, +        whence: ::c_int, +    ) -> ::c_int; +    pub fn ftello(stream: *mut ::FILE) -> ::off_t; +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "tcdrain$UNIX2003" +    )] +    pub fn tcdrain(fd: ::c_int) -> ::c_int; +    pub fn tcflow(fd: ::c_int, action: ::c_int) -> ::c_int; +    pub fn tcflush(fd: ::c_int, action: ::c_int) -> ::c_int; +    pub fn tcgetsid(fd: ::c_int) -> ::pid_t; +    pub fn tcsendbreak(fd: ::c_int, duration: ::c_int) -> ::c_int; +    pub fn mkstemp(template: *mut ::c_char) -> ::c_int; +    pub fn mkdtemp(template: *mut ::c_char) -> *mut ::c_char; + +    pub fn tmpnam(ptr: *mut ::c_char) -> *mut ::c_char; + +    pub fn openlog(ident: *const ::c_char, logopt: ::c_int, facility: ::c_int); +    pub fn closelog(); +    pub fn setlogmask(maskpri: ::c_int) -> ::c_int; +    #[cfg_attr(target_os = "macos", link_name = "syslog$DARWIN_EXTSN")] +    pub fn syslog(priority: ::c_int, message: *const ::c_char, ...); +    #[cfg_attr( +        all(target_os = "macos", target_arch = "x86"), +        link_name = "nice$UNIX2003" +    )] +    pub fn nice(incr: ::c_int) -> ::c_int; + +    pub fn grantpt(fd: ::c_int) -> ::c_int; +    pub fn posix_openpt(flags: ::c_int) -> ::c_int; +    pub fn ptsname(fd: ::c_int) -> *mut ::c_char; +    pub fn unlockpt(fd: ::c_int) -> ::c_int; + +    pub fn strcasestr(cs: *const c_char, ct: *const c_char) -> *mut c_char; +    pub fn getline( +        lineptr: *mut *mut c_char, +        n: *mut size_t, +        stream: *mut FILE, +    ) -> ssize_t; + +    pub fn _rtld_dladdr(addr: *const ::c_void, info: *mut Dl_info) -> ::c_int; +} + +extern { +    // this is gonna be a big one + +    // stdlib.h +    // This function may not be defined for armv7 +    pub fn memalign(block_size: ::size_t, size_arg: ::size_t) +        -> *mut ::c_void; + +    // ioLib.h +    pub fn getcwd(buf: *mut ::c_char, size: ::size_t) -> *mut ::c_char; + +    // ioLib.h +    pub fn chdir(attr: *const ::c_char) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutexattr_init( +        /* PTHREAD STUFF */ +        attr: *mut pthread_mutexattr_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutexattr_destroy( +        attr: *mut pthread_mutexattr_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutexattr_settype( +        pAttr: *mut ::pthread_mutexattr_t, +        pType: ::c_int, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutex_init( +        mutex: *mut pthread_mutex_t, +        attr: *const pthread_mutexattr_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutex_destroy(mutex: *mut pthread_mutex_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutex_lock(mutex: *mut pthread_mutex_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutex_trylock(mutex: *mut pthread_mutex_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutex_timedlock( +        attr: *mut pthread_mutex_t, +        spec: *const timespec, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_mutex_unlock(mutex: *mut pthread_mutex_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_attr_setname( +        pAttr: *mut ::pthread_attr_t, +        name: *mut ::c_char, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_attr_setstacksize( +        attr: *mut ::pthread_attr_t, +        stacksize: ::size_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_attr_getstacksize( +        attr: *const ::pthread_attr_t, +        size: *mut ::size_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_attr_init(attr: *mut ::pthread_attr_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_create( +        pThread: *mut ::pthread_t, +        pAttr: *const ::pthread_attr_t, +        start_routine: extern fn(*mut ::c_void) -> *mut ::c_void, +        value: *mut ::c_void, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_attr_destroy(thread: *mut ::pthread_attr_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_detach(thread: ::pthread_t) -> ::c_int; + +    // int pthread_atfork (void (*)(void), void (*)(void), void (*)(void)); +    pub fn pthread_atfork( +        prepare: ::Option<unsafe extern fn()>, +        parent: ::Option<unsafe extern fn()>, +        child: ::Option<unsafe extern fn()>, +    ) -> ::c_int; +    // stat.h +    pub fn fstat(fildes: ::c_int, buf: *mut stat) -> ::c_int; + +    // stat.h +    pub fn lstat(path: *const ::c_char, buf: *mut stat) -> ::c_int; + +    // unistd.h +    pub fn ftruncate(fd: ::c_int, length: off_t) -> ::c_int; + +    // dirent.h +    pub fn readdir_r( +        pDir: *mut ::DIR, +        entry: *mut ::dirent, +        result: *mut *mut ::dirent, +    ) -> ::c_int; + +    // dirent.h +    pub fn readdir(pDir: *mut ::DIR) -> *mut ::dirent; + +    // fcntl.h or +    // ioLib.h +    pub fn open( +        // this might be hacked +        path: *const ::c_char, +        oflag: ::c_int, +        ... +    ) -> ::c_int; + +    // poll.h +    pub fn poll(fds: *mut pollfd, nfds: nfds_t, timeout: ::c_int) -> ::c_int; + +    // pthread.h +    pub fn pthread_condattr_init(attr: *mut ::pthread_condattr_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_condattr_destroy( +        attr: *mut ::pthread_condattr_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_condattr_getclock( +        pAttr: *const ::pthread_condattr_t, +        pClockId: *mut ::clockid_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_condattr_setclock( +        pAttr: *mut ::pthread_condattr_t, +        clockId: ::clockid_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_cond_init( +        cond: *mut ::pthread_cond_t, +        attr: *const ::pthread_condattr_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_cond_destroy(cond: *mut pthread_cond_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_cond_signal(cond: *mut ::pthread_cond_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_cond_broadcast(cond: *mut ::pthread_cond_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_cond_wait( +        cond: *mut ::pthread_cond_t, +        mutex: *mut ::pthread_mutex_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlockattr_init( +        attr: *mut ::pthread_rwlockattr_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlockattr_destroy( +        attr: *mut ::pthread_rwlockattr_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlockattr_setmaxreaders( +        attr: *mut ::pthread_rwlockattr_t, +        attr2: ::c_uint, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_init( +        attr: *mut ::pthread_rwlock_t, +        host: *const ::pthread_rwlockattr_t, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_destroy(attr: *mut ::pthread_rwlock_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_rdlock(attr: *mut ::pthread_rwlock_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_tryrdlock(attr: *mut ::pthread_rwlock_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_timedrdlock( +        attr: *mut ::pthread_rwlock_t, +        host: *const ::timespec, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_wrlock(attr: *mut ::pthread_rwlock_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_trywrlock(attr: *mut ::pthread_rwlock_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_timedwrlock( +        attr: *mut ::pthread_rwlock_t, +        host: *const ::timespec, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_rwlock_unlock(attr: *mut ::pthread_rwlock_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_key_create( +        key: *mut ::pthread_key_t, +        dtor: ::Option<unsafe extern fn(*mut ::c_void)>, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_key_delete(key: ::pthread_key_t) -> ::c_int; + +    // pthread.h +    pub fn pthread_setspecific( +        key: ::pthread_key_t, +        value: *const ::c_void, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_getspecific(key: ::pthread_key_t) -> *mut ::c_void; + +    // pthread.h +    pub fn pthread_cond_timedwait( +        cond: *mut ::pthread_cond_t, +        mutex: *mut ::pthread_mutex_t, +        abstime: *const ::timespec, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_attr_getname( +        attr: *mut ::pthread_attr_t, +        name: *mut *mut ::c_char, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_join( +        thread: ::pthread_t, +        status: *mut *mut ::c_void, +    ) -> ::c_int; + +    // pthread.h +    pub fn pthread_self() -> ::pthread_t; + +    // clockLib.h +    pub fn clock_gettime( +        clock_id: ::clockid_t, +        tp: *mut ::timespec, +    ) -> ::c_int; + +    // clockLib.h +    pub fn clock_settime( +        clock_id: ::clockid_t, +        tp: *const ::timespec, +    ) -> ::c_int; + +    // clockLib.h +    pub fn clock_getres( +        clock_id: ::clockid_t, +        res: *mut ::timespec, +    ) -> ::c_int; + +    // clockLib.h +    pub fn clock_nanosleep( +        clock_id: ::clockid_t, +        flags: ::c_int, +        rqtp: *const ::timespec, +        rmtp: *mut ::timespec, +    ) -> ::c_int; + +    // timerLib.h +    pub fn nanosleep( +        rqtp: *const ::timespec, +        rmtp: *mut ::timespec, +    ) -> ::c_int; + +    // socket.h +    pub fn accept( +        s: ::c_int, +        addr: *mut ::sockaddr, +        addrlen: *mut ::socklen_t, +    ) -> ::c_int; + +    // socket.h +    pub fn bind(fd: ::c_int, addr: *const sockaddr, len: socklen_t) +        -> ::c_int; + +    // socket.h +    pub fn connect( +        s: ::c_int, +        name: *const ::sockaddr, +        namelen: ::socklen_t, +    ) -> ::c_int; + +    // socket.h +    pub fn getpeername( +        s: ::c_int, +        name: *mut ::sockaddr, +        namelen: *mut ::socklen_t, +    ) -> ::c_int; + +    // socket.h +    pub fn getsockname( +        socket: ::c_int, +        address: *mut sockaddr, +        address_len: *mut socklen_t, +    ) -> ::c_int; + +    // socket.h +    pub fn getsockopt( +        sockfd: ::c_int, +        level: ::c_int, +        optname: ::c_int, +        optval: *mut ::c_void, +        optlen: *mut ::socklen_t, +    ) -> ::c_int; + +    // socket.h +    pub fn listen(socket: ::c_int, backlog: ::c_int) -> ::c_int; + +    // socket.h +    pub fn recv( +        s: ::c_int, +        buf: *mut ::c_void, +        bufLen: ::size_t, +        flags: ::c_int, +    ) -> ::ssize_t; + +    // socket.h +    pub fn recvfrom( +        s: ::c_int, +        buf: *mut ::c_void, +        bufLen: ::size_t, +        flags: ::c_int, +        from: *mut ::sockaddr, +        pFromLen: *mut ::socklen_t, +    ) -> ::ssize_t; + +    // socket.h +    pub fn send( +        socket: ::c_int, +        buf: *const ::c_void, +        len: ::size_t, +        flags: ::c_int, +    ) -> ::ssize_t; + +    // socket.h +    pub fn sendto( +        socket: ::c_int, +        buf: *const ::c_void, +        len: ::size_t, +        flags: ::c_int, +        addr: *const sockaddr, +        addrlen: socklen_t, +    ) -> ::ssize_t; + +    // socket.h +    pub fn setsockopt( +        socket: ::c_int, +        level: ::c_int, +        name: ::c_int, +        value: *const ::c_void, +        option_len: socklen_t, +    ) -> ::c_int; + +    // socket.h +    pub fn shutdown(s: ::c_int, how: ::c_int) -> ::c_int; + +    // socket.h +    pub fn socket( +        domain: ::c_int, +        _type: ::c_int, +        protocol: ::c_int, +    ) -> ::c_int; + +    pub fn socketpair( +        // Doesn't exist +        domain: ::c_int, +        type_: ::c_int, +        protocol: ::c_int, +        socket_vector: *mut ::c_int, +    ) -> ::c_int; + +    // icotl.h +    pub fn ioctl(fd: ::c_int, request: ::c_int, ...) -> ::c_int; + +    // fcntl.h +    pub fn fcntl(fd: ::c_int, cmd: ::c_int, ...) -> ::c_int; + +    // ntp_rfc2553.h for kernel +    // netdb.h for user +    pub fn gai_strerror(errcode: ::c_int) -> *mut ::c_char; + +    // ioLib.h or +    // unistd.h +    pub fn close(fd: ::c_int) -> ::c_int; + +    // ioLib.h or +    // unistd.h +    pub fn read( +        // Since this is from FD< big errors might happen +        fd: ::c_int, +        buf: *mut ::c_void, +        count: ::size_t, +    ) -> ::ssize_t; + +    // ioLib.h or +    // unistd.h +    pub fn write( +        fd: ::c_int, +        buf: *const ::c_void, +        count: ::size_t, +    ) -> ::ssize_t; + +    // ioLib.h or +    // unistd.h +    pub fn isatty(fd: ::c_int) -> ::c_int; + +    // ioLib.h or +    // unistd.h +    pub fn dup(src: ::c_int) -> ::c_int; + +    // ioLib.h or +    // unistd.h +    pub fn dup2(src: ::c_int, dst: ::c_int) -> ::c_int; + +    // ioLib.h or +    // unistd.h +    pub fn pipe(fds: *mut ::c_int) -> ::c_int; + +    // ioLib.h or +    // unistd.h +    pub fn unlink(pathname: *const ::c_char) -> ::c_int; + +    // unistd.h and +    // ioLib.h +    pub fn lseek(fd: ::c_int, offset: off_t, whence: ::c_int) -> off_t; + +    // netdb.h +    pub fn getaddrinfo( +        node: *const ::c_char, +        service: *const ::c_char, +        hints: *const addrinfo, +        res: *mut *mut addrinfo, +    ) -> ::c_int; + +    // netdb.h +    pub fn freeaddrinfo(res: *mut addrinfo); + +    // signal.h +    pub fn signal( +        // Probably wrong ... +        signum: ::c_int, +        handler: sighandler_t, +    ) -> sighandler_t; + +    // unistd.h +    pub fn getpid() -> ::c_int; //should be pid_t, but is being dodged + +    // unistd.h +    pub fn getppid() -> ::c_int; + +    // wait.h +    pub fn waitpid( +        pid: ::c_int, //should be pid_t, but is being dodged +        status: *mut ::c_int, +        optons: ::c_int, +    ) -> ::c_int; //should be pid_t, but is being dodged + +    // unistd.h +    pub fn sysconf(attr: ::c_int) -> ::c_long; + +    // unistd.h +    // For user space, return value is static inline int +    // For kernel space, exactly how it should be +    pub fn getpagesize() -> ::c_int; + +    // stdlib.h +    pub fn setenv( +        // setenv.c +        envVarName: *const ::c_char, +        envVarValue: *const ::c_char, +        overwrite: ::c_int, +    ) -> ::c_int; + +    // stdlib.h +    pub fn unsetenv( +        // setenv.c +        envVarName: *const ::c_char, +    ) -> ::c_int; + +    // unistd.h +    pub fn link(src: *const ::c_char, dst: *const ::c_char) -> ::c_int; + +    // unistd.h +    pub fn readlink( +        path: *const ::c_char, +        buf: *mut ::c_char, +        bufsize: ::size_t, +    ) -> ::ssize_t; + +    // unistd.h +    pub fn symlink(path1: *const ::c_char, path2: *const ::c_char) -> ::c_int; + +    // dirent.h +    pub fn opendir(name: *const ::c_char) -> *mut ::DIR; + +    // unistd.h +    pub fn rmdir(path: *const ::c_char) -> ::c_int; + +    // stat.h +    pub fn mkdir(dirName: *const ::c_char, mode: ::mode_t) -> ::c_int; + +    // stat.h +    pub fn chmod(path: *const ::c_char, mode: ::mode_t) -> ::c_int; + +    // stat.h +    pub fn fchmod(attr1: ::c_int, attr2: ::mode_t) -> ::c_int; + +    // unistd.h +    pub fn fsync(fd: ::c_int) -> ::c_int; + +    // dirent.h +    pub fn closedir(ptr: *mut ::DIR) -> ::c_int; + +    pub fn pwrite64( +        fd: ::c_int, // if you want to use fd, you gotta fix these +        buf: *const ::c_void, +        count: ::size_t, +        offset: off64_t, +    ) -> ::ssize_t; + +    pub fn pread64( +        fd: ::c_int, +        buf: *const ::c_void, +        count: ::size_t, +        offset: off64_t, +    ) -> ::ssize_t; + +    // sched.h +    pub fn sched_yield() -> ::c_int; + +    // errnoLib.h +    pub fn errnoSet(err: ::c_int) -> ::c_int; + +    // errnoLib.h +    pub fn errnoGet() -> ::c_int; + +    pub fn fork(// Does not exist at all +    ) -> ::c_int; + +    // unistd.h +    pub fn _exit(status: ::c_int) -> !; + +    // unistd.h +    pub fn setgid(gid: ::gid_t) -> ::c_int; + +    // unistd.h +    pub fn getgid() -> ::gid_t; + +    // unistd.h +    pub fn setuid(uid: ::uid_t) -> ::c_int; + +    // unistd.h +    pub fn getuid() -> ::uid_t; + +    pub fn setgroups( +        // Does not exist at all +        ngroups: ::c_int, +        grouplist: *const ::gid_t, +    ) -> ::c_int; + +    // signal.h +    pub fn sigemptyset(__set: *mut sigset_t) -> ::c_int; + +    // pthread.h for kernel +    // signal.h for user +    pub fn pthread_sigmask( +        __how: ::c_int, +        __set: *const sigset_t, +        __oset: *mut sigset_t, +    ) -> ::c_int; + +    pub fn execvp( +        // Does not exist at all +        c: *const ::c_char, +        argv: *const *const ::c_char, +    ) -> ::c_int; + +    // signal.h for user +    pub fn kill( +        __pid: ::c_int, //should be pid_t, but is being dodged +        __signo: ::c_int, +    ) -> ::c_int; + +    // signal.h for user +    pub fn sigqueue( +        __pid: ::c_int, //should be pid_t, but is being dodged +        __signo: ::c_int, +        __value: ::size_t, // Actual type is const union sigval value, +                           // which is a union of int and void * +    ) -> ::c_int; + +    // signal.h for user +    pub fn _sigqueue( +        rtpId: ::RTP_ID, +        signo: ::c_int, +        pValue: *mut ::size_t, // Actual type is const union * sigval value, +        // which is a union of int and void * +        sigCode: ::c_int, +    ) -> ::c_int; + +    // signal.h +    // It seems like for kernel space, this function doesn't actually exist, +    // it just macros to kill +    pub fn taskKill(taskId: ::TASK_ID, signo: ::c_int) -> ::c_int; + +    // signal.h +    pub fn raise(__signo: ::c_int) -> ::c_int; +    // taskLibCommon.h +    pub fn taskIdSelf() -> ::TASK_ID; + +    // rtpLibCommon.h +    pub fn rtpInfoGet(rtpId: ::RTP_ID, rtpStruct: *mut ::RTP_DESC) -> ::c_int; + +    // ioLib.h +    pub fn _realpath( +        fileName: *const ::c_char, +        resolvedName: *mut ::c_char, +    ) -> *mut ::c_char; + +    // pathLib.h +    pub fn _pathIsAbsolute( +        filepath: *const ::c_char, +        pNameTail: *const *const ::c_char, +    ) -> bool; + +    pub fn writev( +        fd: ::c_int, +        iov: *const ::iovec, +        iovcnt: ::c_int, +    ) -> ::ssize_t; +    pub fn readv( +        fd: ::c_int, +        iov: *const ::iovec, +        iovcnt: ::c_int, +    ) -> ::ssize_t; +} + +pub fn dladdr(addr: *const ::c_void, info: *mut Dl_info) -> ::c_int { +    unsafe { _rtld_dladdr(addr, info) } +} + +//Dummy functions, these don't really exist in VxWorks. + +// wait.h macros +pub fn WIFEXITED(status: ::c_int) -> bool { +    (status & 0xFF00) == 0 +} +pub fn WIFSIGNALED(status: ::c_int) -> bool { +    (status & 0xFF00) != 0 +} +pub fn WIFSTOPPED(status: ::c_int) -> bool { +    (status & 0xFF0000) != 0 +} +pub fn WEXITSTATUS(status: ::c_int) -> ::c_int { +    status & 0xFF +} +pub fn WTERMSIG(status: ::c_int) -> ::c_int { +    (status >> 8) & 0xFF +} +pub fn WSTOPSIG(status: ::c_int) -> ::c_int { +    (status >> 16) & 0xFF +} + +pub fn pread( +    _fd: ::c_int, +    _buf: *mut ::c_void, +    _count: ::size_t, +    _offset: off64_t, +) -> ::ssize_t { +    -1 +} + +pub fn pwrite( +    _fd: ::c_int, +    _buf: *const ::c_void, +    _count: ::size_t, +    _offset: off64_t, +) -> ::ssize_t { +    -1 +} +pub fn posix_memalign( +    memptr: *mut *mut ::c_void, +    align: ::size_t, +    size: ::size_t, +) -> ::c_int { +    // check to see if align is a power of 2 and if align is a multiple +    //  of sizeof(void *) +    if (align & align - 1 != 0) || (align % size_of::<::size_t>() != 0) { +        return ::EINVAL; +    } + +    unsafe { +        // posix_memalign should not set errno +        let e = ::errnoGet(); + +        let temp = memalign(align, size); +        ::errnoSet(e as ::c_int); + +        if temp.is_null() { +            ::ENOMEM +        } else { +            *memptr = temp; +            0 +        } +    } +} + +// From sysconf.c -> doesn't seem to be supported? +pub fn getpwuid_r( +    _uid: ::uid_t, +    _pwd: *mut passwd, +    _buf: *mut ::c_char, +    _buflen: ::size_t, +    _result: *mut *mut passwd, +) -> ::c_int { +    0 +} + +// VxWorks requires that resolvedName be allocated in userspace +pub fn realpath( +    fileName: *const ::c_char, +    resolvedName: *mut ::c_char, +) -> *mut ::c_char { +    unsafe { +        if resolvedName == null_mut::<::c_char>() { +            let emptyResolvedName = +                super::malloc(::_POSIX_PATH_MAX as _) as *mut ::c_char; +            let r = _realpath(fileName, emptyResolvedName); + +            if r == null_mut::<::c_char>() { +                super::free(emptyResolvedName as *mut _); +            } +            r +        } else { +            _realpath(fileName, resolvedName) +        } +    } +} + +cfg_if! { +    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)] +            __variant1, +            #[doc(hidden)] +            __variant2, +        } +    } +} + +cfg_if! { +    if #[cfg(target_arch = "aarch64")] { +        mod aarch64; +        pub use self::aarch64::*; +    } else if #[cfg(any(target_arch = "arm"))] { +        mod arm; +        pub use self::arm::*; +    } else if #[cfg(any(target_arch = "armv7"))] { +        mod armv7; +        pub use self::armv7::*; +    }  else if #[cfg(any(target_arch = "x86"))] { +        mod x86; +        pub use self::x86::*; +    } else if #[cfg(any(target_arch = "x86_64"))] { +        mod x86_64; +        pub use self::x86_64::*; +    } else if #[cfg(any(target_arch = "powerpc"))] { +        mod powerpc; +        pub use self::powerpc::*; +    } else if #[cfg(any(target_arch = "powerpc64"))] { +        mod powerpc64; +        pub use self::powerpc64::*; +    } else { +        // Unknown target_arch +    } +} diff --git a/libc/src/vxworks/powerpc.rs b/libc/src/vxworks/powerpc.rs new file mode 100644 index 0000000..cfdce82 --- /dev/null +++ b/libc/src/vxworks/powerpc.rs @@ -0,0 +1,3 @@ +pub type c_char = u8; +pub type c_long = i32; +pub type c_ulong = u32; diff --git a/libc/src/vxworks/powerpc64.rs b/libc/src/vxworks/powerpc64.rs new file mode 100644 index 0000000..577c8be --- /dev/null +++ b/libc/src/vxworks/powerpc64.rs @@ -0,0 +1,3 @@ +pub type c_char = u8; +pub type c_long = i64; +pub type c_ulong = u64; diff --git a/libc/src/vxworks/x86.rs b/libc/src/vxworks/x86.rs new file mode 100644 index 0000000..81ba145 --- /dev/null +++ b/libc/src/vxworks/x86.rs @@ -0,0 +1,3 @@ +pub type c_char = i8; +pub type c_long = i32; +pub type c_ulong = u32; diff --git a/libc/src/vxworks/x86_64.rs b/libc/src/vxworks/x86_64.rs new file mode 100644 index 0000000..27b9412 --- /dev/null +++ b/libc/src/vxworks/x86_64.rs @@ -0,0 +1,3 @@ +pub type c_long = i64; +pub type c_ulong = u64; +pub type c_char = i8; | 
