|
@@ -1,18 +1,103 @@
|
|
|
+use core::slice;
|
|
|
use syscall;
|
|
|
-
|
|
|
use c_str;
|
|
|
use types::*;
|
|
|
|
|
|
+pub fn brk(addr: *const c_void) -> {
|
|
|
+ syscall::brk(addr as usize).unwrap_or(-1) as c_int
|
|
|
+
|
|
|
+ pub fn chdir(path: *const c_char) -> c_int {
|
|
|
+ let path = unsafe { c_str(path) };
|
|
|
+ syscall::chdir(path).unwrap_or(-1) as c_int
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+pub fn chown(path: *const c_char, owner: uid_t, group: gid_t) -> c_int {
|
|
|
+ let fd = syscall::open(cstr_to_slice(path));
|
|
|
+ syscall::fchown(fd as usize, owner as usize, group as usize).unwrap_or(-1) as c_int
|
|
|
+
|
|
|
pub fn close(fd: c_int) -> c_int {
|
|
|
syscall::close(fd as usize);
|
|
|
0
|
|
|
}
|
|
|
|
|
|
+pub fn dup(fd: c_int) -> c_int {
|
|
|
+ syscall::dup(fd as usize, &[]).unwrap_or(-1) as c_int
|
|
|
+}
|
|
|
+
|
|
|
+pub fn dup2(fd1: c_int, fd2) -> c_int {
|
|
|
+ syscall::dup2(fd1 as usize, fd2 as usize, &[]).unwrap_or(-1) as c_int
|
|
|
+}
|
|
|
+
|
|
|
pub fn exit(status: c_int) -> ! {
|
|
|
syscall::exit(status as usize);
|
|
|
loop {}
|
|
|
}
|
|
|
|
|
|
+pub fn fchown(fd: c_int, owner: uid_t, group: gid_t) -> c_int {
|
|
|
+ syscall::fchown(owner as usize, group as usize).unwrap_or(-1) as c_int
|
|
|
+}
|
|
|
+
|
|
|
+pub fn fchdir(fd: c_int) -> c_int {
|
|
|
+ let result = fpath(fd as usize, &[]);
|
|
|
+ if result.is_ok() {
|
|
|
+ syscall::chdir(path).unwrap_or(-1) as c_int
|
|
|
+ } else {
|
|
|
+ -1
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+pub fn fsync(fd: c_int) -> c_int {
|
|
|
+ syscall::fsync(fd as usize).unwrap_or(-1) as c_int
|
|
|
+}
|
|
|
+
|
|
|
+pub fn ftruncate(fd: c_int, len: off_t) -> {
|
|
|
+ syscall::ftruncate(fd as usize, len as usize).unwrap_or(-1) as c_int
|
|
|
+}
|
|
|
+
|
|
|
+pub fn getcwd(buf: *mut c_char, size: size_t) -> {
|
|
|
+ // XXX: do something with size maybe
|
|
|
+ let rbuf = unsafe { c_str(buf) };
|
|
|
+ syscall::getcwd(rbuf);
|
|
|
+ unsafe {
|
|
|
+ &*(rbuf as *mut [c_char])
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+pub fn getegid() -> gid_t {
|
|
|
+ syscall::getegid().unwrap_or(-1) as gid_t
|
|
|
+}
|
|
|
+
|
|
|
+pub fn geteuid() -> uid_t {
|
|
|
+ syscall::geteuid().unwrap_or(-1) as uid_t
|
|
|
+}
|
|
|
+
|
|
|
+pub fn getgid() -> gid_t {
|
|
|
+ syscall::getgid().unwrap_or(-1) as gid_t
|
|
|
+}
|
|
|
+
|
|
|
+pub fn getpgid(pid: pid_t) -> pid_t {
|
|
|
+ syscall::getpgid(pid as usize).unwrap_or(-1) as pid_t
|
|
|
+}
|
|
|
+
|
|
|
+pub fn getpid() -> pid_t {
|
|
|
+ syscall::getpid().unwrap_or(-1) as pid_t
|
|
|
+}
|
|
|
+
|
|
|
+pub fn getppid() -> pid_t {
|
|
|
+ syscall::getppid().unwrap_or(-1) as pid_t
|
|
|
+}
|
|
|
+
|
|
|
+pub fn getuid() -> uid_t {
|
|
|
+ syscall::getuid().unwrap_or(-1) as pid_t
|
|
|
+}
|
|
|
+
|
|
|
+pub fn link(path1: const c_char, path2: const c_char) -> c_int {
|
|
|
+ let path1 = unsafe { c_str(path1) };
|
|
|
+ let path2 = unsafe { c_str(path2) };
|
|
|
+ syscall::link(path1, path2).unwrap_or(-1) as c_int
|
|
|
+}
|
|
|
+
|
|
|
pub fn open(path: *const c_char, oflag: c_int, mode: mode_t) -> c_int {
|
|
|
let path = unsafe { c_str(path) };
|
|
|
syscall::open(path, (oflag as usize) | (mode as usize)).unwrap() as c_int
|