Source code

Revision control

Copy as Markdown

Other Tools

//! Interface to VxWorks C library
use core::mem::size_of;
use core::ptr::null_mut;
use crate::prelude::*;
#[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 intmax_t = i64;
pub type uintmax_t = u64;
pub type uintptr_t = usize;
pub type intptr_t = isize;
pub type ptrdiff_t = isize;
pub type size_t = crate::uintptr_t;
pub type ssize_t = intptr_t;
pub type pid_t = c_int;
pub type in_addr_t = u32;
pub type sighandler_t = size_t;
pub type cpuset_t = u32;
pub type blkcnt_t = c_long;
pub type blksize_t = c_long;
pub type ino_t = c_ulong;
pub type rlim_t = c_ulong;
pub type suseconds_t = c_long;
pub type time_t = c_longlong;
pub type errno_t = c_int;
pub type useconds_t = c_ulong;
pub type socklen_t = c_uint;
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 nfds_t = c_uint;
pub type stat64 = crate::stat;
pub type pthread_key_t = c_ulong;
// From b_off_t.h
pub type off_t = c_longlong;
pub type off64_t = off_t;
// From b_BOOL.h
pub type BOOL = c_int;
// From vxWind.h ..
pub type _Vx_OBJ_HANDLE = c_int;
pub type _Vx_TASK_ID = crate::_Vx_OBJ_HANDLE;
pub type _Vx_MSG_Q_ID = crate::_Vx_OBJ_HANDLE;
pub type _Vx_SEM_ID_KERNEL = crate::_Vx_OBJ_HANDLE;
pub type _Vx_RTP_ID = crate::_Vx_OBJ_HANDLE;
pub type _Vx_SD_ID = crate::_Vx_OBJ_HANDLE;
pub type _Vx_CONDVAR_ID = crate::_Vx_OBJ_HANDLE;
pub type _Vx_SEM_ID = *mut crate::_Vx_semaphore;
pub type OBJ_HANDLE = crate::_Vx_OBJ_HANDLE;
pub type TASK_ID = crate::OBJ_HANDLE;
pub type MSG_Q_ID = crate::OBJ_HANDLE;
pub type SEM_ID_KERNEL = crate::OBJ_HANDLE;
pub type RTP_ID = crate::OBJ_HANDLE;
pub type SD_ID = crate::OBJ_HANDLE;
pub type CONDVAR_ID = crate::OBJ_HANDLE;
pub type STATUS = crate::OBJ_HANDLE;
// From vxTypes.h
pub type _Vx_usr_arg_t = isize;
pub type _Vx_exit_code_t = isize;
pub type _Vx_ticks_t = c_uint;
pub type _Vx_ticks64_t = c_ulonglong;
pub type sa_family_t = c_uchar;
// mqueue.h
pub type mqd_t = c_int;
#[cfg_attr(feature = "extra_traits", derive(Debug))]
pub enum _Vx_semaphore {}
impl Copy for _Vx_semaphore {}
impl Clone for _Vx_semaphore {
fn clone(&self) -> _Vx_semaphore {
*self
}
}
impl siginfo_t {
pub unsafe fn si_addr(&self) -> *mut c_void {
self.si_addr
}
pub unsafe fn si_value(&self) -> crate::sigval {
self.si_value
}
pub unsafe fn si_pid(&self) -> crate::pid_t {
self.si_pid
}
pub unsafe fn si_uid(&self) -> crate::uid_t {
self.si_uid
}
pub unsafe fn si_status(&self) -> c_int {
self.si_status
}
}
s! {
// b_pthread_condattr_t.h
pub struct pthread_condattr_t {
pub condAttrStatus: c_int,
pub condAttrPshared: c_int,
pub condAttrClockId: crate::clockid_t,
}
// b_pthread_cond_t.h
pub struct pthread_cond_t {
pub condSemId: crate::_Vx_SEM_ID,
pub condValid: c_int,
pub condInitted: c_int,
pub condRefCount: c_int,
pub condMutex: *mut crate::pthread_mutex_t,
pub condAttr: crate::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 rwlockAttrPshared: c_int,
pub rwlockAttrMaxReaders: c_uint,
pub rwlockAttrConformOpt: c_uint,
}
// b_pthread_rwlock_t.h
pub struct pthread_rwlock_t {
pub rwlockSemId: crate::_Vx_SEM_ID,
pub rwlockReadersRefCount: c_uint,
pub rwlockValid: c_int,
pub rwlockInitted: c_int,
pub rwlockAttr: crate::pthread_rwlockattr_t,
pub rwlockSemName: [c_char; _PTHREAD_SHARED_SEM_NAME_MAX],
}
// b_struct_timeval.h
pub struct timeval {
pub tv_sec: crate::time_t,
pub tv_usec: crate::suseconds_t,
}
// socket.h
pub struct linger {
pub l_onoff: c_int,
pub l_linger: c_int,
}
pub struct sockaddr {
pub sa_len: c_uchar,
pub sa_family: sa_family_t,
pub sa_data: [c_char; 14],
}
pub struct iovec {
pub iov_base: *mut c_void,
pub iov_len: size_t,
}
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,
}
// poll.h
pub struct pollfd {
pub fd: c_int,
pub events: c_short,
pub revents: c_short,
}
// resource.h
pub struct rlimit {
pub rlim_cur: crate::rlim_t,
pub rlim_max: crate::rlim_t,
}
// stat.h
pub struct stat {
pub st_dev: crate::dev_t,
pub st_ino: crate::ino_t,
pub st_mode: crate::mode_t,
pub st_nlink: crate::nlink_t,
pub st_uid: crate::uid_t,
pub st_gid: crate::gid_t,
pub st_rdev: crate::dev_t,
pub st_size: off_t,
pub st_atime: crate::time_t,
pub st_mtime: crate::time_t,
pub st_ctime: crate::time_t,
pub st_blksize: crate::blksize_t,
pub st_blocks: crate::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: crate::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: crate::_Timespec, /* replenishment period */
pub sched_ss_init_budget: crate::_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: crate::sched_param,
}
// signal.h
pub struct sigaction {
pub sa_u: crate::sa_u_t,
pub sa_mask: crate::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,
pub si_value: crate::sigval,
pub si_errno: c_int,
pub si_status: c_int,
pub si_addr: *mut c_void,
pub si_uid: crate::uid_t,
pub si_pid: crate::pid_t,
}
// 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: crate::_Vx_SEM_ID, /*_Vx_SEM_ID ..*/
pub mutexValid: c_int,
pub mutexInitted: c_int,
pub mutexCondRefCount: c_int,
pub mutexSavPriority: c_int,
pub mutexAttr: crate::pthread_mutexattr_t,
pub mutexSemName: [c_char; _PTHREAD_SHARED_SEM_NAME_MAX],
}
// b_struct_timespec.h
pub struct timespec {
pub tv_sec: crate::time_t,
pub tv_nsec: c_long,
}
// time.h
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,
}
// 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
#[repr(align(4))]
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 crate::sockaddr,
pub ai_next: *mut crate::addrinfo,
}
// in.h
pub struct sockaddr_in {
pub sin_len: u8,
pub sin_family: u8,
pub sin_port: u16,
pub sin_addr: crate::in_addr,
pub sin_zero: [c_char; 8],
}
// in6.h
pub struct sockaddr_in6 {
pub sin6_len: u8,
pub sin6_family: u8,
pub sin6_port: u16,
pub sin6_flowinfo: u32,
pub sin6_addr: crate::in6_addr,
pub sin6_scope_id: u32,
}
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 mq_attr {
pub mq_maxmsg: c_long,
pub mq_msgsize: c_long,
pub mq_flags: c_long,
pub mq_curmsgs: c_long,
}
}
s_no_extra_traits! {
// dirent.h
pub struct dirent {
pub d_ino: crate::ino_t,
pub d_name: [c_char; _PARM_NAME_MAX as usize + 1],
}
pub struct sockaddr_un {
pub sun_len: u8,
pub sun_family: sa_family_t,
pub sun_path: [c_char; 104],
}
// rtpLibCommon.h
pub struct RTP_DESC {
pub status: c_int,
pub options: u32,
pub entrAddr: *mut c_void,
pub initTaskId: crate::TASK_ID,
pub parentId: crate::RTP_ID,
pub pathName: [c_char; VX_RTP_NAME_LENGTH as usize + 1],
pub taskCnt: c_int,
pub textStart: *mut c_void,
pub textEnd: *mut c_void,
}
// socket.h
pub struct sockaddr_storage {
pub ss_len: c_uchar,
pub ss_family: crate::sa_family_t,
pub __ss_pad1: [c_char; _SS_PAD1SIZE],
pub __ss_align: i32,
pub __ss_pad2: [c_char; _SS_PAD2SIZE],
}
pub union sa_u_t {
pub sa_handler: Option<unsafe extern "C" fn(c_int) -> !>,
pub sa_sigaction:
Option<unsafe extern "C" fn(c_int, *mut crate::siginfo_t, *mut c_void) -> !>,
}
pub union sigval {
pub sival_int: c_int,
pub sival_ptr: *mut c_void,
}
}
cfg_if! {
if #[cfg(feature = "extra_traits")] {
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_name", &&self.d_name[..])
.finish()
}
}
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)
.field("sun_path", &&self.sun_path[..])
.finish()
}
}
impl fmt::Debug for RTP_DESC {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
f.debug_struct("RTP_DESC")
.field("status", &self.status)
.field("options", &self.options)
.field("entrAddr", &self.entrAddr)
.field("initTaskId", &self.initTaskId)
.field("parentId", &self.parentId)
.field("pathName", &&self.pathName[..])
.field("taskCnt", &self.taskCnt)
.field("textStart", &self.textStart)
.field("textEnd", &self.textEnd)
.finish()
}
}
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)
.field("__ss_pad2", &&self.__ss_pad2[..])
.finish()
}
}
impl PartialEq for sa_u_t {
fn eq(&self, other: &sa_u_t) -> bool {
unsafe {
let h1 = match self.sa_handler {
Some(handler) => handler as usize,
None => 0 as usize,
};
let h2 = match other.sa_handler {
Some(handler) => handler as usize,
None => 0 as usize,
};
h1 == h2
}
}
}
impl Eq for sa_u_t {}
impl hash::Hash for sa_u_t {
fn hash<H: hash::Hasher>(&self, state: &mut H) {
unsafe {
let h = match self.sa_handler {
Some(handler) => handler as usize,
None => 0 as usize,
};
h.hash(state)
}
}
}
impl PartialEq for sigval {
fn eq(&self, other: &sigval) -> bool {
unsafe { self.sival_ptr as usize == other.sival_ptr as usize }
}
}
impl Eq for sigval {}
impl hash::Hash for sigval {
fn hash<H: hash::Hasher>(&self, state: &mut H) {
unsafe { (self.sival_ptr as usize).hash(state) };
}
}
}
}
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;
// FIXME(vxworks): This is not defined in vxWorks, but we have to define it here
// to make the building pass for getrandom and std
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 TIMER_RELTIME: c_int = 0x0;
// 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;
//sched.h
pub const SCHED_FIFO: c_int = 0x01;
pub const SCHED_RR: c_int = 0x02;
pub const SCHED_OTHER: c_int = 0x04;
pub const SCHED_SPORADIC: c_int = 0x08;
pub const PRIO_PROCESS: c_uint = 0;
pub const SCHED_FIFO_HIGH_PRI: c_int = 255;
pub const SCHED_FIFO_LOW_PRI: c_int = 0;
pub const SCHED_RR_HIGH_PRI: c_int = 255;
pub const SCHED_RR_LOW_PRI: c_int = 0;
pub const SCHED_SPORADIC_HIGH_PRI: c_int = 255;
pub const SCHED_SPORADIC_LOW_PRI: c_int = 0;
// ERRNO STUFF
pub const ERROR: c_int = -1;
pub const OK: c_int = 0;
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 EIO: 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 ECHILD: 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 EFAULT: c_int = 14;
pub const ENOTEMPTY: 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 ENAMETOOLONG: 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 EDEADLK: c_int = 33;
pub const ERANGE: c_int = 38;
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;
pub const ENETDOWN: c_int = 62;
pub const ETXTBSY: c_int = 63;
pub const ELOOP: c_int = 64;
pub const EHOSTUNREACH: c_int = 65;
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 EDQUOT: c_int = 83;
pub const ESTALE: c_int = 88;
// NFS errnos: Refer to pkgs_v2/storage/fs/nfs/h/nfs/nfsCommon.h
const M_nfsStat: c_int = 48 << 16;
enum nfsstat {
NFSERR_REMOTE = 71,
NFSERR_WFLUSH = 99,
NFSERR_BADHANDLE = 10001,
NFSERR_NOT_SYNC = 10002,
NFSERR_BAD_COOKIE = 10003,
NFSERR_TOOSMALL = 10005,
NFSERR_BADTYPE = 10007,
NFSERR_JUKEBOX = 10008,
}
pub const S_nfsLib_NFS_OK: c_int = OK;
pub const S_nfsLib_NFSERR_PERM: c_int = EPERM;
pub const S_nfsLib_NFSERR_NOENT: c_int = ENOENT;
pub const S_nfsLib_NFSERR_IO: c_int = EIO;
pub const S_nfsLib_NFSERR_NXIO: c_int = ENXIO;
pub const S_nfsLib_NFSERR_ACCESS: c_int = EACCES;
pub const S_nfsLib_NFSERR_EXIST: c_int = EEXIST;
pub const S_nfsLib_NFSERR_ENODEV: c_int = ENODEV;
pub const S_nfsLib_NFSERR_NOTDIR: c_int = ENOTDIR;
pub const S_nfsLib_NFSERR_ISDIR: c_int = EISDIR;
pub const S_nfsLib_NFSERR_INVAL: c_int = EINVAL;
pub const S_nfsLib_NFSERR_FBIG: c_int = EFBIG;
pub const S_nfsLib_NFSERR_NOSPC: c_int = ENOSPC;
pub const S_nfsLib_NFSERR_ROFS: c_int = EROFS;
pub const S_nfsLib_NFSERR_NAMETOOLONG: c_int = ENAMETOOLONG;
pub const S_nfsLib_NFSERR_NOTEMPTY: c_int = ENOTEMPTY;
pub const S_nfsLib_NFSERR_DQUOT: c_int = EDQUOT;
pub const S_nfsLib_NFSERR_STALE: c_int = ESTALE;
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 = EOPNOTSUPP;
pub const S_nfsLib_NFSERR_TOOSMALL: c_int = M_nfsStat | nfsstat::NFSERR_TOOSMALL as c_int;
pub const S_nfsLib_NFSERR_SERVERFAULT: c_int = EIO;
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;
// internal offset values for below constants
const taskErrorBase: c_int = 0x00030000;
const semErrorBase: c_int = 0x00160000;
const objErrorBase: c_int = 0x003d0000;
// taskLibCommon.h
pub const S_taskLib_NAME_NOT_FOUND: c_int = taskErrorBase + 0x0065;
pub const S_taskLib_TASK_HOOK_TABLE_FULL: c_int = taskErrorBase + 0x0066;
pub const S_taskLib_TASK_HOOK_NOT_FOUND: c_int = taskErrorBase + 0x0067;
pub const S_taskLib_ILLEGAL_PRIORITY: c_int = taskErrorBase + 0x0068;
// FIXME(vxworks): could also be useful for TASK_DESC type
pub const VX_TASK_NAME_LENGTH: c_int = 31;
// semLibCommon.h
pub const S_semLib_INVALID_STATE: c_int = semErrorBase + 0x0065;
pub const S_semLib_INVALID_OPTION: c_int = semErrorBase + 0x0066;
pub const S_semLib_INVALID_QUEUE_TYPE: c_int = semErrorBase + 0x0067;
pub const S_semLib_INVALID_OPERATION: c_int = semErrorBase + 0x0068;
// objLibCommon.h
pub const S_objLib_OBJ_ID_ERROR: c_int = objErrorBase + 0x0001;
pub const S_objLib_OBJ_UNAVAILABLE: c_int = objErrorBase + 0x0002;
pub const S_objLib_OBJ_DELETED: c_int = objErrorBase + 0x0003;
pub const S_objLib_OBJ_TIMEOUT: c_int = objErrorBase + 0x0004;
pub const S_objLib_OBJ_NO_METHOD: c_int = objErrorBase + 0x0005;
// in.h
pub const IPPROTO_IP: c_int = 0;
pub const IPPROTO_IPV6: c_int = 41;
pub const IP_TTL: c_int = 4;
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 = 12;
pub const IP_DROP_MEMBERSHIP: c_int = 13;
// in6.h
pub const IPV6_V6ONLY: c_int = 1;
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_ADD_MEMBERSHIP: c_int = 12;
pub const IPV6_DROP_MEMBERSHIP: c_int = 13;
// STAT Stuff
pub const S_IFMT: c_int = 0o17_0000;
pub const S_IFIFO: c_int = 0o1_0000;
pub const S_IFCHR: c_int = 0o2_0000;
pub const S_IFDIR: c_int = 0o4_0000;
pub const S_IFBLK: c_int = 0o6_0000;
pub const S_IFREG: c_int = 0o10_0000;
pub const S_IFLNK: c_int = 0o12_0000;
pub const S_IFSHM: c_int = 0o13_0000;
pub const S_IFSOCK: c_int = 0o14_0000;
pub const S_ISUID: c_int = 0o4000;
pub const S_ISGID: c_int = 0o2000;
pub const S_ISTXT: c_int = 0o1000;
pub const S_ISVTX: c_int = 0o1000;
pub const S_IRUSR: c_int = 0o0400;
pub const S_IWUSR: c_int = 0o0200;
pub const S_IXUSR: c_int = 0o0100;
pub const S_IRWXU: c_int = 0o0700;
pub const S_IRGRP: c_int = 0o0040;
pub const S_IWGRP: c_int = 0o0020;
pub const S_IXGRP: c_int = 0o0010;
pub const S_IRWXG: c_int = 0o0070;
pub const S_IROTH: c_int = 0o0004;
pub const S_IWOTH: c_int = 0o0002;
pub const S_IXOTH: c_int = 0o0001;
pub const S_IRWXO: c_int = 0o0007;
// socket.h
pub const SOL_SOCKET: c_int = 0xffff;
pub const SOMAXCONN: c_int = 128;
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 SO_SNDLOWAT: c_int = 0x0013;
pub const SO_SNDTIMEO: c_int = 0x1005;
pub const SO_ACCEPTCONN: c_int = 0x001e;
pub const SO_BROADCAST: c_int = 0x0020;
pub const SO_USELOOPBACK: c_int = 0x0040;
pub const SO_LINGER: c_int = 0x0080;
pub const SO_REUSEPORT: c_int = 0x0200;
pub const SO_VLAN: c_int = 0x8000;
pub const SO_SNDBUF: c_int = 0x1001;
pub const SO_RCVBUF: c_int = 0x1002;
pub const SO_RCVTIMEO: c_int = 0x1006;
pub const SO_ERROR: c_int = 0x1007;
pub const SO_TYPE: c_int = 0x1008;
pub const SO_BINDTODEVICE: c_int = 0x1010;
pub const SO_OOBINLINE: c_int = 0x1011;
pub const SO_CONNTIMEO: c_int = 0x100a;
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 _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::<crate::sa_family_t>();
pub const _SS_PAD2SIZE: usize = _SS_MAXSIZE
- size_of::<c_uchar>()
- size_of::<crate::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 = 37;
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;
// ioLib.h
pub const FIONREAD: c_int = 0x40040001;
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 FIODISKCHANGE: c_int = 13;
pub const FIOCANCEL: c_int = 14;
pub const FIOSQUEEZE: c_int = 15;
pub const FIOGETNAME: c_int = 18;
pub const FIONBIO: c_int = 0x90040010;
// limits.h
pub const PATH_MAX: c_int = _PARM_PATH_MAX;
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 POLLERR: c_short = 0x0008;
pub const POLLHUP: c_short = 0x0010;
pub const POLLNVAL: c_short = 0x0020;
// fnctlcom.h
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;
// signal.h
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 = -1 as isize 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: c_int = 255;
pub const _PARM_PATH_MAX: c_int = 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: -1,
mutexAttr: PTHREAD_MUTEXATTR_INITIALIZER,
mutexSemName: [0; _PTHREAD_SHARED_SEM_NAME_MAX],
};
const PTHREAD_CONDATTR_INITIALIZER: pthread_condattr_t = pthread_condattr_t {
condAttrStatus: 0xf70990ef,
condAttrPshared: 1,
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,
rwlockAttrPshared: 1,
rwlockAttrMaxReaders: 0,
rwlockAttrConformOpt: 1,
};
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,
rwlockSemName: [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: c_int = 255;
pub const RTP_ID_ERROR: crate::RTP_ID = -1;
// h/public/unistd.h
pub const _SC_GETPW_R_SIZE_MAX: c_int = 21; // Via unistd.h
pub const _SC_PAGESIZE: c_int = 39;
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 = 0x0002;
pub const O_WRONLY: c_int = 0x0001;
pub const O_RDONLY: c_int = 0;
pub const O_NONBLOCK: c_int = 0x4000;
// mman.h
pub const PROT_NONE: c_int = 0x0000;
pub const PROT_READ: c_int = 0x0001;
pub const PROT_WRITE: c_int = 0x0002;
pub const PROT_EXEC: c_int = 0x0004;
pub const MAP_SHARED: c_int = 0x0001;
pub const MAP_PRIVATE: c_int = 0x0002;
pub const MAP_ANON: c_int = 0x0004;
pub const MAP_ANONYMOUS: c_int = MAP_ANON;
pub const MAP_FIXED: c_int = 0x0010;
pub const MAP_CONTIG: c_int = 0x0020;
pub const MAP_FAILED: *mut c_void = !0 as *mut c_void;
#[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 {} // FIXME(vxworks): fill this out with a struct
impl Copy for fpos_t {}
impl Clone for fpos_t {
fn clone(&self) -> fpos_t {
*self
}
}
f! {
pub {const} fn CMSG_ALIGN(len: usize) -> usize {
len + mem::size_of::<usize>() - 1 & !(mem::size_of::<usize>() - 1)
}
pub fn CMSG_NXTHDR(mhdr: *const msghdr, cmsg: *const cmsghdr) -> *mut 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 usize)) as *mut cmsghdr
} else {
0 as *mut cmsghdr
}
}
pub fn CMSG_FIRSTHDR(mhdr: *const msghdr) -> *mut cmsghdr {
if (*mhdr).msg_controllen as usize > 0 {
(*mhdr).msg_control as *mut cmsghdr
} else {
0 as *mut cmsghdr
}
}
pub fn CMSG_DATA(cmsg: *const cmsghdr) -> *mut c_uchar {
(cmsg as *mut c_uchar).offset(CMSG_ALIGN(mem::size_of::<cmsghdr>()) as isize)
}
pub {const} fn CMSG_SPACE(length: c_uint) -> c_uint {
(CMSG_ALIGN(length as usize) + CMSG_ALIGN(mem::size_of::<cmsghdr>())) as c_uint
}
pub {const} fn CMSG_LEN(length: c_uint) -> c_uint {
CMSG_ALIGN(mem::size_of::<cmsghdr>()) as c_uint + length
}
}
extern "C" {
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 isblank(c: c_int) -> c_int;
pub fn tolower(c: c_int) -> c_int;
pub fn toupper(c: c_int) -> c_int;
pub fn fopen(filename: *const c_char, mode: *const c_char) -> *mut FILE;
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;
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;
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);
pub fn fgetpos(stream: *mut FILE, ptr: *mut fpos_t) -> c_int;
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 atof(s: *const c_char) -> c_double;
pub fn atoi(s: *const c_char) -> c_int;
pub fn atol(s: *const c_char) -> c_long;
pub fn atoll(s: *const c_char) -> c_longlong;
pub fn strtod(s: *const c_char, endp: *mut *mut c_char) -> c_double;
pub fn strtof(s: *const c_char, endp: *mut *mut c_char) -> c_float;
pub fn strtol(s: *const c_char, endp: *mut *mut c_char, base: c_int) -> c_long;
pub fn strtoll(s: *const c_char, endp: *mut *mut c_char, base: c_int) -> c_longlong;
pub fn strtoul(s: *const c_char, endp: *mut *mut c_char, base: c_int) -> c_ulong;
pub fn strtoull(s: *const c_char, endp: *mut *mut c_char, base: c_int) -> c_ulonglong;
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 atexit(cb: extern "C" fn()) -> c_int;
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 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 wmemchr(cx: *const wchar_t, c: wchar_t, n: size_t) -> *mut wchar_t;
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 "C" {
pub fn fprintf(stream: *mut crate::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 crate::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 fdopen(fd: c_int, mode: *const c_char) -> *mut crate::FILE;
pub fn fileno(stream: *mut crate::FILE) -> c_int;
pub fn creat(path: *const c_char, mode: mode_t) -> c_int;
pub fn rewinddir(dirp: *mut crate::DIR);
pub fn fchown(fd: c_int, owner: crate::uid_t, group: crate::gid_t) -> 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;
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 sleep(secs: c_uint) -> c_uint;
pub fn ttyname(fd: c_int) -> *mut c_char;
pub fn wait(status: *mut c_int) -> pid_t;
pub fn umask(mask: mode_t) -> mode_t;
pub fn mlock(addr: *const c_void, len: size_t) -> c_int;
pub fn mlockall(flags: c_int) -> c_int;
pub fn munlockall() -> c_int;
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;
pub fn munmap(addr: *mut c_void, len: size_t) -> c_int;
pub fn truncate(path: *const c_char, length: off_t) -> c_int;
pub fn shm_open(name: *const c_char, oflag: c_int, mode: crate::mode_t) -> c_int;
pub fn shm_unlink(name: *const c_char) -> c_int;
pub fn gettimeofday(tp: *mut crate::timeval, tz: *mut c_void) -> c_int;
pub fn pthread_exit(value: *mut c_void) -> !;
pub fn pthread_attr_setdetachstate(attr: *mut crate::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 sigaddset(set: *mut sigset_t, signum: c_int) -> c_int;
pub fn sigaction(signum: c_int, act: *const sigaction, oldact: *mut sigaction) -> c_int;
pub fn utimes(filename: *const c_char, times: *const crate::timeval) -> c_int;
#[link_name = "_rtld_dlopen"]
pub fn dlopen(filename: *const c_char, flag: c_int) -> *mut c_void;
#[link_name = "_rtld_dlerror"]
pub fn dlerror() -> *mut c_char;
#[link_name = "_rtld_dlsym"]
pub fn dlsym(handle: *mut c_void, symbol: *const c_char) -> *mut c_void;
#[link_name = "_rtld_dlclose"]
pub fn dlclose(handle: *mut c_void) -> c_int;
#[link_name = "_rtld_dladdr"]
pub fn dladdr(addr: *mut c_void, info: *mut Dl_info) -> c_int;
// time.h
pub fn gmtime_r(time_p: *const time_t, result: *mut tm) -> *mut tm;
pub fn localtime_r(time_p: *const time_t, result: *mut tm) -> *mut tm;
pub fn mktime(tm: *mut tm) -> time_t;
pub fn time(time: *mut time_t) -> time_t;
pub fn gmtime(time_p: *const time_t) -> *mut tm;
pub fn localtime(time_p: *const time_t) -> *mut tm;
pub fn timegm(tm: *mut tm) -> time_t;
pub fn difftime(time1: time_t, time0: time_t) -> c_double;
pub fn gethostname(name: *mut c_char, len: size_t) -> c_int;
pub fn usleep(secs: crate::useconds_t) -> c_int;
pub fn putenv(string: *mut c_char) -> c_int;
pub fn setlocale(category: c_int, locale: *const c_char) -> *mut c_char;
pub fn sigprocmask(how: c_int, set: *const sigset_t, oldset: *mut sigset_t) -> c_int;
pub fn sigpending(set: *mut sigset_t) -> c_int;
pub fn mkfifo(path: *const c_char, mode: mode_t) -> c_int;
pub fn fseeko(stream: *mut crate::FILE, offset: off_t, whence: c_int) -> c_int;
pub fn ftello(stream: *mut crate::FILE) -> off_t;
pub fn mkstemp(template: *mut c_char) -> c_int;
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;
pub fn syslog(priority: c_int, message: *const c_char, ...);
pub fn getline(lineptr: *mut *mut c_char, n: *mut size_t, stream: *mut FILE) -> ssize_t;
}
extern "C" {
// stdlib.h
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(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 crate::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 crate::pthread_attr_t, name: *mut c_char) -> c_int;
// pthread.h
pub fn pthread_attr_setstacksize(attr: *mut crate::pthread_attr_t, stacksize: size_t) -> c_int;
// pthread.h
pub fn pthread_attr_getstacksize(
attr: *const crate::pthread_attr_t,
size: *mut size_t,
) -> c_int;
// pthread.h
pub fn pthread_attr_init(attr: *mut crate::pthread_attr_t) -> c_int;
// pthread.h
pub fn pthread_create(
pThread: *mut crate::pthread_t,
pAttr: *const crate::pthread_attr_t,
start_routine: extern "C" fn(*mut c_void) -> *mut c_void,
value: *mut c_void,
) -> c_int;
//pthread.h
pub fn pthread_setschedparam(
native: crate::pthread_t,
policy: c_int,
param: *const crate::sched_param,
) -> c_int;
//pthread.h
pub fn pthread_getschedparam(
native: crate::pthread_t,
policy: *mut c_int,
param: *mut crate::sched_param,
) -> c_int;
//pthread.h
pub fn pthread_attr_setinheritsched(
attr: *mut crate::pthread_attr_t,
inheritsched: c_int,
) -> c_int;
//pthread.h
pub fn pthread_attr_setschedpolicy(attr: *mut crate::pthread_attr_t, policy: c_int) -> c_int;
// pthread.h
pub fn pthread_attr_destroy(thread: *mut crate::pthread_attr_t) -> c_int;
// pthread.h
pub fn pthread_detach(thread: crate::pthread_t) -> c_int;
// int pthread_atfork (void (*)(void), void (*)(void), void (*)(void));
pub fn pthread_atfork(
prepare: Option<unsafe extern "C" fn()>,
parent: Option<unsafe extern "C" fn()>,
child: Option<unsafe extern "C" 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 crate::DIR,
entry: *mut crate::dirent,
result: *mut *mut crate::dirent,
) -> c_int;
// dirent.h
pub fn readdir(pDir: *mut crate::DIR) -> *mut crate::dirent;
// fcntl.h or
// ioLib.h
pub fn open(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 crate::pthread_condattr_t) -> c_int;
// pthread.h
pub fn pthread_condattr_destroy(attr: *mut crate::pthread_condattr_t) -> c_int;
// pthread.h
pub fn pthread_condattr_getclock(
pAttr: *const crate::pthread_condattr_t,
pClockId: *mut crate::clockid_t,
) -> c_int;
// pthread.h
pub fn pthread_condattr_setclock(
pAttr: *mut crate::pthread_condattr_t,
clockId: crate::clockid_t,
) -> c_int;
// pthread.h
pub fn pthread_cond_init(
cond: *mut crate::pthread_cond_t,
attr: *const crate::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 crate::pthread_cond_t) -> c_int;
// pthread.h
pub fn pthread_cond_broadcast(cond: *mut crate::pthread_cond_t) -> c_int;
// pthread.h
pub fn pthread_cond_wait(
cond: *mut crate::pthread_cond_t,
mutex: *mut crate::pthread_mutex_t,
) -> c_int;
// pthread.h
pub fn pthread_rwlockattr_init(attr: *mut crate::pthread_rwlockattr_t) -> c_int;
// pthread.h
pub fn pthread_rwlockattr_destroy(attr: *mut crate::pthread_rwlockattr_t) -> c_int;
// pthread.h
pub fn pthread_rwlockattr_setmaxreaders(
attr: *mut crate::pthread_rwlockattr_t,
attr2: c_uint,
) -> c_int;
// pthread.h
pub fn pthread_rwlock_init(
attr: *mut crate::pthread_rwlock_t,
host: *const crate::pthread_rwlockattr_t,
) -> c_int;
// pthread.h
pub fn pthread_rwlock_destroy(attr: *mut crate::pthread_rwlock_t) -> c_int;
// pthread.h
pub fn pthread_rwlock_rdlock(attr: *mut crate::pthread_rwlock_t) -> c_int;
// pthread.h
pub fn pthread_rwlock_tryrdlock(attr: *mut crate::pthread_rwlock_t) -> c_int;
// pthread.h
pub fn pthread_rwlock_timedrdlock(
attr: *mut crate::pthread_rwlock_t,
host: *const crate::timespec,
) -> c_int;
// pthread.h
pub fn pthread_rwlock_wrlock(attr: *mut crate::pthread_rwlock_t) -> c_int;
// pthread.h
pub fn pthread_rwlock_trywrlock(attr: *mut crate::pthread_rwlock_t) -> c_int;
// pthread.h
pub fn pthread_rwlock_timedwrlock(
attr: *mut crate::pthread_rwlock_t,
host: *const crate::timespec,
) -> c_int;
// pthread.h
pub fn pthread_rwlock_unlock(attr: *mut crate::pthread_rwlock_t) -> c_int;
// pthread.h
pub fn pthread_key_create(
key: *mut crate::pthread_key_t,
dtor: Option<unsafe extern "C" fn(*mut c_void)>,
) -> c_int;
// pthread.h
pub fn pthread_key_delete(key: crate::pthread_key_t) -> c_int;
// pthread.h
pub fn pthread_setspecific(key: crate::pthread_key_t, value: *const c_void) -> c_int;
// pthread.h
pub fn pthread_getspecific(key: crate::pthread_key_t) -> *mut c_void;
// pthread.h
pub fn pthread_cond_timedwait(
cond: *mut crate::pthread_cond_t,
mutex: *mut crate::pthread_mutex_t,
abstime: *const crate::timespec,
) -> c_int;
// pthread.h
pub fn pthread_attr_getname(attr: *mut crate::pthread_attr_t, name: *mut *mut c_char) -> c_int;
// pthread.h
pub fn pthread_join(thread: crate::pthread_t, status: *mut *mut c_void) -> c_int;
// pthread.h
pub fn pthread_self() -> crate::pthread_t;
// clockLib.h
pub fn clock_gettime(clock_id: crate::clockid_t, tp: *mut crate::timespec) -> c_int;
// clockLib.h
pub fn clock_settime(clock_id: crate::clockid_t, tp: *const crate::timespec) -> c_int;
// clockLib.h
pub fn clock_getres(clock_id: crate::clockid_t, res: *mut crate::timespec) -> c_int;
// clockLib.h
pub fn clock_nanosleep(
clock_id: crate::clockid_t,
flags: c_int,
rqtp: *const crate::timespec,
rmtp: *mut crate::timespec,
) -> c_int;
// timerLib.h
pub fn nanosleep(rqtp: *const crate::timespec, rmtp: *mut crate::timespec) -> c_int;
// socket.h
pub fn accept(s: c_int, addr: *mut crate::sockaddr, addrlen: *mut crate::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 crate::sockaddr, namelen: crate::socklen_t) -> c_int;
// socket.h
pub fn getpeername(
s: c_int,
name: *mut crate::sockaddr,
namelen: *mut crate::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 crate::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 crate::sockaddr,
pFromLen: *mut crate::socklen_t,
) -> ssize_t;
pub fn recvmsg(socket: c_int, mp: *mut crate::msghdr, flags: c_int) -> ssize_t;
// socket.h
pub fn send(socket: c_int, buf: *const c_void, len: size_t, flags: c_int) -> ssize_t;
pub fn sendmsg(socket: c_int, mp: *const crate::msghdr, 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;
// 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(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(signum: c_int, handler: sighandler_t) -> sighandler_t;
// unistd.h
pub fn getpid() -> pid_t;
// unistd.h
pub fn getppid() -> pid_t;
// wait.h
pub fn waitpid(pid: pid_t, status: *mut c_int, optons: c_int) -> pid_t;
// unistd.h
pub fn sysconf(attr: c_int) -> c_long;
// 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;
// stdlib.h
pub fn realpath(fileName: *const c_char, resolvedName: *mut c_char) -> *mut c_char;
// 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 crate::DIR;
// unistd.h
pub fn rmdir(path: *const c_char) -> c_int;
// stat.h
pub fn mkdir(dirName: *const c_char, mode: crate::mode_t) -> c_int;
// stat.h
pub fn chmod(path: *const c_char, mode: crate::mode_t) -> c_int;
// stat.h
pub fn fchmod(attr1: c_int, attr2: crate::mode_t) -> c_int;
// unistd.h
pub fn fsync(fd: c_int) -> c_int;
// dirent.h
pub fn closedir(ptr: *mut crate::DIR) -> c_int;
//sched.h
pub fn sched_get_priority_max(policy: c_int) -> c_int;
//sched.h
pub fn sched_get_priority_min(policy: c_int) -> c_int;
//sched.h
pub fn sched_setparam(pid: crate::pid_t, param: *const crate::sched_param) -> c_int;
//sched.h
pub fn sched_getparam(pid: crate::pid_t, param: *mut crate::sched_param) -> c_int;
//sched.h
pub fn sched_setscheduler(
pid: crate::pid_t,
policy: c_int,
param: *const crate::sched_param,
) -> c_int;
//sched.h
pub fn sched_getscheduler(pid: crate::pid_t) -> c_int;
//sched.h
pub fn sched_rr_get_interval(pid: crate::pid_t, tp: *mut crate::timespec) -> c_int;
// 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;
// unistd.h
pub fn _exit(status: c_int) -> !;
// unistd.h
pub fn setgid(gid: crate::gid_t) -> c_int;
// unistd.h
pub fn getgid() -> crate::gid_t;
// unistd.h
pub fn setuid(uid: crate::uid_t) -> c_int;
// unistd.h
pub fn getuid() -> crate::uid_t;
// 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;
// signal.h for user
pub fn kill(__pid: pid_t, __signo: c_int) -> c_int;
// signal.h for user
pub fn sigqueue(__pid: pid_t, __signo: c_int, __value: crate::sigval) -> c_int;
// signal.h for user
pub fn _sigqueue(
rtpId: crate::RTP_ID,
signo: c_int,
pValue: *const crate::sigval,
sigCode: c_int,
) -> c_int;
// signal.h
pub fn taskKill(taskId: crate::TASK_ID, signo: c_int) -> c_int;
// signal.h
pub fn raise(__signo: c_int) -> c_int;
// taskLibCommon.h
pub fn taskIdSelf() -> crate::TASK_ID;
pub fn taskDelay(ticks: crate::_Vx_ticks_t) -> c_int;
// taskLib.h
pub fn taskNameSet(task_id: crate::TASK_ID, task_name: *mut c_char) -> c_int;
pub fn taskNameGet(task_id: crate::TASK_ID, buf_name: *mut c_char, bufsize: size_t) -> c_int;
// rtpLibCommon.h
pub fn rtpInfoGet(rtpId: crate::RTP_ID, rtpStruct: *mut crate::RTP_DESC) -> c_int;
pub fn rtpSpawn(
pubrtpFileName: *const c_char,
argv: *mut *const c_char,
envp: *mut *const c_char,
priority: c_int,
uStackSize: size_t,
options: c_int,
taskOptions: c_int,
) -> RTP_ID;
// 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: *mut *const c_char) -> BOOL;
pub fn writev(fd: c_int, iov: *const crate::iovec, iovcnt: c_int) -> ssize_t;
pub fn readv(fd: c_int, iov: *const crate::iovec, iovcnt: c_int) -> ssize_t;
// randomNumGen.h
pub fn randBytes(buf: *mut c_uchar, length: c_int) -> c_int;
pub fn randABytes(buf: *mut c_uchar, length: c_int) -> c_int;
pub fn randUBytes(buf: *mut c_uchar, length: c_int) -> c_int;
pub fn randSecure() -> c_int;
// mqueue.h
pub fn mq_open(name: *const c_char, oflag: c_int, ...) -> crate::mqd_t;
pub fn mq_close(mqd: crate::mqd_t) -> c_int;
pub fn mq_unlink(name: *const c_char) -> c_int;
pub fn mq_receive(
mqd: crate::mqd_t,
msg_ptr: *mut c_char,
msg_len: size_t,
msg_prio: *mut c_uint,
) -> ssize_t;
pub fn mq_timedreceive(
mqd: crate::mqd_t,
msg_ptr: *mut c_char,
msg_len: size_t,
msg_prio: *mut c_uint,
abs_timeout: *const crate::timespec,
) -> ssize_t;
pub fn mq_send(
mqd: crate::mqd_t,
msg_ptr: *const c_char,
msg_len: size_t,
msg_prio: c_uint,
) -> c_int;
pub fn mq_timedsend(
mqd: crate::mqd_t,
msg_ptr: *const c_char,
msg_len: size_t,
msg_prio: c_uint,
abs_timeout: *const crate::timespec,
) -> c_int;
pub fn mq_getattr(mqd: crate::mqd_t, attr: *mut crate::mq_attr) -> c_int;
pub fn mq_setattr(
mqd: crate::mqd_t,
newattr: *const crate::mq_attr,
oldattr: *mut crate::mq_attr,
) -> c_int;
// vxCpuLib.h
pub fn vxCpuEnabledGet() -> crate::cpuset_t; // Get set of running CPU's in the system
pub fn vxCpuConfiguredGet() -> crate::cpuset_t; // Get set of Configured CPU's in the system
}
//Dummy functions, these don't really exist in VxWorks.
// wait.h macros
safe_f! {
pub {const} fn WIFEXITED(status: c_int) -> bool {
(status & 0xFF00) == 0
}
pub {const} fn WIFSIGNALED(status: c_int) -> bool {
(status & 0xFF00) != 0
}
pub {const} fn WIFSTOPPED(status: c_int) -> bool {
(status & 0xFF0000) != 0
}
pub {const} fn WEXITSTATUS(status: c_int) -> c_int {
status & 0xFF
}
pub {const} fn WTERMSIG(status: c_int) -> c_int {
(status >> 8) & 0xFF
}
pub {const} 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 as usize % size_of::<size_t>() != 0) {
return crate::EINVAL;
}
unsafe {
// posix_memalign should not set errno
let e = crate::errnoGet();
let temp = memalign(align, size);
crate::errnoSet(e as c_int);
if temp.is_null() {
crate::ENOMEM
} else {
*memptr = temp;
0
}
}
}
cfg_if! {
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 = "x86")] {
mod x86;
pub use self::x86::*;
} else if #[cfg(target_arch = "x86_64")] {
mod x86_64;
pub use self::x86_64::*;
} else if #[cfg(target_arch = "powerpc")] {
mod powerpc;
pub use self::powerpc::*;
} else if #[cfg(target_arch = "powerpc64")] {
mod powerpc64;
pub use self::powerpc64::*;
} else if #[cfg(target_arch = "riscv32")] {
mod riscv32;
pub use self::riscv32::*;
} else if #[cfg(target_arch = "riscv64")] {
mod riscv64;
pub use self::riscv64::*;
} else {
// Unknown target_arch
}
}