return error code from syscall, not always -1

toolchain_update
Ben Pig Chu 6 years ago
parent fa03f7b112
commit f8533442f2

@ -53,7 +53,7 @@ pub fn syscall(id: usize, args: [usize; 6], tf: &mut TrapFrame) -> i32 {
};
match ret {
Ok(code) => code,
Err(_) => -1,
Err(err) => -(err as i32),
}
}
@ -96,7 +96,7 @@ fn sys_close(fd: usize) -> SysResult {
info!("close: fd: {:?}", fd);
match process().files.remove(&fd) {
Some(_) => Ok(0),
None => Err(SysError::InvalidFile),
None => Err(SysError::Badf),
}
}
@ -118,11 +118,11 @@ fn sys_getdirentry(fd: usize, dentry_ptr: *mut DirEntry) -> SysResult {
let file = get_file(fd)?;
let dentry = unsafe { &mut *dentry_ptr };
if !dentry.check() {
return Err(SysError::InvalidArgument);
return Err(SysError::Inval);
}
let info = file.lock().info()?;
if info.type_ != FileType::Dir || info.size <= dentry.entry_id() {
return Err(SysError::InvalidArgument);
return Err(SysError::Inval);
}
let name = file.lock().get_entry(dentry.entry_id())?;
dentry.set_name(name.as_str());
@ -133,7 +133,7 @@ fn sys_dup(fd1: usize, fd2: usize) -> SysResult {
info!("dup: {} {}", fd1, fd2);
let file = get_file(fd1)?;
if process().files.contains_key(&fd2) {
return Err(SysError::InvalidFile);
return Err(SysError::Badf);
}
process().files.insert(fd2, file.clone());
Ok(0)
@ -278,7 +278,7 @@ fn sys_putc(c: char) -> SysResult {
}
fn get_file(fd: usize) -> Result<&'static Arc<Mutex<File>>, SysError> {
process().files.get(&fd).ok_or(SysError::InvalidFile)
process().files.get(&fd).ok_or(SysError::Badf)
}
pub type SysResult = Result<i32, SysError>;
@ -286,14 +286,21 @@ pub type SysResult = Result<i32, SysError>;
#[repr(i32)]
#[derive(Debug)]
pub enum SysError {
VfsError,
InvalidFile,
InvalidArgument,
// ucore compatible error code, which is a modified version of the ones used in linux
// name conversion E_XXXXX -> SysError::Xxxxx
// see https://github.com/oscourse-tsinghua/ucore_plus/blob/master/ucore/src/libs-user-ucore/common/error.h
// we only add current used errors here
Badf = 9,// Invaild fd number
Inval = 22,// Invalid argument.
Unknown = 65535,// A really really unknown error.
}
impl From<FsError> for SysError {
fn from(_: FsError) -> Self {
SysError::VfsError
fn from(error: FsError) -> Self {
match error {
_ => SysError::Unknown
}
}
}

Loading…
Cancel
Save