Skip to content
Snippets Groups Projects
Commit 9de89e03 authored by Paul Sajna's avatar Paul Sajna
Browse files

fchdir

parent 95e74373
No related branches found
No related tags found
1 merge request!14implement some unistd
......@@ -51,6 +51,12 @@ pub fn fchown(fildes: c_int, owner: uid_t, group: gid_t) -> c_int {
}
}
pub fn fchdir(fildes: c_int) -> c_int {
unsafe {
syscall!(FCHDIR, fildes) as c_int
}
}
#[cfg(target_arch = "x86_64")]
pub fn open(path: *const c_char, oflag: c_int, mode: mode_t) -> c_int {
unsafe {
......
......@@ -40,6 +40,11 @@ pub fn fchown(fd: c_int, owner: uid_t, group: gid_t) -> c_int {
syscall::fchown(owner, group)? as c_int
}
pub fn fchdir(fd: c_int) -> c_int {
let path = fpath(fd as usize, &[]).unwrap();
syscall::chdir(path)? 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
......
......@@ -136,7 +136,7 @@ pub extern "C" fn fchown(fildes: c_int, owner: uid_t, group: gid_t) -> c_int {
#[no_mangle]
pub extern "C" fn fchdir(fildes: c_int) -> c_int {
unimplemented!();
platform::fchdir(fildes)
}
#[no_mangle]
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment