#![allow(clippy::cast_possible_truncation)]
#![allow(clippy::cast_possible_wrap)]
#![allow(clippy::cast_sign_loss)]
#![allow(clippy::missing_errors_doc)]
#![allow(clippy::missing_safety_doc)]
#![allow(clippy::similar_names)]
#![allow(clippy::wildcard_imports)]
extern crate alloc;
use crate::c_str::CString;
use crate::path::Path;
use crate::syscalls::*;
use crate::sysno::*;
use crate::types::*;
pub unsafe fn abort2(why: &str, args_len: i32, args: usize) -> ! {
let why = CString::new(why);
let why_ptr = why.as_ptr() as usize;
let args_len = args_len as usize;
let _ = syscall3(SYS_ABORT2, why_ptr, args_len, args);
core::hint::unreachable_unchecked();
}
pub unsafe fn accept(
sockfd: i32,
addr: &mut sockaddr_in_t,
addrlen: &mut socklen_t,
) -> Result<i32, Errno> {
let sockfd = sockfd as usize;
let addr_ptr = addr as *mut sockaddr_in_t as usize;
let addrlen_ptr = addrlen as *mut socklen_t as usize;
syscall3(SYS_ACCEPT, sockfd, addr_ptr, addrlen_ptr).map(|val| val as i32)
}
pub unsafe fn accept4(
sockfd: i32,
addr: &mut sockaddr_in_t,
addrlen: &mut socklen_t,
flags: i32,
) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let addr_ptr = addr as *mut sockaddr_in_t as usize;
let addrlen_ptr = addrlen as *mut socklen_t as usize;
let flags = flags as usize;
syscall4(SYS_ACCEPT4, sockfd, addr_ptr, addrlen_ptr, flags).map(drop)
}
pub unsafe fn access<P: AsRef<Path>>(filename: P, mode: i32) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
syscall2(SYS_ACCESS, filename_ptr, mode).map(drop)
}
pub unsafe fn acct<P: AsRef<Path>>(filename: P) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
syscall1(SYS_ACCT, filename_ptr).map(drop)
}
pub unsafe fn adjtime(delta: &timeval_t, old_delta: &mut timeval_t) -> Result<(), Errno> {
let delta_ptr = delta as *const timeval_t as usize;
let old_delta_ptr = old_delta as *mut timeval_t as usize;
syscall2(SYS_ADJTIME, delta_ptr, old_delta_ptr).map(drop)
}
pub unsafe fn aio_cancel(fd: i32, job: &mut aiocb_t) -> Result<i32, Errno> {
let fd = fd as usize;
let job_ptr = job as *mut aiocb_t as usize;
syscall2(SYS_AIO_CANCEL, fd, job_ptr).map(|val| val as i32)
}
pub unsafe fn aio_error(job: &aiocb_t) -> Result<(), Errno> {
let job_ptr = job as *const aiocb_t as usize;
syscall1(SYS_AIO_ERROR, job_ptr).map(drop)
}
pub unsafe fn aio_fsync(op: i32, job: &mut aiocb_t) -> Result<(), Errno> {
let op = op as usize;
let job_ptr = job as *mut aiocb_t as usize;
syscall2(SYS_AIO_FSYNC, op, job_ptr).map(drop)
}
pub unsafe fn aio_mlock(job: &mut aiocb_t) -> Result<(), Errno> {
let job_ptr = job as *mut aiocb_t as usize;
syscall1(SYS_AIO_MLOCK, job_ptr).map(drop)
}
pub unsafe fn aio_read(job: &mut aiocb_t) -> Result<(), Errno> {
let job_ptr = job as *mut aiocb_t as usize;
syscall1(SYS_AIO_READ, job_ptr).map(drop)
}
pub unsafe fn aio_readv(job: &mut aiocb_t) -> Result<(), Errno> {
let job_ptr = job as *mut aiocb_t as usize;
syscall1(SYS_AIO_READV, job_ptr).map(drop)
}
pub unsafe fn aio_return(job: &mut aiocb_t) -> Result<ssize_t, Errno> {
let job_ptr = job as *mut aiocb_t as usize;
syscall1(SYS_AIO_RETURN, job_ptr).map(|val| val as ssize_t)
}
pub unsafe fn aio_suspend(jobs: &[aiocb_t], timeout: ×pec_t) -> Result<(), Errno> {
let jobs_ptr = jobs.as_ptr() as usize;
let nent = jobs.len();
let timeout_ptr = timeout as *const timespec_t as usize;
syscall3(SYS_AIO_SUSPEND, jobs_ptr, nent, timeout_ptr).map(drop)
}
pub unsafe fn aio_waitcomplete(
job: &mut aiocb_t,
timeout: Option<×pec_t>,
) -> Result<ssize_t, Errno> {
let job_ptr = job as *mut aiocb_t as usize;
let timeout_ptr =
core::mem::transmute::<Option<_>, ×pec_t>(timeout) as *const timespec_t as usize;
syscall2(SYS_AIO_WAITCOMPLETE, job_ptr, timeout_ptr).map(|val| val as ssize_t)
}
pub unsafe fn aio_write(job: &mut aiocb_t) -> Result<(), Errno> {
let job_ptr = job as *mut aiocb_t as usize;
syscall1(SYS_AIO_WRITE, job_ptr).map(drop)
}
pub unsafe fn aio_writev(job: &mut aiocb_t) -> Result<(), Errno> {
let job_ptr = job as *mut aiocb_t as usize;
syscall1(SYS_AIO_WRITEV, job_ptr).map(drop)
}
pub unsafe fn audit(record: &[u8]) -> Result<(), Errno> {
let record_ptr = record.as_ptr() as usize;
let length = record.len();
syscall2(SYS_AUDIT, record_ptr, length).map(drop)
}
pub unsafe fn auditctl<P: AsRef<Path>>(path: P) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
syscall1(SYS_AUDITCTL, path_ptr).map(drop)
}
pub unsafe fn auditon(cmd: i32, data: &[u8]) -> Result<(), Errno> {
let cmd = cmd as usize;
let data_ptr = data.as_ptr() as usize;
let length = data.len();
syscall3(SYS_AUDITON, cmd, data_ptr, length).map(drop)
}
pub unsafe fn bind(sockfd: i32, addr: &sockaddr_t, addrlen: socklen_t) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let addr_ptr = addr as *const sockaddr_t as usize;
let addrlen = addrlen as usize;
syscall3(SYS_BIND, sockfd, addr_ptr, addrlen).map(drop)
}
pub unsafe fn bindat(
fd: i32,
sockfd: i32,
addr: *const sockaddr_t,
addrlen: socklen_t,
) -> Result<(), Errno> {
let fd = fd as usize;
let sockfd = sockfd as usize;
let addr_ptr = addr as usize;
let addrlen = addrlen as usize;
syscall4(SYS_BINDAT, fd, sockfd, addr_ptr, addrlen).map(drop)
}
pub unsafe fn r#break(addr: usize) -> Result<(), Errno> {
syscall1(SYS_BREAK, addr).map(drop)
}
pub unsafe fn cap_enter() -> Result<(), Errno> {
syscall0(SYS_CAP_ENTER).map(drop)
}
pub unsafe fn cap_fcntls_get(fd: i32, fcntl_rights: &mut u32) -> Result<(), Errno> {
let fd = fd as usize;
let fcntl_rights_ptr = fcntl_rights as *mut u32 as usize;
syscall2(SYS_CAP_FCNTLS_GET, fd, fcntl_rights_ptr).map(drop)
}
pub unsafe fn cap_fcntls_limit(fd: i32, fcntl_rights: u32) -> Result<(), Errno> {
let fd = fd as usize;
let fcntl_rights = fcntl_rights as usize;
syscall2(SYS_CAP_FCNTLS_LIMIT, fd, fcntl_rights).map(drop)
}
pub unsafe fn cap_getmode(mode: &mut u32) -> Result<(), Errno> {
let mode_ptr = mode as *mut u32 as usize;
syscall1(SYS_CAP_GETMODE, mode_ptr).map(drop)
}
pub unsafe fn cap_ioctls_get(fd: i32, cmds: &mut [usize]) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let cmds_ptr = cmds.as_mut_ptr() as usize;
let ncmds = cmds.len();
syscall3(SYS_CAP_IOCTLS_GET, fd, cmds_ptr, ncmds).map(|val| val as ssize_t)
}
pub unsafe fn cap_ioctls_limit(fd: i32, cmds: &[usize]) -> Result<(), Errno> {
let fd = fd as usize;
let cmds_ptr = cmds.as_ptr() as usize;
let ncmds = cmds.len();
syscall3(SYS_CAP_IOCTLS_LIMIT, fd, cmds_ptr, ncmds).map(drop)
}
pub unsafe fn cap_rights_limit(fd: i32, rights: &cap_rights_t) -> Result<(), Errno> {
let fd = fd as usize;
let rights_ptr = rights as *const cap_rights_t as usize;
syscall2(SYS_CAP_RIGHTS_LIMIT, fd, rights_ptr).map(drop)
}
pub unsafe fn chdir<P: AsRef<Path>>(filename: P) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
syscall1(SYS_CHDIR, filename_ptr).map(drop)
}
pub unsafe fn chflags<P: AsRef<Path>>(path: P, flags: fflags_t) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let flags = flags as usize;
syscall2(SYS_CHFLAGS, path_ptr, flags).map(drop)
}
pub unsafe fn chflagsat<P: AsRef<Path>>(
fd: i32,
path: P,
flags: fflags_t,
atflag: i32,
) -> Result<(), Errno> {
let fd = fd as usize;
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let flags = flags as usize;
let atflag = atflag as usize;
syscall4(SYS_CHFLAGSAT, fd, path_ptr, flags, atflag).map(drop)
}
pub unsafe fn chmod<P: AsRef<Path>>(filename: P, mode: mode_t) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
syscall2(SYS_CHMOD, filename_ptr, mode).map(drop)
}
pub unsafe fn chown<P: AsRef<Path>>(filename: P, user: uid_t, group: gid_t) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let user = user as usize;
let group = group as usize;
syscall3(SYS_CHOWN, filename_ptr, user, group).map(drop)
}
pub unsafe fn chroot<P: AsRef<Path>>(filename: P) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
syscall1(SYS_CHROOT, filename_ptr).map(drop)
}
pub unsafe fn clock_getcpuclockid2(
id: id_t,
which: i32,
clock_id: &mut clockid_t,
) -> Result<(), Errno> {
let id = id as usize;
let which = which as usize;
let clock_id_ptr = clock_id as *mut clockid_t as usize;
syscall3(SYS_CLOCK_GETCPUCLOCKID2, id, which, clock_id_ptr).map(drop)
}
pub unsafe fn clock_getres(which_clock: clockid_t, tp: &mut timespec_t) -> Result<(), Errno> {
let which_clock = which_clock as usize;
let tp_ptr = tp as *mut timespec_t as usize;
syscall2(SYS_CLOCK_GETRES, which_clock, tp_ptr).map(drop)
}
pub unsafe fn clock_gettime(which_clock: clockid_t, tp: &mut timespec_t) -> Result<(), Errno> {
let which_clock = which_clock as usize;
let tp_ptr = tp as *mut timespec_t as usize;
syscall2(SYS_CLOCK_GETTIME, which_clock, tp_ptr).map(drop)
}
pub unsafe fn clock_nanosleep(
which_clock: clockid_t,
flags: i32,
rqtp: ×pec_t,
rmtp: &mut timespec_t,
) -> Result<(), Errno> {
let which_clock = which_clock as usize;
let flags = flags as usize;
let rqtp_ptr = rqtp as *const timespec_t as usize;
let rmtp_ptr = rmtp as *mut timespec_t as usize;
syscall4(SYS_CLOCK_NANOSLEEP, which_clock, flags, rqtp_ptr, rmtp_ptr).map(drop)
}
pub unsafe fn clock_settime(which_clock: clockid_t, tp: ×pec_t) -> Result<(), Errno> {
let which_clock = which_clock as usize;
let tp_ptr = tp as *const timespec_t as usize;
syscall2(SYS_CLOCK_SETTIME, which_clock, tp_ptr).map(drop)
}
pub unsafe fn close(fd: i32) -> Result<(), Errno> {
let fd = fd as usize;
syscall1(SYS_CLOSE, fd).map(drop)
}
pub unsafe fn close_range(first_fd: u32, last_fd: u32, flags: u32) -> Result<(), Errno> {
let first = first_fd as usize;
let last = last_fd as usize;
let flags = flags as usize;
syscall3(SYS_CLOSE_RANGE, first, last, flags).map(drop)
}
pub unsafe fn connect(
sockfd: i32,
addr: *const sockaddr_t,
addrlen: socklen_t,
) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let addr_ptr = addr as usize;
let addrlen = addrlen as usize;
syscall3(SYS_CONNECT, sockfd, addr_ptr, addrlen).map(drop)
}
pub unsafe fn connectat(
fd: i32,
sockfd: i32,
addr: *const sockaddr_t,
addrlen: socklen_t,
) -> Result<(), Errno> {
let fd = fd as usize;
let sockfd = sockfd as usize;
let addr_ptr = addr as usize;
let addrlen = addrlen as usize;
syscall4(SYS_CONNECTAT, fd, sockfd, addr_ptr, addrlen).map(drop)
}
pub unsafe fn copy_file_range(
fd_in: i32,
off_in: &mut loff_t,
fd_out: i32,
off_out: &mut loff_t,
len: size_t,
flags: u32,
) -> Result<ssize_t, Errno> {
let fd_in = fd_in as usize;
let off_in_ptr = off_in as *mut loff_t as usize;
let fd_out = fd_out as usize;
let off_out_ptr = off_out as *mut loff_t as usize;
let flags = flags as usize;
syscall6(
SYS_COPY_FILE_RANGE,
fd_in,
off_in_ptr,
fd_out,
off_out_ptr,
len,
flags,
)
.map(|ret| ret as ssize_t)
}
pub unsafe fn cpuset(setid: &mut cpuset_t) -> Result<(), Errno> {
let setid_ptr = setid as *mut cpuset_t as usize;
syscall1(SYS_CPUSET, setid_ptr).map(drop)
}
pub unsafe fn cpuset_getaffinity(
level: cpulevel_t,
which: cpuwhich_t,
id: id_t,
mask: &mut [cpuset_t],
) -> Result<(), Errno> {
let level = level as usize;
let which = which as usize;
let id = id as usize;
let mask_len = mask.len();
let mask_ptr = mask.as_mut_ptr() as usize;
syscall5(SYS_CPUSET_GETAFFINITY, level, which, id, mask_ptr, mask_len).map(drop)
}
pub unsafe fn cpuset_getdomain(
level: cpulevel_t,
which: cpuwhich_t,
id: id_t,
domainset_size: size_t,
mask: &mut domainset_t,
policy: &mut i32,
) -> Result<(), Errno> {
let level = level as usize;
let which = which as usize;
let id = id as usize;
let mask_ptr = mask as *mut domainset_t as usize;
let policy_ptr = policy as *mut i32 as usize;
syscall6(
SYS_CPUSET_GETDOMAIN,
level,
which,
id,
domainset_size,
mask_ptr,
policy_ptr,
)
.map(drop)
}
pub unsafe fn cpuset_getid(
level: cpulevel_t,
which: cpuwhich_t,
id: id_t,
setid: &mut cpuset_t,
) -> Result<(), Errno> {
let level = level as usize;
let which = which as usize;
let id = id as usize;
let setid_ptr = setid as *mut cpuset_t as usize;
syscall4(SYS_CPUSET_GETID, level, which, id, setid_ptr).map(drop)
}
pub unsafe fn cpuset_setaffinity(
level: cpulevel_t,
which: cpuwhich_t,
id: id_t,
mask: &[cpuset_t],
) -> Result<(), Errno> {
let level = level as usize;
let which = which as usize;
let id = id as usize;
let mask_len = mask.len();
let mask_ptr = mask.as_ptr() as usize;
syscall5(SYS_CPUSET_SETAFFINITY, level, which, id, mask_ptr, mask_len).map(drop)
}
pub unsafe fn cpuset_setdomain(
level: cpulevel_t,
which: cpuwhich_t,
id: id_t,
domainset_size: size_t,
mask: &domainset_t,
policy: i32,
) -> Result<(), Errno> {
let level = level as usize;
let which = which as usize;
let id = id as usize;
let mask_ptr = mask as *const domainset_t as usize;
let policy = policy as usize;
syscall6(
SYS_CPUSET_SETDOMAIN,
level,
which,
id,
domainset_size,
mask_ptr,
policy,
)
.map(drop)
}
pub unsafe fn cpuset_setid(which: cpuwhich_t, id: id_t, setid: &cpuset_t) -> Result<(), Errno> {
let which = which as usize;
let id = id as usize;
let setid = setid as *const cpuset_t as usize;
syscall3(SYS_CPUSET_SETID, which, id, setid).map(drop)
}
pub unsafe fn dup(oldfd: i32) -> Result<i32, Errno> {
let oldfd = oldfd as usize;
syscall1(SYS_DUP, oldfd).map(|ret| ret as i32)
}
pub unsafe fn dup2(oldfd: i32, newfd: i32) -> Result<(), Errno> {
let oldfd = oldfd as usize;
let newfd = newfd as usize;
syscall2(SYS_DUP2, oldfd, newfd).map(drop)
}
pub unsafe fn eaccess<P: AsRef<Path>>(filename: P, mode: i32) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
syscall2(SYS_EACCESS, filename_ptr, mode).map(drop)
}
pub unsafe fn execve<P: AsRef<Path>>(
filename: P,
argv: &[&str],
env: &[&str],
) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let argv_ptr = argv.as_ptr() as usize;
let env_ptr = env.as_ptr() as usize;
syscall3(SYS_EXECVE, filename_ptr, argv_ptr, env_ptr).map(drop)
}
pub unsafe fn exit(status: i32) -> ! {
let status = status as usize;
let _ret = syscall1(SYS_EXIT, status);
core::hint::unreachable_unchecked();
}
pub unsafe fn extattrctl<P: AsRef<Path>>(
path: P,
cmd: i32,
filename: P,
attr_namespace: i32,
attr_name: &str,
) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let cmd = cmd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let attr_name = CString::new(attr_name);
let attr_name_ptr = attr_name.as_ptr() as usize;
syscall5(
SYS_EXTATTRCTL,
path_ptr,
cmd,
filename_ptr,
attr_namespace,
attr_name_ptr,
)
.map(drop)
}
pub unsafe fn extattr_delete_fd(
fd: i32,
attr_namespace: i32,
attr_name: &str,
) -> Result<(), Errno> {
let fd = fd as usize;
let attr_namespace = attr_namespace as usize;
let attr_name_ptr = attr_name.as_ptr() as usize;
syscall3(SYS_EXTATTR_DELETE_FD, fd, attr_namespace, attr_name_ptr).map(drop)
}
pub unsafe fn extattr_delete_file<P: AsRef<Path>>(
path: P,
attr_namespace: i32,
attr_name: &str,
) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let attr_name_ptr = attr_name.as_ptr() as usize;
syscall3(
SYS_EXTATTR_DELETE_FILE,
path_ptr,
attr_namespace,
attr_name_ptr,
)
.map(drop)
}
pub unsafe fn extattr_delete_link<P: AsRef<Path>>(
path: P,
attr_namespace: i32,
attr_name: &str,
) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let attr_name_ptr = attr_name.as_ptr() as usize;
syscall3(
SYS_EXTATTR_DELETE_LINK,
path_ptr,
attr_namespace,
attr_name_ptr,
)
.map(drop)
}
pub unsafe fn extattr_get_fd(
fd: i32,
attr_namespace: i32,
attr_name: &str,
data: &mut [u8],
) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let attr_namespace = attr_namespace as usize;
let attr_name_ptr = attr_name.as_ptr() as usize;
let data_ptr = data.as_mut_ptr() as usize;
let nbytes = data.len();
syscall5(
SYS_EXTATTR_GET_FILE,
fd,
attr_namespace,
attr_name_ptr,
data_ptr,
nbytes,
)
.map(|val| val as ssize_t)
}
pub unsafe fn extattr_get_file<P: AsRef<Path>>(
path: P,
attr_namespace: i32,
attr_name: &str,
data: &mut [u8],
) -> Result<ssize_t, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let attr_name = CString::new(attr_name);
let attr_name_ptr = attr_name.as_ptr() as usize;
let data_ptr = data.as_mut_ptr() as usize;
let nbytes = data.len();
syscall5(
SYS_EXTATTR_GET_FILE,
path_ptr,
attr_namespace,
attr_name_ptr,
data_ptr,
nbytes,
)
.map(|val| val as ssize_t)
}
pub unsafe fn extattr_get_link<P: AsRef<Path>>(
path: P,
attr_namespace: i32,
attr_name: &str,
data: &mut [u8],
) -> Result<ssize_t, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let attr_name_ptr = attr_name.as_ptr() as usize;
let data_ptr = data.as_mut_ptr() as usize;
let nbytes = data.len();
syscall5(
SYS_EXTATTR_GET_LINK,
path_ptr,
attr_namespace,
attr_name_ptr,
data_ptr,
nbytes,
)
.map(|val| val as ssize_t)
}
pub unsafe fn extattr_list_fd(
fd: i32,
attr_namespace: i32,
data: &mut [u8],
) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let attr_namespace = attr_namespace as usize;
let data_ptr = data.as_mut_ptr() as usize;
let nbytes = data.len();
syscall4(SYS_EXTATTR_LIST_FD, fd, attr_namespace, data_ptr, nbytes).map(|val| val as ssize_t)
}
pub unsafe fn extattr_list_file<P: AsRef<Path>>(
path: P,
attr_namespace: i32,
data: &mut [u8],
) -> Result<ssize_t, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let data_ptr = data.as_mut_ptr() as usize;
let nbytes = data.len();
syscall4(
SYS_EXTATTR_LIST_FILE,
path_ptr,
attr_namespace,
data_ptr,
nbytes,
)
.map(|val| val as ssize_t)
}
pub unsafe fn extattr_list_link<P: AsRef<Path>>(
path: P,
attr_namespace: i32,
data: &mut [u8],
) -> Result<ssize_t, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let data_ptr = data.as_mut_ptr() as usize;
let nbytes = data.len();
syscall4(
SYS_EXTATTR_LIST_LINK,
path_ptr,
attr_namespace,
data_ptr,
nbytes,
)
.map(|val| val as ssize_t)
}
pub unsafe fn extattr_set_fd(
fd: i32,
attr_namespace: i32,
attr_name: &str,
data: &[u8],
) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let attr_namespace = attr_namespace as usize;
let attr_name_ptr = attr_name.as_ptr() as usize;
let data_ptr = data.as_ptr() as usize;
let nbytes = data.len();
syscall5(
SYS_EXTATTR_SET_FD,
fd,
attr_namespace,
attr_name_ptr,
data_ptr,
nbytes,
)
.map(|val| val as ssize_t)
}
pub unsafe fn extattr_set_file<P: AsRef<Path>>(
path: P,
attr_namespace: i32,
attr_name: &str,
data: &[u8],
) -> Result<ssize_t, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let attr_name = CString::new(attr_name);
let attr_name_ptr = attr_name.as_ptr() as usize;
let data_ptr = data.as_ptr() as usize;
let nbytes = data.len();
syscall5(
SYS_EXTATTR_SET_FILE,
path_ptr,
attr_namespace,
attr_name_ptr,
data_ptr,
nbytes,
)
.map(|val| val as ssize_t)
}
pub unsafe fn extattr_set_link<P: AsRef<Path>>(
path: P,
attr_namespace: i32,
attr_name: &str,
data: &[u8],
) -> Result<ssize_t, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let attr_namespace = attr_namespace as usize;
let attr_name_ptr = attr_name.as_ptr() as usize;
let data_ptr = data.as_ptr() as usize;
let nbytes = data.len();
syscall5(
SYS_EXTATTR_SET_LINK,
path_ptr,
attr_namespace,
attr_name_ptr,
data_ptr,
nbytes,
)
.map(|val| val as ssize_t)
}
pub unsafe fn faccessat<P: AsRef<Path>>(dfd: i32, filename: P, mode: i32) -> Result<(), Errno> {
let dfd = dfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
syscall3(SYS_FACCESSAT, dfd, filename_ptr, mode).map(drop)
}
pub unsafe fn fchdir(fd: i32) -> Result<(), Errno> {
let fd = fd as usize;
syscall1(SYS_FCHDIR, fd).map(drop)
}
pub unsafe fn fchflags(fd: i32, flags: fflags_t) -> Result<(), Errno> {
let fd = fd as usize;
let flags = flags as usize;
syscall2(SYS_FCHFLAGS, fd, flags).map(drop)
}
pub unsafe fn fchmod(fd: i32, mode: mode_t) -> Result<(), Errno> {
let fd = fd as usize;
let mode = mode as usize;
syscall2(SYS_FCHMOD, fd, mode).map(drop)
}
pub unsafe fn fchmodat<P: AsRef<Path>>(dirfd: i32, filename: P, mode: mode_t) -> Result<(), Errno> {
let dirfd = dirfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
syscall3(SYS_FCHMODAT, dirfd, filename_ptr, mode).map(drop)
}
pub unsafe fn fchown(fd: i32, user: uid_t, group: gid_t) -> Result<(), Errno> {
let fd = fd as usize;
let user = user as usize;
let group = group as usize;
syscall3(SYS_FCHOWN, fd, user, group).map(drop)
}
pub unsafe fn fchownat<P: AsRef<Path>>(
dirfd: i32,
filename: P,
user: uid_t,
group: gid_t,
flag: i32,
) -> Result<(), Errno> {
let dirfd = dirfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let user = user as usize;
let group = group as usize;
let flag = flag as usize;
syscall5(SYS_FCHOWNAT, dirfd, filename_ptr, user, group, flag).map(drop)
}
pub unsafe fn fcntl(fd: i32, cmd: i32, arg: usize) -> Result<i32, Errno> {
let fd = fd as usize;
let cmd = cmd as usize;
syscall3(SYS_FCNTL, fd, cmd, arg).map(|ret| ret as i32)
}
pub unsafe fn fdatasync(fd: i32) -> Result<(), Errno> {
let fd = fd as usize;
syscall1(SYS_FDATASYNC, fd).map(drop)
}
pub unsafe fn fexecve(fd: i32, argv: &[&str], env: &[&str]) -> Result<(), Errno> {
let fd = fd as usize;
let argv_ptr = argv.as_ptr() as usize;
let env_ptr = env.as_ptr() as usize;
syscall3(SYS_FEXECVE, fd, argv_ptr, env_ptr).map(drop)
}
pub unsafe fn ffclock_getcounter(ffcount: &mut ffcounter_t) -> Result<(), Errno> {
let ffcount_ptr = ffcount as *mut ffcounter_t as usize;
syscall1(SYS_FFCLOCK_GETCOUNTER, ffcount_ptr).map(drop)
}
pub unsafe fn ffclock_getestimate(cest: &mut ffclock_estimate_t) -> Result<(), Errno> {
let cest_ptr = cest as *mut ffclock_estimate_t as usize;
syscall1(SYS_FFCLOCK_GETESTIMATE, cest_ptr).map(drop)
}
pub unsafe fn ffclock_setestimate(cest: &mut ffclock_estimate_t) -> Result<(), Errno> {
let cest_ptr = cest as *mut ffclock_estimate_t as usize;
syscall1(SYS_FFCLOCK_SETESTIMATE, cest_ptr).map(drop)
}
pub unsafe fn fhlink<P: AsRef<Path>>(fh: &mut fhandle_t, to: P) -> Result<(), Errno> {
let fh_ptr = fh as *mut fhandle_t as usize;
let to = CString::new(to.as_ref());
let to_ptr = to.as_ptr() as usize;
syscall2(SYS_FHLINK, fh_ptr, to_ptr).map(drop)
}
pub unsafe fn fhlinkat<P: AsRef<Path>>(fh: &mut fhandle_t, tofd: i32, to: P) -> Result<(), Errno> {
let fh_ptr = fh as *mut fhandle_t as usize;
let tofd = tofd as usize;
let to = CString::new(to.as_ref());
let to_ptr = to.as_ptr() as usize;
syscall3(SYS_FHLINKAT, fh_ptr, tofd, to_ptr).map(drop)
}
pub unsafe fn fhopen(fh: &fhandle_t, flags: i32) -> Result<i32, Errno> {
let fh_ptr = fh as *const fhandle_t as usize;
let flags = flags as usize;
syscall2(SYS_FHOPEN, fh_ptr, flags).map(|val| val as i32)
}
pub unsafe fn fhreadlink(fh: &mut fhandle_t, buf: &mut [u8]) -> Result<i32, Errno> {
let fh_ptr = fh as *mut fhandle_t as usize;
let buf_ptr = buf.as_mut_ptr() as usize;
syscall2(SYS_FHREADLINK, fh_ptr, buf_ptr).map(|val| val as i32)
}
pub unsafe fn fhstat(fh: &fhandle_t, sb: &mut stat_t) -> Result<(), Errno> {
let fh_ptr = fh as *const fhandle_t as usize;
let sb_ptr = sb as *mut stat_t as usize;
syscall2(SYS_FHSTAT, fh_ptr, sb_ptr).map(drop)
}
pub unsafe fn fhstatfs(fh: &fhandle_t, buf: &mut statfs_t) -> Result<(), Errno> {
let fh_ptr = fh as *const fhandle_t as usize;
let buf_ptr = buf as *mut statfs_t as usize;
syscall2(SYS_FHSTATFS, fh_ptr, buf_ptr).map(drop)
}
pub unsafe fn flock(fd: i32, operation: i32) -> Result<(), Errno> {
let fd = fd as usize;
let operation = operation as usize;
syscall2(SYS_FLOCK, fd, operation).map(drop)
}
pub unsafe fn fork() -> Result<pid_t, Errno> {
syscall0(SYS_FORK).map(|ret| ret as pid_t)
}
pub unsafe fn fpathconf(fd: i32, name: i32) -> Result<isize, Errno> {
let fd = fd as usize;
let name = name as usize;
syscall2(SYS_FPATHCONF, fd, name).map(|val| val as isize)
}
pub unsafe fn freebsd10_pipe() -> Result<(), Errno> {
syscall0(SYS_FREEBSD10_PIPE).map(drop)
}
pub unsafe fn fstat(fd: i32, statbuf: &mut stat_t) -> Result<(), Errno> {
let fd = fd as usize;
let statbuf_ptr = statbuf as *mut stat_t as usize;
syscall2(SYS_FSTAT, fd, statbuf_ptr).map(drop)
}
pub unsafe fn fstatat<P: AsRef<Path>>(
dfd: i32,
filename: P,
statbuf: &mut stat_t,
flag: i32,
) -> Result<(), Errno> {
let dfd = dfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let statbuf_ptr = statbuf as *mut stat_t as usize;
let flag = flag as usize;
syscall4(SYS_FSTATAT, dfd, filename_ptr, statbuf_ptr, flag).map(drop)
}
pub unsafe fn fstatfs(fd: i32, buf: &mut statfs_t) -> Result<(), Errno> {
let fd = fd as usize;
let buf_ptr = buf as *mut statfs_t as usize;
syscall2(SYS_FSTATFS, fd, buf_ptr).map(drop)
}
pub unsafe fn fsync(fd: i32) -> Result<(), Errno> {
let fd = fd as usize;
syscall1(SYS_FSYNC, fd).map(drop)
}
pub unsafe fn ftruncate(fd: i32, length: off_t) -> Result<(), Errno> {
let fd = fd as usize;
let length = length as usize;
syscall2(SYS_FTRUNCATE, fd, length).map(drop)
}
pub unsafe fn funlinkat<P: AsRef<Path>>(
dfd: i32,
filename: P,
fd: i32,
flag: i32,
) -> Result<(), Errno> {
let dfd = dfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let fd = fd as usize;
let flag = flag as usize;
syscall4(SYS_FUNLINKAT, dfd, filename_ptr, fd, flag).map(drop)
}
pub unsafe fn futimens(fd: i32, times: &[timespec_t; 2]) -> Result<(), Errno> {
let fd = fd as usize;
let times_ptr = times.as_ptr() as usize;
syscall2(SYS_FUTIMENS, fd, times_ptr).map(drop)
}
pub unsafe fn futimes(fd: i32, times: &[timeval_t; 2]) -> Result<(), Errno> {
let fd = fd as usize;
let times_ptr = times.as_ptr() as usize;
syscall2(SYS_FUTIMES, fd, times_ptr).map(drop)
}
pub unsafe fn futimesat<P: AsRef<Path>>(
dirfd: i32,
filename: P,
times: &[timeval_t; 2],
) -> Result<(), Errno> {
let dirfd = dirfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let times_ptr = times.as_ptr() as usize;
syscall3(SYS_FUTIMESAT, dirfd, filename_ptr, times_ptr).map(drop)
}
pub unsafe fn getaudit(info: &mut auditinfo_t) -> Result<(), Errno> {
let info_ptr = info as *mut auditinfo_t as usize;
syscall1(SYS_GETAUDIT, info_ptr).map(drop)
}
pub unsafe fn getaudit_addr(info: &mut auditinfo_addr_t, length: u32) -> Result<(), Errno> {
let info_ptr = info as *mut auditinfo_addr_t as usize;
let length = length as usize;
syscall2(SYS_GETAUDIT_ADDR, info_ptr, length).map(drop)
}
pub unsafe fn getauid(auid: &mut au_id_t) -> Result<(), Errno> {
let auid_ptr = auid as *mut au_id_t as usize;
syscall1(SYS_GETAUID, auid_ptr).map(drop)
}
pub unsafe fn getcontext(ctx: &mut ucontext_t) -> Result<(), Errno> {
let ctx_ptr = ctx as *mut ucontext_t as usize;
syscall1(SYS_GETCONTEXT, ctx_ptr).map(drop)
}
pub unsafe fn getdirentries(fd: i32, buf: &mut [c_char], off: off_t) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let buf_ptr = buf.as_mut_ptr() as usize;
let buf_len = buf.len();
let off = off as usize;
syscall4(SYS_GETDIRENTRIES, fd, buf_ptr, buf_len, off).map(|ret| ret as ssize_t)
}
pub unsafe fn getdtablesize() -> Result<i32, Errno> {
syscall0(SYS_GETDTABLESIZE).map(|val| val as i32)
}
#[must_use]
pub unsafe fn getegid() -> gid_t {
syscall0(SYS_GETEGID).expect("getegid() failed") as gid_t
}
#[must_use]
pub unsafe fn geteuid() -> uid_t {
syscall0(SYS_GETEUID).expect("geteuid() failed") as uid_t
}
pub unsafe fn getfh<P: AsRef<Path>>(path: P, fh: &mut fhandle_t) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let fh_ptr = fh as *mut fhandle_t as usize;
syscall2(SYS_GETFH, path_ptr, fh_ptr).map(drop)
}
pub unsafe fn getfhat<P: AsRef<Path>>(
fd: i32,
path: P,
fh: &mut fhandle_t,
flag: i32,
) -> Result<(), Errno> {
let fd = fd as usize;
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let fh_ptr = fh as *mut fhandle_t as usize;
let flag = flag as usize;
syscall4(SYS_GETFHAT, fd, path_ptr, fh_ptr, flag).map(drop)
}
pub unsafe fn getfsstat(buf: Option<&mut [statfs_t]>, mode: i32) -> Result<i32, Errno> {
let buf_size = buf
.as_ref()
.map_or(0, |buf| buf.len() * core::mem::size_of::<statfs_t>());
let buf_ptr = buf.map_or(0, |buf| buf.as_mut_ptr() as usize);
let mode = mode as usize;
syscall3(SYS_GETFSSTAT, buf_ptr, buf_size, mode).map(|val| val as i32)
}
#[must_use]
pub unsafe fn getgid() -> gid_t {
syscall0(SYS_GETGID).expect("getgid() failed") as gid_t
}
pub unsafe fn getgroups(size: i32, group_list: &mut [gid_t]) -> Result<i32, Errno> {
let size = size as usize;
let group_ptr = group_list.as_mut_ptr() as usize;
syscall2(SYS_GETGROUPS, size, group_ptr).map(|ret| ret as i32)
}
pub unsafe fn getitimer(which: i32, curr_val: &mut itimerval_t) -> Result<(), Errno> {
let which = which as usize;
let curr_val_ptr = curr_val as *mut itimerval_t as usize;
syscall2(SYS_GETITIMER, which, curr_val_ptr).map(drop)
}
pub unsafe fn getlogin(name: &mut [u8]) -> Result<(), Errno> {
let name_ptr = name.as_mut_ptr() as usize;
let len = name.len();
syscall2(SYS_GETLOGIN, name_ptr, len).map(drop)
}
pub unsafe fn getloginclass(name: &mut [u8]) -> Result<(), Errno> {
let name_ptr = name.as_mut_ptr() as usize;
let len = name.len();
syscall2(SYS_GETLOGINCLASS, name_ptr, len).map(drop)
}
pub unsafe fn getpeername(
sockfd: i32,
addr: &mut sockaddr_in_t,
addrlen: &mut socklen_t,
) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let addr_ptr = addr as *mut sockaddr_in_t as usize;
let addrlen_ptr = addrlen as *mut socklen_t as usize;
syscall3(SYS_GETPEERNAME, sockfd, addr_ptr, addrlen_ptr).map(drop)
}
pub unsafe fn getpgid(pid: pid_t) -> Result<pid_t, Errno> {
let pid = pid as usize;
syscall1(SYS_GETPGID, pid).map(|ret| ret as pid_t)
}
#[must_use]
pub unsafe fn getpgrp() -> pid_t {
syscall0(SYS_GETPGRP).expect("getpgrp() failed") as pid_t
}
#[must_use]
pub unsafe fn getpid() -> pid_t {
syscall0(SYS_GETPID).expect("getpid() failed") as pid_t
}
#[must_use]
pub unsafe fn getppid() -> pid_t {
syscall0(SYS_GETPPID).expect("getppid() failed") as pid_t
}
pub unsafe fn getpriority(which: i32, who: i32) -> Result<i32, Errno> {
let which = which as usize;
let who = who as usize;
syscall2(SYS_GETPRIORITY, which, who).map(|ret| {
let ret = ret as i32;
if ret > PRIO_MAX {
return PRIO_MAX - ret;
}
ret
})
}
pub unsafe fn getrandom(buf: &mut [u8], buf_len: usize, flags: u32) -> Result<ssize_t, Errno> {
let buf_ptr = buf.as_mut_ptr() as usize;
let flags = flags as usize;
syscall3(SYS_GETRANDOM, buf_ptr, buf_len, flags).map(|ret| ret as ssize_t)
}
pub unsafe fn getresgid(rgid: &mut gid_t, egid: &mut gid_t, sgid: &mut gid_t) -> Result<(), Errno> {
let rgid_ptr = rgid as *mut gid_t as usize;
let egid_ptr = egid as *mut gid_t as usize;
let sgid_ptr = sgid as *mut gid_t as usize;
syscall3(SYS_GETRESGID, rgid_ptr, egid_ptr, sgid_ptr).map(drop)
}
pub unsafe fn getresuid(ruid: &mut uid_t, euid: &mut uid_t, suid: &mut uid_t) -> Result<(), Errno> {
let ruid_ptr = ruid as *mut uid_t as usize;
let euid_ptr = euid as *mut uid_t as usize;
let suid_ptr = suid as *mut uid_t as usize;
syscall3(SYS_GETRESUID, ruid_ptr, euid_ptr, suid_ptr).map(drop)
}
pub unsafe fn getrlimit(resource: i32, rlim: &mut rlimit_t) -> Result<(), Errno> {
let resource = resource as usize;
let rlim_ptr = rlim as *mut rlimit_t as usize;
syscall2(SYS_GETRLIMIT, resource, rlim_ptr).map(drop)
}
pub unsafe fn getrusage(who: i32, usage: &mut rusage_t) -> Result<(), Errno> {
let who = who as usize;
let usage_ptr = usage as *mut rusage_t as usize;
syscall2(SYS_GETRUSAGE, who, usage_ptr).map(drop)
}
#[must_use]
pub unsafe fn getsid(pid: pid_t) -> pid_t {
let pid = pid as usize;
syscall1(SYS_GETSID, pid).expect("getsid() failed") as pid_t
}
pub unsafe fn getsockname(
sockfd: i32,
addr: &mut sockaddr_in_t,
addrlen: &mut socklen_t,
) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let addr_ptr = addr as *mut sockaddr_in_t as usize;
let addrlen_ptr = addrlen as *mut socklen_t as usize;
syscall3(SYS_GETSOCKNAME, sockfd, addr_ptr, addrlen_ptr).map(drop)
}
pub unsafe fn getsockopt(
sockfd: i32,
level: i32,
optname: i32,
optval: &mut usize,
optlen: &mut socklen_t,
) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let level = level as usize;
let optname = optname as usize;
let optval_ptr = optval as *mut usize as usize;
let optlen_ptr = optlen as *mut socklen_t as usize;
syscall5(
SYS_GETSOCKOPT,
sockfd,
level,
optname,
optval_ptr,
optlen_ptr,
)
.map(drop)
}
pub unsafe fn gettimeofday(timeval: &mut timeval_t, tz: &mut timezone_t) -> Result<(), Errno> {
let timeval_ptr = timeval as *mut timeval_t as usize;
let tz_ptr = tz as *mut timezone_t as usize;
syscall2(SYS_GETTIMEOFDAY, timeval_ptr, tz_ptr).map(drop)
}
#[must_use]
pub unsafe fn getuid() -> uid_t {
syscall0(SYS_GETUID).expect("getuid() failed") as uid_t
}
pub unsafe fn ioctl(fd: i32, cmd: i32, arg: usize) -> Result<(), Errno> {
let fd = fd as usize;
let cmd = cmd as usize;
syscall3(SYS_IOCTL, fd, cmd, arg).map(drop)
}
#[must_use]
pub unsafe fn issetugid() -> i32 {
syscall0(SYS_ISSETUGID)
.map(|val| val as i32)
.expect("issetugid() failed")
}
pub unsafe fn jail(conf: &jail_t) -> Result<i32, Errno> {
let conf_ptr = conf as *const jail_t as usize;
syscall1(SYS_JAIL, conf_ptr).map(|ret| ret as i32)
}
pub unsafe fn jail_attach(jid: i32) -> Result<(), Errno> {
let jid = jid as usize;
syscall1(SYS_JAIL_ATTACH, jid).map(drop)
}
pub unsafe fn jail_get(iov: &mut [iovec_t], flags: i32) -> Result<i32, Errno> {
let iov_ptr = iov.as_mut_ptr() as usize;
let iov_len = iov.len();
let flags = flags as usize;
syscall3(SYS_JAIL_GET, iov_ptr, iov_len, flags).map(|val| val as i32)
}
pub unsafe fn jail_remove(jid: i32) -> Result<(), Errno> {
let jid = jid as usize;
syscall1(SYS_JAIL_REMOVE, jid).map(drop)
}
pub unsafe fn jail_set(iov: &mut [iovec_t], flags: i32) -> Result<i32, Errno> {
let iov_ptr = iov.as_mut_ptr() as usize;
let iov_len = iov.len();
let flags = flags as usize;
syscall3(SYS_JAIL_SET, iov_ptr, iov_len, flags).map(|val| val as i32)
}
pub unsafe fn kenv(action: i32, name: &str, value: Option<&mut [u8]>) -> Result<i32, Errno> {
let action = action as usize;
let name = CString::new(name);
let name_ptr = name.as_ptr() as usize;
let value_ptr = value.map_or(0, |value| value.as_mut_ptr() as usize);
syscall3(SYS_KENV, action, name_ptr, value_ptr).map(|val| val as i32)
}
pub unsafe fn kill(pid: pid_t, signal: i32) -> Result<(), Errno> {
let pid = pid as usize;
let signal = signal as usize;
syscall2(SYS_KILL, pid, signal).map(drop)
}
pub unsafe fn kldfind<P: AsRef<Path>>(file: P) -> Result<i32, Errno> {
let file = CString::new(file.as_ref());
let file_ptr = file.as_ptr() as usize;
syscall1(SYS_KLDFIND, file_ptr).map(|ret| ret as i32)
}
pub unsafe fn kldfirstmod(file_id: i32) -> Result<i32, Errno> {
let file_id = file_id as usize;
syscall1(SYS_KLDFIRSTMOD, file_id).map(|ret| ret as i32)
}
pub unsafe fn kldload<P: AsRef<Path>>(file: P) -> Result<i32, Errno> {
let file = CString::new(file.as_ref());
let file_ptr = file.as_ptr() as usize;
syscall1(SYS_KLDLOAD, file_ptr).map(|ret| ret as i32)
}
pub unsafe fn kldnext(file_id: i32) -> Result<i32, Errno> {
let file_id = file_id as usize;
syscall1(SYS_KLDNEXT, file_id).map(|ret| ret as i32)
}
pub unsafe fn kldstat(file_id: i32, stat: &mut kld_file_stat_t) -> Result<(), Errno> {
let file_id = file_id as usize;
let stat_ptr = stat as *mut kld_file_stat_t as usize;
syscall2(SYS_KLDSTAT, file_id, stat_ptr).map(drop)
}
pub unsafe fn kldsym(file_id: i32, cmd: i32, data: usize) -> Result<(), Errno> {
let file_id = file_id as usize;
let cmd = cmd as usize;
syscall3(SYS_KLDSYM, file_id, cmd, data).map(drop)
}
pub unsafe fn kldunload(file_id: i32) -> Result<(), Errno> {
let file_id = file_id as usize;
syscall1(SYS_KLDUNLOAD, file_id).map(drop)
}
pub unsafe fn kldunloadf(file_id: i32, flags: i32) -> Result<(), Errno> {
let file_id = file_id as usize;
let flags = flags as usize;
syscall2(SYS_KLDUNLOAD, file_id, flags).map(drop)
}
pub unsafe fn kmq_notify(mqd: i32, event: &sigevent_t) -> Result<(), Errno> {
let mqd = mqd as usize;
let event_ptr = event as *const sigevent_t as usize;
syscall2(SYS_KMQ_NOTIFY, mqd, event_ptr).map(drop)
}
pub unsafe fn kmq_open<P: AsRef<Path>>(
path: P,
flags: i32,
mode: mode_t,
attr: &mq_attr_t,
) -> Result<i32, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let flags = flags as usize;
let mode = mode as usize;
let attr_ptr = attr as *const mq_attr_t as usize;
syscall4(SYS_KMQ_OPEN, path_ptr, flags, mode, attr_ptr).map(|ret| ret as i32)
}
pub unsafe fn kmq_setattr(
mqd: i32,
attr: &mq_attr_t,
old_attr: &mut mq_attr_t,
) -> Result<(), Errno> {
let mqd = mqd as usize;
let attr_ptr = attr as *const mq_attr_t as usize;
let old_attr_ptr = old_attr as *mut mq_attr_t as usize;
syscall3(SYS_KMQ_SETATTR, mqd, attr_ptr, old_attr_ptr).map(drop)
}
pub unsafe fn kmq_timedreceive(
mqd: i32,
msg: &mut [u8],
msg_len: usize,
msg_prio: u32,
abs_timeout: ×pec_t,
) -> Result<ssize_t, Errno> {
let mqd = mqd as usize;
let msg_ptr = msg.as_mut_ptr() as usize;
let msg_prio = msg_prio as usize;
let abs_timeout_ptr = abs_timeout as *const timespec_t as usize;
syscall5(
SYS_KMQ_TIMEDRECEIVE,
mqd,
msg_ptr,
msg_len,
msg_prio,
abs_timeout_ptr,
)
.map(|val| val as ssize_t)
}
pub unsafe fn kmq_timedsend(
mqd: i32,
msg: &[u8],
msg_prio: u32,
abs_timeout: ×pec_t,
) -> Result<(), Errno> {
let mqd = mqd as usize;
let msg_ptr = msg.as_ptr() as usize;
let msg_len = msg.len();
let msg_prio = msg_prio as usize;
let abs_timeout_ptr = abs_timeout as *const timespec_t as usize;
syscall5(
SYS_KMQ_TIMEDSEND,
mqd,
msg_ptr,
msg_len,
msg_prio,
abs_timeout_ptr,
)
.map(drop)
}
pub unsafe fn kmq_unlink<P: AsRef<Path>>(path: P) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
syscall1(SYS_KMQ_UNLINK, path_ptr).map(drop)
}
pub unsafe fn kqueue() -> Result<i32, Errno> {
syscall0(SYS_KQUEUE).map(|val| val as i32)
}
pub unsafe fn ksem_close(id: semid_t) -> Result<(), Errno> {
let id = id as usize;
syscall1(SYS_KSEM_CLOSE, id).map(drop)
}
pub unsafe fn ksem_destroy(id: semid_t) -> Result<(), Errno> {
let id = id as usize;
syscall1(SYS_KSEM_DESTROY, id).map(drop)
}
pub unsafe fn ksem_getvalue(id: semid_t, value: &mut i32) -> Result<(), Errno> {
let id = id as usize;
let value_ptr = value as *mut i32 as usize;
syscall2(SYS_KSEM_GETVALUE, id, value_ptr).map(drop)
}
pub unsafe fn ksem_init(value: u32, id: &mut semid_t) -> Result<(), Errno> {
let value = value as usize;
let id_ptr = id as *mut semid_t as usize;
syscall2(SYS_KSEM_INIT, value, id_ptr).map(drop)
}
pub unsafe fn ksem_open<P: AsRef<Path>>(
name: P,
flags: i32,
mode: mode_t,
value: u32,
id: &mut semid_t,
) -> Result<i32, Errno> {
let name = CString::new(name.as_ref());
let name_ptr = name.as_ptr() as usize;
let flags = flags as usize;
let mode = mode as usize;
let value = value as usize;
let id_ptr = id as *mut semid_t as usize;
syscall5(SYS_KSEM_OPEN, name_ptr, flags, mode, value, id_ptr).map(|ret| ret as i32)
}
pub unsafe fn ksem_post(id: semid_t) -> Result<(), Errno> {
let id = id as usize;
syscall1(SYS_KSEM_POST, id).map(drop)
}
pub unsafe fn ksem_timedwait(id: semid_t, abstime: ×pec_t) -> Result<(), Errno> {
let id = id as usize;
let abstime_ptr = abstime as *const timespec_t as usize;
syscall2(SYS_KSEM_TIMEDWAIT, id, abstime_ptr).map(drop)
}
pub unsafe fn ksem_trywait(id: semid_t) -> Result<(), Errno> {
let id = id as usize;
syscall1(SYS_KSEM_TRYWAIT, id).map(drop)
}
pub unsafe fn ksem_unlink<P: AsRef<Path>>(name: P) -> Result<(), Errno> {
let name = CString::new(name.as_ref());
let name_ptr = name.as_ptr() as usize;
syscall1(SYS_KSEM_UNLINK, name_ptr).map(drop)
}
pub unsafe fn ksem_wait(id: semid_t) -> Result<(), Errno> {
let id = id as usize;
syscall1(SYS_KSEM_WAIT, id).map(drop)
}
pub unsafe fn ktimer_craete(
clockid: clockid_t,
evp: &mut sigevent_t,
timer_id: &mut i32,
) -> Result<(), Errno> {
let clockid = clockid as usize;
let evp_ptr = evp as *mut sigevent_t as usize;
let timer_id_ptr = timer_id as *mut i32 as usize;
syscall3(SYS_KTIMER_CREATE, clockid, evp_ptr, timer_id_ptr).map(drop)
}
pub unsafe fn ktimer_delete(timer_id: i32) -> Result<(), Errno> {
let timer_id = timer_id as usize;
syscall1(SYS_KTIMER_DELETE, timer_id).map(drop)
}
pub unsafe fn ktimer_getoverrun(timer_id: i32) -> Result<i32, Errno> {
let timer_id = timer_id as usize;
syscall1(SYS_KTIMER_GETOVERRUN, timer_id).map(|val| val as i32)
}
pub unsafe fn ktimer_gettime(timer_id: i32, value: &mut itimerspec_t) -> Result<(), Errno> {
let timer_id = timer_id as usize;
let value_ptr = value as *mut itimerspec_t as usize;
syscall2(SYS_KTIMER_GETTIME, timer_id, value_ptr).map(drop)
}
pub unsafe fn ktimer_settime(
timer_id: i32,
flags: i32,
value: &itimerspec_t,
ovalue: &mut itimerspec_t,
) -> Result<(), Errno> {
let timer_id = timer_id as usize;
let flags = flags as usize;
let value_ptr = value as *const itimerspec_t as usize;
let ovalue_ptr = ovalue as *mut itimerspec_t as usize;
syscall4(SYS_KTIMER_SETTIME, timer_id, flags, value_ptr, ovalue_ptr).map(drop)
}
pub unsafe fn ktrace<P: AsRef<Path>>(
tracefile: P,
ops: i32,
facs: i32,
pid: i32,
) -> Result<(), Errno> {
let tracefile = CString::new(tracefile.as_ref());
let tracefile_ptr = tracefile.as_ptr() as usize;
let ops = ops as usize;
let facs = facs as usize;
let pid = pid as usize;
syscall4(SYS_KTRACE, tracefile_ptr, ops, facs, pid).map(drop)
}
pub unsafe fn lchflags<P: AsRef<Path>>(path: P, flags: fflags_t) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let flags = flags as usize;
syscall2(SYS_LCHFLAGS, path_ptr, flags).map(drop)
}
pub unsafe fn lchmod<P: AsRef<Path>>(filename: P, mode: mode_t) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
syscall2(SYS_LCHMOD, filename_ptr, mode).map(drop)
}
pub unsafe fn lchown<P: AsRef<Path>>(filename: P, user: uid_t, group: gid_t) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let user = user as usize;
let group = group as usize;
syscall3(SYS_LCHOWN, filename_ptr, user, group).map(drop)
}
pub unsafe fn lgetfh<P: AsRef<Path>>(path: P, fh: &mut fhandle_t) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let fh_ptr = fh as *mut fhandle_t as usize;
syscall2(SYS_LGETFH, path_ptr, fh_ptr).map(drop)
}
pub unsafe fn link<P: AsRef<Path>>(old_filename: P, new_filename: P) -> Result<(), Errno> {
let old_filename = CString::new(old_filename.as_ref());
let old_filename_ptr = old_filename.as_ptr() as usize;
let new_filename = CString::new(new_filename.as_ref());
let new_filename_ptr = new_filename.as_ptr() as usize;
syscall2(SYS_LINK, old_filename_ptr, new_filename_ptr).map(drop)
}
pub unsafe fn linkat<P: AsRef<Path>>(
olddfd: i32,
oldfilename: P,
newdfd: i32,
newfilename: P,
flags: i32,
) -> Result<(), Errno> {
let olddfd = olddfd as usize;
let oldfilename = CString::new(oldfilename.as_ref());
let oldfilename_ptr = oldfilename.as_ptr() as usize;
let newdfd = newdfd as usize;
let newfilename = CString::new(newfilename.as_ref());
let newfilename_ptr = newfilename.as_ptr() as usize;
let flags = flags as usize;
syscall5(
SYS_LINKAT,
olddfd,
oldfilename_ptr,
newdfd,
newfilename_ptr,
flags,
)
.map(drop)
}
pub unsafe fn listen(sockfd: i32, backlog: i32) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let backlog = backlog as usize;
syscall2(SYS_LISTEN, sockfd, backlog).map(drop)
}
pub unsafe fn lpathconf<P: AsRef<Path>>(path: P, name: i32) -> Result<isize, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let name = name as usize;
syscall2(SYS_LPATHCONF, path_ptr, name).map(|val| val as isize)
}
pub unsafe fn lseek(fd: i32, offset: off_t, whence: i32) -> Result<(), Errno> {
let fd = fd as usize;
let offset = offset as usize;
let whence = whence as usize;
syscall3(SYS_LSEEK, fd, offset, whence).map(drop)
}
pub unsafe fn lutimes<P: AsRef<Path>>(filename: P, times: &[timeval_t; 2]) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let times_ptr = times.as_ptr() as usize;
syscall2(SYS_LUTIMES, filename_ptr, times_ptr).map(drop)
}
pub unsafe fn madvise(addr: usize, len: size_t, advice: i32) -> Result<(), Errno> {
let advice = advice as usize;
syscall3(SYS_MADVISE, addr, len, advice).map(drop)
}
pub unsafe fn mincore(start: usize, len: size_t, vec: *const u8) -> Result<(), Errno> {
let vec_ptr = vec as usize;
syscall3(SYS_MINCORE, start, len, vec_ptr).map(drop)
}
pub unsafe fn minherit(addr: usize, len: size_t, inherit: i32) -> Result<(), Errno> {
let inherit = inherit as usize;
syscall3(SYS_MINHERIT, addr, len, inherit).map(drop)
}
pub unsafe fn mkdir<P: AsRef<Path>>(filename: P, mode: mode_t) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
syscall2(SYS_MKDIR, filename_ptr, mode).map(drop)
}
pub unsafe fn mkdirat<P: AsRef<Path>>(dirfd: i32, filename: P, mode: mode_t) -> Result<(), Errno> {
let dirfd = dirfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
syscall3(SYS_MKDIRAT, dirfd, filename_ptr, mode).map(drop)
}
pub unsafe fn mkfifo<P: AsRef<Path>>(path: P, mode: mode_t) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let mode = mode as usize;
syscall2(SYS_MKFIFO, path_ptr, mode).map(drop)
}
pub unsafe fn mkfifoat<P: AsRef<Path>>(dfd: i32, path: P, mode: mode_t) -> Result<(), Errno> {
let dfd = dfd as usize;
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let mode = mode as usize;
syscall3(SYS_MKFIFOAT, dfd, path_ptr, mode).map(drop)
}
pub unsafe fn mknodat<P: AsRef<Path>>(
dirfd: i32,
filename: P,
mode: mode_t,
dev: dev_t,
) -> Result<(), Errno> {
let dirfd = dirfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let mode = mode as usize;
let dev = dev as usize;
syscall4(SYS_MKNODAT, dirfd, filename_ptr, mode, dev).map(drop)
}
pub unsafe fn mlock(addr: usize, len: size_t) -> Result<(), Errno> {
syscall2(SYS_MLOCK, addr, len).map(drop)
}
pub unsafe fn mlockall(flags: i32) -> Result<(), Errno> {
let flags = flags as usize;
syscall1(SYS_MLOCKALL, flags).map(drop)
}
pub unsafe fn mmap(
start: usize,
len: size_t,
prot: i32,
flags: i32,
fd: i32,
offset: off_t,
) -> Result<usize, Errno> {
let prot = prot as usize;
let flags = flags as usize;
let fd = fd as usize;
let offset = offset as usize;
syscall6(SYS_MMAP, start, len, prot, flags, fd, offset)
}
pub unsafe fn modfind(name: &str) -> Result<i32, Errno> {
let name = CString::new(name);
let name_ptr = name.as_ptr() as usize;
syscall1(SYS_MODFIND, name_ptr).map(|ret| ret as i32)
}
pub unsafe fn modfnext(modid: i32) -> Result<i32, Errno> {
let modid = modid as usize;
syscall1(SYS_MODFNEXT, modid).map(|ret| ret as i32)
}
pub unsafe fn modnext(modid: i32) -> Result<i32, Errno> {
let modid = modid as usize;
syscall1(SYS_MODNEXT, modid).map(|ret| ret as i32)
}
pub unsafe fn modstat(modid: i32, stat: &mut module_stat_t) -> Result<(), Errno> {
let modid = modid as usize;
let stat_ptr = stat as *mut module_stat_t as usize;
syscall2(SYS_MODSTAT, modid, stat_ptr).map(drop)
}
pub unsafe fn mount<P: AsRef<Path>>(
dev_name: P,
dir_name: P,
fs_type: P,
flags: usize,
data: usize,
) -> Result<(), Errno> {
let dev_name = CString::new(dev_name.as_ref());
let dev_name_ptr = dev_name.as_ptr() as usize;
let dir_name = CString::new(dir_name.as_ref());
let dir_name_ptr = dir_name.as_ptr() as usize;
let fs_type = CString::new(fs_type.as_ref());
let fs_type_ptr = fs_type.as_ptr() as usize;
syscall5(
SYS_MOUNT,
dev_name_ptr,
dir_name_ptr,
fs_type_ptr,
flags,
data,
)
.map(drop)
}
pub unsafe fn mprotect(addr: usize, len: size_t, prot: i32) -> Result<(), Errno> {
let prot = prot as usize;
syscall3(SYS_MPROTECT, addr, len, prot).map(drop)
}
pub unsafe fn msgctl(msqid: i32, cmd: i32, buf: &mut msqid_ds_t) -> Result<i32, Errno> {
let msqid = msqid as usize;
let cmd = cmd as usize;
let buf_ptr = buf as *mut msqid_ds_t as usize;
syscall3(SYS_MSGCTL, msqid, cmd, buf_ptr).map(|ret| ret as i32)
}
pub unsafe fn msgget(key: key_t, msgflg: i32) -> Result<i32, Errno> {
let key = key as usize;
let msgflg = msgflg as usize;
syscall2(SYS_MSGGET, key, msgflg).map(|ret| ret as i32)
}
pub unsafe fn msgrcv(
msqid: i32,
msgq: usize,
msgsz: size_t,
msgtyp: isize,
msgflg: i32,
) -> Result<ssize_t, Errno> {
let msqid = msqid as usize;
let msgtyp = msgtyp as usize;
let msgflg = msgflg as usize;
syscall5(SYS_MSGRCV, msqid, msgq, msgsz, msgtyp, msgflg).map(|ret| ret as ssize_t)
}
pub unsafe fn msgsnd(msqid: i32, msgq: usize, msgsz: size_t, msgflg: i32) -> Result<(), Errno> {
let msqid = msqid as usize;
let msgflg = msgflg as usize;
syscall4(SYS_MSGSND, msqid, msgq, msgsz, msgflg).map(drop)
}
pub unsafe fn msgsys(which: i32, a2: i32, a3: i32, a4: i32, a5: i32, a6: i32) -> Result<(), Errno> {
let which = which as usize;
let a2 = a2 as usize;
let a3 = a3 as usize;
let a4 = a4 as usize;
let a5 = a5 as usize;
let a6 = a6 as usize;
syscall6(SYS_MSGSYS, which, a2, a3, a4, a5, a6).map(drop)
}
pub unsafe fn msync(addr: usize, len: size_t, flags: i32) -> Result<(), Errno> {
let flags = flags as usize;
syscall3(SYS_MSYNC, addr, len, flags).map(drop)
}
pub unsafe fn munlock(addr: usize, len: size_t) -> Result<(), Errno> {
syscall2(SYS_MUNLOCK, addr, len).map(drop)
}
pub unsafe fn munlockall() -> Result<(), Errno> {
syscall0(SYS_MUNLOCKALL).map(drop)
}
pub unsafe fn munmap(addr: usize, len: size_t) -> Result<(), Errno> {
syscall2(SYS_MUNMAP, addr, len).map(drop)
}
pub unsafe fn nanosleep(req: ×pec_t, rem: Option<&mut timespec_t>) -> Result<(), Errno> {
let req_ptr = req as *const timespec_t as usize;
let rem_ptr = rem.map_or(0, |rem| rem as *mut timespec_t as usize);
syscall2(SYS_NANOSLEEP, req_ptr, rem_ptr).map(drop)
}
pub unsafe fn ntp_adjtime(time: &mut timex_t) -> Result<i32, Errno> {
let time_ptr = time as *mut timex_t as usize;
syscall1(SYS_NTP_ADJTIME, time_ptr).map(|val| val as i32)
}
pub unsafe fn ntp_gettime(time: &mut ntptimeval_t) -> Result<i32, Errno> {
let time_ptr = time as *mut ntptimeval_t as usize;
syscall1(SYS_NTP_GETTIME, time_ptr).map(|val| val as i32)
}
pub unsafe fn open<P: AsRef<Path>>(filename: P, flags: i32, mode: mode_t) -> Result<i32, Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let flags = flags as usize;
let mode = mode as usize;
syscall3(SYS_OPEN, filename_ptr, flags, mode).map(|ret| ret as i32)
}
pub unsafe fn openat<P: AsRef<Path>>(
dirfd: i32,
filename: P,
flags: i32,
mode: mode_t,
) -> Result<i32, Errno> {
let dirfd = dirfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let flags = flags as usize;
let mode = mode as usize;
syscall4(SYS_OPENAT, dirfd, filename_ptr, flags, mode).map(|ret| ret as i32)
}
pub unsafe fn pathconf<P: AsRef<Path>>(path: P, name: i32) -> Result<isize, Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let name = name as usize;
syscall2(SYS_PATHCONF, path_ptr, name).map(|val| val as isize)
}
pub unsafe fn pdfork(fd: &mut i32, flags: i32) -> Result<pid_t, Errno> {
let fd_ptr = fd as *mut i32 as usize;
let flags = flags as usize;
syscall2(SYS_PDFORK, fd_ptr, flags).map(|ret| ret as pid_t)
}
pub unsafe fn pdgetpid(fd: i32, pid: &mut pid_t) -> Result<(), Errno> {
let fd = fd as usize;
let pid_ptr = pid as *mut pid_t as usize;
syscall2(SYS_PDGETPID, fd, pid_ptr).map(drop)
}
pub unsafe fn pdkill(fd: i32, sig: i32) -> Result<(), Errno> {
let fd = fd as usize;
let sig = sig as usize;
syscall2(SYS_PDKILL, fd, sig).map(drop)
}
pub unsafe fn pipe2(pipefd: &mut [i32; 2], flags: i32) -> Result<(), Errno> {
let pipefd_ptr = pipefd.as_mut_ptr() as usize;
let flags = flags as usize;
syscall2(SYS_PIPE2, pipefd_ptr, flags).map(drop)
}
pub unsafe fn poll(fds: &mut [pollfd_t], timeout: i32) -> Result<i32, Errno> {
let fds_ptr = fds.as_mut_ptr() as usize;
let nfds = fds.len();
let timeout = timeout as usize;
syscall3(SYS_POLL, fds_ptr, nfds, timeout).map(|ret| ret as i32)
}
pub unsafe fn posix_fadvise(
fd: i32,
offset: loff_t,
len: size_t,
advice: i32,
) -> Result<(), Errno> {
let fd = fd as usize;
let offset = offset as usize;
let advice = advice as usize;
syscall4(SYS_POSIX_FADVISE, fd, offset, len, advice).map(drop)
}
pub unsafe fn posix_fallocate(fd: i32, offset: off_t, len: off_t) -> Result<(), Errno> {
let fd = fd as usize;
let offset = offset as usize;
let len = len as usize;
syscall3(SYS_POSIX_FALLOCATE, fd, offset, len).map(drop)
}
pub unsafe fn posix_openpt(flags: i32) -> Result<i32, Errno> {
let flags = flags as usize;
syscall1(SYS_POSIX_OPENPT, flags).map(|ret| ret as i32)
}
pub unsafe fn ppoll(
fds: &mut [pollfd_t],
timeout: ×pec_t,
sigmask: &sigset_t,
sigsetsize: size_t,
) -> Result<i32, Errno> {
let fds_ptr = fds.as_mut_ptr() as usize;
let nfds = fds.len();
let timeout_ptr = timeout as *const timespec_t as usize;
let sigmask_ptr = sigmask as *const sigset_t as usize;
syscall5(
SYS_PPOLL,
fds_ptr,
nfds,
timeout_ptr,
sigmask_ptr,
sigsetsize,
)
.map(|ret| ret as i32)
}
pub unsafe fn pread(fd: i32, buf: usize, count: usize, offset: off_t) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let offset = offset as usize;
syscall4(SYS_PREAD, fd, buf, count, offset).map(|ret| ret as ssize_t)
}
pub unsafe fn preadv(
fd: i32,
vec: &mut [iovec_t],
pos_l: usize,
pos_h: usize,
) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let vec_ptr = vec.as_mut_ptr() as usize;
let vec_len = vec.len();
syscall5(SYS_PREADV, fd, vec_ptr, vec_len, pos_l, pos_h).map(|ret| ret as ssize_t)
}
pub unsafe fn procctl(idtype: idtype_t, id: id_t, cmd: i32, data: usize) -> Result<(), Errno> {
let idtype = idtype as usize;
let id = id as usize;
let cmd = cmd as usize;
syscall4(SYS_PROCCTL, idtype, id, cmd, data).map(drop)
}
pub unsafe fn ptrace(request: i32, pid: pid_t, addr: usize, data: usize) -> Result<isize, Errno> {
let request = request as usize;
let pid = pid as usize;
syscall4(SYS_PTRACE, request, pid, addr, data).map(|ret| ret as isize)
}
pub unsafe fn pwrite(fd: i32, buf: usize, count: size_t, offset: off_t) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let offset = offset as usize;
syscall4(SYS_PWRITE, fd, buf, count, offset).map(|ret| ret as ssize_t)
}
pub unsafe fn pwritev(
fd: i32,
vec: &[iovec_t],
pos_l: usize,
pos_h: usize,
) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let vec_ptr = vec.as_ptr() as usize;
let vec_len = vec.len();
syscall5(SYS_PWRITEV, fd, vec_ptr, vec_len, pos_l, pos_h).map(|ret| ret as ssize_t)
}
pub unsafe fn quotactl<P: AsRef<Path>>(
path: P,
cmd: i32,
id: i32,
addr: usize,
) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let cmd = cmd as usize;
let id = id as usize;
syscall4(SYS_QUOTACTL, path_ptr, cmd, id, addr).map(drop)
}
pub unsafe fn read(fd: i32, buf_ptr: usize, count: size_t) -> Result<ssize_t, Errno> {
let fd = fd as usize;
syscall3(SYS_READ, fd, buf_ptr, count).map(|ret| ret as ssize_t)
}
pub unsafe fn readlink<P: AsRef<Path>>(
filename: P,
buf: &mut [u8],
buf_len: size_t,
) -> Result<ssize_t, Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let buf_ptr = buf.as_mut_ptr() as usize;
syscall3(SYS_READLINK, filename_ptr, buf_ptr, buf_len).map(|ret| ret as ssize_t)
}
pub unsafe fn readlinkat<P: AsRef<Path>>(
dirfd: i32,
filename: P,
buf: &mut [u8],
buf_len: size_t,
) -> Result<ssize_t, Errno> {
let dirfd = dirfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let buf_ptr = buf.as_mut_ptr() as usize;
syscall4(SYS_READLINKAT, dirfd, filename_ptr, buf_ptr, buf_len).map(|ret| ret as ssize_t)
}
pub unsafe fn readv(fd: i32, iov: &mut [iovec_t]) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let iov_ptr = iov.as_mut_ptr() as usize;
let len = iov.len();
syscall3(SYS_READV, fd, iov_ptr, len).map(|ret| ret as ssize_t)
}
pub unsafe fn reboot(magic: i32, magci2: i32, cmd: u32, arg: usize) -> Result<(), Errno> {
let magic = magic as usize;
let magic2 = magci2 as usize;
let cmd = cmd as usize;
syscall4(SYS_REBOOT, magic, magic2, cmd, arg).map(drop)
}
pub unsafe fn recvfrom(
sockfd: i32,
buf: &mut [u8],
flags: i32,
src_addr: &mut sockaddr_in_t,
addrlen: &mut socklen_t,
) -> Result<ssize_t, Errno> {
let sockfd = sockfd as usize;
let buf_ptr = buf.as_mut_ptr() as usize;
let buflen = buf.len();
let flags = flags as usize;
let src_addr_ptr = src_addr as *mut sockaddr_in_t as usize;
let addrlen_ptr = addrlen as *mut socklen_t as usize;
syscall6(
SYS_RECVFROM,
sockfd,
buf_ptr,
buflen,
flags,
src_addr_ptr,
addrlen_ptr,
)
.map(|ret| ret as ssize_t)
}
pub unsafe fn recvmsg(sockfd: i32, msg: &mut msghdr_t, flags: i32) -> Result<ssize_t, Errno> {
let sockfd = sockfd as usize;
let msg_ptr = msg as *mut msghdr_t as usize;
let flags = flags as usize;
syscall3(SYS_RECVMSG, sockfd, msg_ptr, flags).map(|ret| ret as ssize_t)
}
pub unsafe fn rename<P: AsRef<Path>>(oldfilename: P, newfilename: P) -> Result<(), Errno> {
let oldfilename = CString::new(oldfilename.as_ref());
let oldfilename_ptr = oldfilename.as_ptr() as usize;
let newfilename = CString::new(newfilename.as_ref());
let newfilename_ptr = newfilename.as_ptr() as usize;
syscall2(SYS_RENAME, oldfilename_ptr, newfilename_ptr).map(drop)
}
pub unsafe fn renameat<P: AsRef<Path>>(
olddfd: i32,
oldfilename: P,
newdfd: i32,
newfilename: P,
) -> Result<(), Errno> {
let olddfd = olddfd as usize;
let oldfilename = CString::new(oldfilename.as_ref());
let oldfilename_ptr = oldfilename.as_ptr() as usize;
let newdfd = newdfd as usize;
let newfilename = CString::new(newfilename.as_ref());
let newfilename_ptr = newfilename.as_ptr() as usize;
syscall4(
SYS_RENAMEAT,
olddfd,
oldfilename_ptr,
newdfd,
newfilename_ptr,
)
.map(drop)
}
pub unsafe fn rfork(flags: i32) -> Result<pid_t, Errno> {
let flags = flags as usize;
syscall1(SYS_RFORK, flags).map(|ret| ret as pid_t)
}
pub unsafe fn rmdir<P: AsRef<Path>>(filename: P) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
syscall1(SYS_RMDIR, filename_ptr).map(drop)
}
pub unsafe fn rtprio(function: i32, pid: pid_t, rt: &mut rtprio_t) -> Result<(), Errno> {
let function = function as usize;
let pid = pid as usize;
let rt_ptr = rt as *mut rtprio_t as usize;
syscall3(SYS_RTPRIO, function, pid, rt_ptr).map(drop)
}
pub unsafe fn rtprio_thread(function: i32, lwpid: lwpid_t, rt: &mut rtprio_t) -> Result<(), Errno> {
let function = function as usize;
let lwpid = lwpid as usize;
let rt_ptr = rt as *mut rtprio_t as usize;
syscall3(SYS_RTPRIO_THREAD, function, lwpid, rt_ptr).map(drop)
}
pub unsafe fn sbrk(incr: intptr_t) -> Result<usize, Errno> {
let incr = incr as usize;
syscall1(SYS_SBRK, incr)
}
pub unsafe fn sched_getcpu() -> Result<i32, Errno> {
syscall0(SYS_SCHED_GETCPU).map(|val| val as i32)
}
pub unsafe fn sched_getparam(pid: pid_t, param: &mut sched_param_t) -> Result<(), Errno> {
let pid = pid as usize;
let param_ptr = param as *mut sched_param_t as usize;
syscall2(SYS_SCHED_GETPARAM, pid, param_ptr).map(drop)
}
pub unsafe fn sched_getscheduler(pid: pid_t) -> Result<i32, Errno> {
let pid = pid as usize;
syscall1(SYS_SCHED_GETSCHEDULER, pid).map(|ret| ret as i32)
}
pub unsafe fn sched_get_priority_max(policy: i32) -> Result<i32, Errno> {
let policy = policy as usize;
syscall1(SYS_SCHED_GET_PRIORITY_MAX, policy).map(|ret| ret as i32)
}
pub unsafe fn sched_get_priority_min(policy: i32) -> Result<i32, Errno> {
let policy = policy as usize;
syscall1(SYS_SCHED_GET_PRIORITY_MIN, policy).map(|ret| ret as i32)
}
pub unsafe fn sched_rr_get_interval(pid: pid_t, interval: &mut timespec_t) -> Result<(), Errno> {
let pid = pid as usize;
let interval_ptr = interval as *mut timespec_t as usize;
syscall2(SYS_SCHED_RR_GET_INTERVAL, pid, interval_ptr).map(drop)
}
pub unsafe fn sched_setparam(pid: pid_t, param: &sched_param_t) -> Result<(), Errno> {
let pid = pid as usize;
let param_ptr = param as *const sched_param_t as usize;
syscall2(SYS_SCHED_SETPARAM, pid, param_ptr).map(drop)
}
pub unsafe fn sched_setscheduler(
pid: pid_t,
policy: i32,
param: &sched_param_t,
) -> Result<(), Errno> {
let pid = pid as usize;
let policy = policy as usize;
let param_ptr = param as *const sched_param_t as usize;
syscall3(SYS_SCHED_SETSCHEDULER, pid, policy, param_ptr).map(drop)
}
pub unsafe fn sched_yield() -> Result<(), Errno> {
syscall0(SYS_SCHED_YIELD).map(drop)
}
pub unsafe fn select(
nfds: i32,
readfds: &mut fd_set_t,
writefds: &mut fd_set_t,
exceptfds: &mut fd_set_t,
timeout: &mut timeval_t,
) -> Result<i32, Errno> {
let nfds = nfds as usize;
let readfds_ptr = readfds as *mut fd_set_t as usize;
let writefds_ptr = writefds as *mut fd_set_t as usize;
let exceptfds_ptr = exceptfds as *mut fd_set_t as usize;
let timeout_ptr = timeout as *mut timeval_t as usize;
syscall5(
SYS_SELECT,
nfds,
readfds_ptr,
writefds_ptr,
exceptfds_ptr,
timeout_ptr,
)
.map(|ret| ret as i32)
}
pub unsafe fn semget(key: key_t, nsems: i32, semflg: i32) -> Result<i32, Errno> {
let key = key as usize;
let nsems = nsems as usize;
let semflg = semflg as usize;
syscall3(SYS_SEMGET, key, nsems, semflg).map(|ret| ret as i32)
}
pub unsafe fn semop(semid: i32, sops: &mut [sembuf_t]) -> Result<(), Errno> {
let semid = semid as usize;
let sops_ptr = sops.as_ptr() as usize;
let nops = sops.len();
syscall3(SYS_SEMOP, semid, sops_ptr, nops).map(drop)
}
pub unsafe fn semsys(which: i32, a2: i32, a3: i32, a4: i32, a5: i32) -> Result<(), Errno> {
let which = which as usize;
let a2 = a2 as usize;
let a3 = a3 as usize;
let a4 = a4 as usize;
let a5 = a5 as usize;
syscall5(SYS_SEMSYS, which, a2, a3, a4, a5).map(drop)
}
pub unsafe fn sendfile(
out_fd: i32,
in_fd: i32,
offset: &mut off_t,
count: size_t,
) -> Result<ssize_t, Errno> {
let out_fd = out_fd as usize;
let in_fd = in_fd as usize;
let offset_ptr = offset as *mut off_t as usize;
syscall4(SYS_SENDFILE, out_fd, in_fd, offset_ptr, count).map(|ret| ret as ssize_t)
}
pub unsafe fn sendmsg(sockfd: i32, msg: &msghdr_t, flags: i32) -> Result<ssize_t, Errno> {
let sockfd = sockfd as usize;
let msg_ptr = msg as *const msghdr_t as usize;
let flags = flags as usize;
syscall3(SYS_SENDMSG, sockfd, msg_ptr, flags).map(|ret| ret as ssize_t)
}
pub unsafe fn sendto(
sockfd: i32,
buf: &[u8],
len: size_t,
flags: i32,
dest_addr: &sockaddr_in_t,
addrlen: socklen_t,
) -> Result<ssize_t, Errno> {
let sockfd = sockfd as usize;
let buf_ptr = buf.as_ptr() as usize;
let flags = flags as usize;
let dest_addr_ptr = dest_addr as *const sockaddr_in_t as usize;
let addrlen = addrlen as usize;
syscall6(
SYS_SENDTO,
sockfd,
buf_ptr,
len,
flags,
dest_addr_ptr,
addrlen,
)
.map(|ret| ret as ssize_t)
}
pub unsafe fn setaudit(info: &mut auditinfo_t) -> Result<(), Errno> {
let info_ptr = info as *mut auditinfo_t as usize;
syscall1(SYS_SETAUDIT, info_ptr).map(drop)
}
pub unsafe fn setaudit_addr(info: &mut auditinfo_addr_t, length: u32) -> Result<(), Errno> {
let info_ptr = info as *mut auditinfo_addr_t as usize;
let length = length as usize;
syscall2(SYS_SETAUDIT_ADDR, info_ptr, length).map(drop)
}
pub unsafe fn setauid(auid: &mut au_id_t) -> Result<(), Errno> {
let auid_ptr = auid as *mut au_id_t as usize;
syscall1(SYS_SETAUID, auid_ptr).map(drop)
}
pub unsafe fn setcontext(ctx: &ucontext_t) -> Result<(), Errno> {
let ctx_ptr = ctx as *const ucontext_t as usize;
syscall1(SYS_SETCONTEXT, ctx_ptr).map(drop)
}
pub unsafe fn setegid(gid: gid_t) -> Result<(), Errno> {
let gid = gid as usize;
syscall1(SYS_SETEGID, gid).map(drop)
}
pub unsafe fn seteuid(uid: uid_t) -> Result<(), Errno> {
let uid = uid as usize;
syscall1(SYS_SETEUID, uid).map(drop)
}
pub unsafe fn setgid(gid: gid_t) -> Result<(), Errno> {
let gid = gid as usize;
syscall1(SYS_SETGID, gid).map(drop)
}
pub unsafe fn setgroups(group_list: &[gid_t]) -> Result<(), Errno> {
let group_len = group_list.len();
let group_ptr = group_list.as_ptr() as usize;
syscall2(SYS_SETGROUPS, group_len, group_ptr).map(drop)
}
pub unsafe fn setitimer(
which: i32,
new_val: &itimerval_t,
old_val: &mut itimerval_t,
) -> Result<(), Errno> {
let which = which as usize;
let new_val_ptr = new_val as *const itimerval_t as usize;
let old_val_ptr = old_val as *mut itimerval_t as usize;
syscall3(SYS_SETITIMER, which, new_val_ptr, old_val_ptr).map(drop)
}
pub unsafe fn setlogin(name: &str) -> Result<(), Errno> {
let name = CString::new(name);
let name_ptr = name.as_ptr() as usize;
syscall1(SYS_SETLOGIN, name_ptr).map(drop)
}
pub unsafe fn setloginclass(name: &str) -> Result<(), Errno> {
let name = CString::new(name);
let name_ptr = name.as_ptr() as usize;
syscall1(SYS_SETLOGINCLASS, name_ptr).map(drop)
}
pub unsafe fn setpgid(pid: pid_t, pgid: pid_t) -> Result<(), Errno> {
let pid = pid as usize;
let pgid = pgid as usize;
syscall2(SYS_SETPGID, pid, pgid).map(drop)
}
pub unsafe fn setpriority(which: i32, who: i32, prio: i32) -> Result<(), Errno> {
let which = which as usize;
let who = who as usize;
let prio = prio as usize;
syscall3(SYS_SETPRIORITY, which, who, prio).map(drop)
}
pub unsafe fn setregid(rgid: gid_t, egid: gid_t) -> Result<(), Errno> {
let rgid = rgid as usize;
let egid = egid as usize;
syscall2(SYS_SETREGID, rgid, egid).map(drop)
}
pub unsafe fn setresgid(rgid: gid_t, egid: gid_t, sgid: gid_t) -> Result<(), Errno> {
let rgid = rgid as usize;
let egid = egid as usize;
let sgid = sgid as usize;
syscall3(SYS_SETRESGID, rgid, egid, sgid).map(drop)
}
pub unsafe fn setresuid(ruid: uid_t, euid: uid_t, suid: uid_t) -> Result<(), Errno> {
let ruid = ruid as usize;
let euid = euid as usize;
let suid = suid as usize;
syscall3(SYS_SETRESUID, ruid, euid, suid).map(drop)
}
pub unsafe fn setreuid(ruid: uid_t, euid: uid_t) -> Result<(), Errno> {
let ruid = ruid as usize;
let euid = euid as usize;
syscall2(SYS_SETREUID, ruid, euid).map(drop)
}
pub unsafe fn setrlimit(resource: i32, rlimit: &rlimit_t) -> Result<(), Errno> {
let resource = resource as usize;
let rlimit_ptr = rlimit as *const rlimit_t as usize;
syscall2(SYS_SETRLIMIT, resource, rlimit_ptr).map(drop)
}
pub unsafe fn setsid() -> Result<pid_t, Errno> {
syscall0(SYS_SETSID).map(|ret| ret as pid_t)
}
pub unsafe fn setsockopt(
sockfd: i32,
level: i32,
optname: i32,
optval: usize,
optlen: socklen_t,
) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let level = level as usize;
let optname = optname as usize;
let optlen = optlen as usize;
syscall5(SYS_SETSOCKOPT, sockfd, level, optname, optval, optlen).map(drop)
}
pub unsafe fn settimeofday(timeval: &timeval_t, tz: &timezone_t) -> Result<(), Errno> {
let timeval_ptr = timeval as *const timeval_t as usize;
let tz_ptr = tz as *const timezone_t as usize;
syscall2(SYS_SETTIMEOFDAY, timeval_ptr, tz_ptr).map(drop)
}
pub unsafe fn setuid(uid: uid_t) -> Result<(), Errno> {
let uid = uid as usize;
syscall1(SYS_SETUID, uid).map(drop)
}
pub unsafe fn shmat(shmid: i32, shmaddr: usize, shmflg: i32) -> Result<usize, Errno> {
let shmid = shmid as usize;
let shmflg = shmflg as usize;
syscall3(SYS_SHMAT, shmid, shmaddr, shmflg)
}
pub unsafe fn shmctl(shmid: i32, cmd: i32, buf: &mut shmid_ds_t) -> Result<i32, Errno> {
let shmid = shmid as usize;
let cmd = cmd as usize;
let buf_ptr = buf as *mut shmid_ds_t as usize;
syscall3(SYS_SHMCTL, shmid, cmd, buf_ptr).map(|ret| ret as i32)
}
pub unsafe fn shmdt(shmaddr: usize) -> Result<(), Errno> {
syscall1(SYS_SHMDT, shmaddr).map(drop)
}
pub unsafe fn shmget(key: key_t, size: size_t, shmflg: i32) -> Result<i32, Errno> {
let key = key as usize;
let shmflg = shmflg as usize;
syscall3(SYS_SHMGET, key, size, shmflg).map(|ret| ret as i32)
}
pub unsafe fn shmsys(which: i32, a2: i32, a3: i32, a4: i32) -> Result<(), Errno> {
let which = which as usize;
let a2 = a2 as usize;
let a3 = a3 as usize;
let a4 = a4 as usize;
syscall4(SYS_SHMSYS, which, a2, a3, a4).map(drop)
}
pub unsafe fn shm_open2<P: AsRef<Path>>(
path: P,
flags: i32,
mode: mode_t,
shmflags: i32,
fcaps: &mut filecaps_t,
name: P,
) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
let flags = flags as usize;
let mode = mode as usize;
let shmflags = shmflags as usize;
let fcaps_ptr = fcaps as *mut filecaps_t as usize;
let name = CString::new(name.as_ref());
let name_ptr = name.as_ptr() as usize;
syscall6(
SYS_SHM_OPEN2,
path_ptr,
flags,
mode,
shmflags,
fcaps_ptr,
name_ptr,
)
.map(drop)
}
pub unsafe fn shm_rename<P: AsRef<Path>>(
path_from: P,
path_to: P,
flags: i32,
) -> Result<(), Errno> {
let path_from = CString::new(path_from.as_ref());
let path_from_ptr = path_from.as_ptr() as usize;
let path_to = CString::new(path_to.as_ref());
let path_to_ptr = path_to.as_ptr() as usize;
let flags = flags as usize;
syscall3(SYS_SHM_RENAME, path_from_ptr, path_to_ptr, flags).map(drop)
}
pub unsafe fn shm_unlink<P: AsRef<Path>>(path: P) -> Result<(), Errno> {
let path = CString::new(path.as_ref());
let path_ptr = path.as_ptr() as usize;
syscall1(SYS_SHM_UNLINK, path_ptr).map(drop)
}
pub unsafe fn shutdown(sockfd: i32, how: i32) -> Result<(), Errno> {
let sockfd = sockfd as usize;
let how = how as usize;
syscall2(SYS_SHUTDOWN, sockfd, how).map(drop)
}
pub unsafe fn sigaction(
sig: i32,
act: &sigaction_t,
old_act: &mut sigaction_t,
) -> Result<(), Errno> {
let sig = sig as usize;
let act_ptr = act as *const sigaction_t as usize;
let old_act_ptr = old_act as *mut sigaction_t as usize;
syscall3(SYS_SIGACTION, sig, act_ptr, old_act_ptr).map(drop)
}
pub unsafe fn sigaltstack(uss: &sigaltstack_t, uoss: &mut sigaltstack_t) -> Result<(), Errno> {
let uss_ptr = uss as *const sigaltstack_t as usize;
let uoss_ptr = uoss as *mut sigaltstack_t as usize;
syscall2(SYS_SIGALTSTACK, uss_ptr, uoss_ptr).map(drop)
}
pub unsafe fn sigpending(set: &mut sigset_t) -> Result<(), Errno> {
let set_ptr = set as *mut sigset_t as usize;
syscall1(SYS_SIGPENDING, set_ptr).map(drop)
}
pub unsafe fn sigprocmask(
how: i32,
newset: &mut sigset_t,
oldset: &mut sigset_t,
) -> Result<(), Errno> {
let how = how as usize;
let newset_ptr = newset as *mut sigset_t as usize;
let oldset_ptr = oldset as *mut sigset_t as usize;
syscall3(SYS_SIGPROCMASK, how, newset_ptr, oldset_ptr).map(drop)
}
pub unsafe fn sigreturn() {
let _ = syscall0(SYS_SIGRETURN);
}
pub unsafe fn sigsuspend(mask: &old_sigset_t) -> Result<(), Errno> {
let mask_ptr = mask as *const old_sigset_t as usize;
syscall1(SYS_SIGSUSPEND, mask_ptr).map(drop)
}
pub unsafe fn socket(domain: i32, sock_type: i32, protocol: i32) -> Result<i32, Errno> {
let domain = domain as usize;
let sock_type = sock_type as usize;
let protocol = protocol as usize;
syscall3(SYS_SOCKET, domain, sock_type, protocol).map(|ret| ret as i32)
}
pub unsafe fn socketpair(
domain: i32,
type_: i32,
protocol: i32,
sv: [i32; 2],
) -> Result<(), Errno> {
let domain = domain as usize;
let type_ = type_ as usize;
let protocol = protocol as usize;
let sv_ptr = sv.as_ptr() as usize;
syscall4(SYS_SOCKETPAIR, domain, type_, protocol, sv_ptr).map(drop)
}
pub unsafe fn statfs<P: AsRef<Path>>(filename: P, buf: &mut statfs_t) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let buf_ptr = buf as *mut statfs_t as usize;
syscall2(SYS_STATFS, filename_ptr, buf_ptr).map(drop)
}
pub unsafe fn swapcontext(old_ctx: &mut ucontext_t, ctx: &ucontext_t) -> Result<(), Errno> {
let old_ctx_ptr = old_ctx as *mut ucontext_t as usize;
let ctx_ptr = ctx as *const ucontext_t as usize;
syscall2(SYS_SWAPCONTEXT, old_ctx_ptr, ctx_ptr).map(drop)
}
pub unsafe fn swapoff<P: AsRef<Path>>(filename: P) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
syscall1(SYS_SWAPOFF, filename_ptr).map(drop)
}
pub unsafe fn swapon<P: AsRef<Path>>(filename: P, flags: i32) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let flags = flags as usize;
syscall2(SYS_SWAPON, filename_ptr, flags).map(drop)
}
pub unsafe fn symlink<P: AsRef<Path>>(oldname: P, newname: P) -> Result<(), Errno> {
let oldname = CString::new(oldname.as_ref());
let oldname_ptr = oldname.as_ptr() as usize;
let newname = CString::new(newname.as_ref());
let newname_ptr = newname.as_ptr() as usize;
syscall2(SYS_SYMLINK, oldname_ptr, newname_ptr).map(drop)
}
pub unsafe fn symlinkat<P: AsRef<Path>>(
oldname: P,
newdirfd: i32,
newname: P,
) -> Result<(), Errno> {
let oldname = CString::new(oldname.as_ref());
let oldname_ptr = oldname.as_ptr() as usize;
let newname = CString::new(newname.as_ref());
let newname_ptr = newname.as_ptr() as usize;
let newdirfd = newdirfd as usize;
syscall3(SYS_SYMLINKAT, oldname_ptr, newdirfd, newname_ptr).map(drop)
}
pub unsafe fn sync() -> Result<(), Errno> {
syscall0(SYS_SYNC).map(drop)
}
pub unsafe fn sysarch(number: i32, args: usize) -> Result<usize, Errno> {
let number = number as usize;
syscall2(SYS_SYSARCH, number, args)
}
pub unsafe fn thr_craete(ctx: &mut ucontext_t, id: &mut isize, flags: i32) -> Result<(), Errno> {
let ctx_ptr = ctx as *mut ucontext_t as usize;
let id_ptr = id as *mut isize as usize;
let flags = flags as usize;
syscall3(SYS_THR_CREATE, ctx_ptr, id_ptr, flags).map(drop)
}
pub unsafe fn thr_exit(state: Option<&mut isize>) -> ! {
let state_ptr = state.map_or(0, |state| state as *mut isize as usize);
let _ret = syscall1(SYS_THR_EXIT, state_ptr).map(drop);
core::hint::unreachable_unchecked();
}
pub unsafe fn thr_kill(id: isize, sig: i32) -> Result<(), Errno> {
let id = id as usize;
let sig = sig as usize;
syscall2(SYS_THR_KILL, id, sig).map(drop)
}
pub unsafe fn thr_kill2(pid: pid_t, id: isize, sig: i32) -> Result<(), Errno> {
let pid = pid as usize;
let id = id as usize;
let sig = sig as usize;
syscall3(SYS_THR_KILL2, pid, id, sig).map(drop)
}
pub unsafe fn thr_new(param: &mut thr_param_t) -> Result<(), Errno> {
let param_ptr = param as *mut thr_param_t as usize;
let param_size = core::mem::size_of::<thr_param_t>();
syscall2(SYS_THR_NEW, param_ptr, param_size).map(drop)
}
pub unsafe fn thr_self(id: &mut isize) -> Result<(), Errno> {
let id_ptr = id as *mut isize as usize;
syscall1(SYS_THR_SELF, id_ptr).map(drop)
}
pub unsafe fn thr_set_name(id: isize, name: &str) -> Result<(), Errno> {
let id = id as usize;
let name = CString::new(name);
let name_ptr = name.as_ptr() as usize;
syscall2(SYS_THR_SET_NAME, id, name_ptr).map(drop)
}
pub unsafe fn thr_suspend(timeout: ×pec_t) -> Result<(), Errno> {
let timeout_ptr = timeout as *const timespec_t as usize;
syscall1(SYS_THR_SUSPEND, timeout_ptr).map(drop)
}
pub unsafe fn thr_wake(id: isize) -> Result<(), Errno> {
let id = id as usize;
syscall1(SYS_THR_WAKE, id).map(drop)
}
pub unsafe fn truncate<P: AsRef<Path>>(filename: P, length: off_t) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let length = length as usize;
syscall2(SYS_TRUNCATE, filename_ptr, length).map(drop)
}
pub unsafe fn umask(mode: mode_t) -> Result<mode_t, Errno> {
let mode = mode as usize;
syscall1(SYS_UMASK, mode).map(|ret| ret as mode_t)
}
pub unsafe fn unlink<P: AsRef<Path>>(filename: P) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
syscall1(SYS_UNLINK, filename_ptr).map(drop)
}
pub unsafe fn unlinkat<P: AsRef<Path>>(dfd: i32, filename: P, flag: i32) -> Result<(), Errno> {
let dfd = dfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let flag = flag as usize;
syscall3(SYS_UNLINKAT, dfd, filename_ptr, flag).map(drop)
}
pub unsafe fn utimensat<P: AsRef<Path>>(
dirfd: i32,
filename: P,
times: &[timespec_t; 2],
flags: i32,
) -> Result<(), Errno> {
let dirfd = dirfd as usize;
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let times_ptr = times.as_ptr() as usize;
let flags = flags as usize;
syscall4(SYS_UTIMENSAT, dirfd, filename_ptr, times_ptr, flags).map(drop)
}
pub unsafe fn utimes<P: AsRef<Path>>(filename: P, times: &[timeval_t; 2]) -> Result<(), Errno> {
let filename = CString::new(filename.as_ref());
let filename_ptr = filename.as_ptr() as usize;
let times_ptr = times.as_ptr() as usize;
syscall2(SYS_UTIMES, filename_ptr, times_ptr).map(drop)
}
pub unsafe fn uuidgen(store: &mut [uuid_t]) -> Result<(), Errno> {
let store_ptr = store.as_mut_ptr() as usize;
let count = store.len();
syscall2(SYS_UUIDGEN, store_ptr, count).map(drop)
}
pub unsafe fn vfork() -> Result<pid_t, Errno> {
syscall0(SYS_VFORK).map(|ret| ret as pid_t)
}
pub unsafe fn wait4(
pid: pid_t,
wstatus: &mut i32,
options: i32,
rusage: &mut rusage_t,
) -> Result<pid_t, Errno> {
let pid = pid as usize;
let wstatus_ptr = wstatus as *mut i32 as usize;
let options = options as usize;
let rusage_ptr = rusage as *mut rusage_t as usize;
syscall4(SYS_WAIT4, pid, wstatus_ptr, options, rusage_ptr).map(|ret| ret as pid_t)
}
pub unsafe fn wait6(
idtype: idtype_t,
id: id_t,
status: &mut i32,
options: i32,
wrusage: &mut wrusage_t,
info: &mut siginfo_t,
) -> Result<pid_t, Errno> {
let idtype = idtype as usize;
let id = id as usize;
let status_ptr = status as *mut i32 as usize;
let options = options as usize;
let wrusage_ptr = wrusage as *mut wrusage_t as usize;
let info_ptr = info as *mut siginfo_t as usize;
syscall6(
SYS_WAIT6,
idtype,
id,
status_ptr,
options,
wrusage_ptr,
info_ptr,
)
.map(|ret| ret as pid_t)
}
pub unsafe fn write(fd: i32, buf_ptr: usize, count: size_t) -> Result<ssize_t, Errno> {
let fd = fd as usize;
syscall3(SYS_WRITE, fd, buf_ptr, count).map(|ret| ret as ssize_t)
}
pub unsafe fn writev(fd: i32, iov: &[iovec_t]) -> Result<ssize_t, Errno> {
let fd = fd as usize;
let iov_ptr = iov.as_ptr() as usize;
let len = iov.len();
syscall3(SYS_WRITEV, fd, iov_ptr, len).map(|ret| ret as ssize_t)
}
pub unsafe fn r#yield() -> Result<(), Errno> {
syscall0(SYS_YIELD).map(drop)
}