use macro to handle IO error

master
WangRunji 6 years ago
parent 9b2c35dcf2
commit ef4e619d89

@ -44,7 +44,6 @@ use std::io::{Read, Seek, SeekFrom, Write};
use std::path::PathBuf; use std::path::PathBuf;
use std::sgxfs::{OpenOptions, SgxFile}; use std::sgxfs::{OpenOptions, SgxFile};
use std::sync::{SgxMutex as Mutex, SgxRwLock as RwLock}; use std::sync::{SgxMutex as Mutex, SgxRwLock as RwLock};
use std::untrusted::path::PathEx;
use std::vec::Vec; use std::vec::Vec;
#[no_mangle] #[no_mangle]
@ -59,13 +58,19 @@ pub extern "C" fn ecall_set_sefs_dir(path: *const u8, len: usize) -> i32 {
} }
} }
/// Helper macro to reply error when IO fails
macro_rules! try_io {
($expr:expr) => (match $expr {
Ok(val) => val,
Err(err) => return err.raw_os_error().unwrap(),
});
}
#[no_mangle] #[no_mangle]
pub extern "C" fn ecall_file_open(fd: usize) -> i32 { pub extern "C" fn ecall_file_open(fd: usize) -> i32 {
let path = get_path(fd); let path = get_path(fd);
let file = match OpenOptions::new().append(true).update(true).open(&path) { let file = try_io!(OpenOptions::new().append(true).update(true).binary(true).open(&path));
Ok(f) => f, println!("open fd = {}", fd);
Err(e) => { println!("open err {}", e); panic!() }
};
let file = LockedFile(Mutex::new(file)); let file = LockedFile(Mutex::new(file));
let mut files = FILES.write().unwrap(); let mut files = FILES.write().unwrap();
files.insert(fd, file); files.insert(fd, file);
@ -76,6 +81,7 @@ pub extern "C" fn ecall_file_open(fd: usize) -> i32 {
pub extern "C" fn ecall_file_close(fd: usize) -> i32 { pub extern "C" fn ecall_file_close(fd: usize) -> i32 {
let mut files = FILES.write().unwrap(); let mut files = FILES.write().unwrap();
files.remove(&fd); files.remove(&fd);
println!("close fd = {}", fd);
0 0
} }
@ -83,10 +89,9 @@ pub extern "C" fn ecall_file_close(fd: usize) -> i32 {
pub extern "C" fn ecall_file_flush(fd: usize) -> i32 { pub extern "C" fn ecall_file_flush(fd: usize) -> i32 {
let files = FILES.read().unwrap(); let files = FILES.read().unwrap();
let mut file = files[&fd].0.lock().unwrap(); let mut file = files[&fd].0.lock().unwrap();
match file.flush() { println!("flush fd = {}", fd);
Ok(_) => 0, try_io!(file.flush());
Err(_) => -1, 0
}
} }
#[no_mangle] #[no_mangle]
@ -94,17 +99,17 @@ pub extern "C" fn ecall_file_read_at(fd: usize, offset: usize, buf: *mut u8, len
let files = FILES.read().unwrap(); let files = FILES.read().unwrap();
let mut file = files[&fd].0.lock().unwrap(); let mut file = files[&fd].0.lock().unwrap();
println!("read_at fd = {}, offset = {}, len = {}", fd, offset, len);
let offset = offset as u64; let offset = offset as u64;
match file.seek(SeekFrom::Start(offset)) { println!("read_at fd = {}, offset = {}, len = {}", fd, offset, len);
Ok(real_offset) if real_offset == offset => {}, try_io!(file.seek(SeekFrom::Start(offset)));
_ => return -1, println!("pos = {}", try_io!(file.seek(SeekFrom::Current(0))));
}
let buf = unsafe { std::slice::from_raw_parts_mut(buf, len) }; let buf = unsafe { std::slice::from_raw_parts_mut(buf, len) };
match file.read(buf) { let len = try_io!(file.read(buf)) as i32;
Ok(len) => len as i32, println!("{:?}", buf);
Err(e) => {println!("read_at fail {}", e); -2}, println!("end pos = {}", try_io!(file.seek(SeekFrom::Current(0))));
}
len
} }
#[no_mangle] #[no_mangle]
@ -114,15 +119,14 @@ pub extern "C" fn ecall_file_write_at(fd: usize, offset: usize, buf: *const u8,
let offset = offset as u64; let offset = offset as u64;
println!("write_at fd = {}, offset = {}, len = {}", fd, offset, len); println!("write_at fd = {}, offset = {}, len = {}", fd, offset, len);
match file.seek(SeekFrom::Start(offset)) { try_io!(file.seek(SeekFrom::Start(offset)));
Ok(real_offset) if real_offset == offset => {}, println!("pos = {}", try_io!(file.seek(SeekFrom::Current(0))));
_ => return -1,
}
let buf = unsafe { std::slice::from_raw_parts(buf, len) }; let buf = unsafe { std::slice::from_raw_parts(buf, len) };
match file.write(buf) { let ret = try_io!(file.write(buf)) as i32;
Ok(len) => len as i32, println!("{:?}", buf);
Err(_) => return -2, println!("end pos = {}", try_io!(file.seek(SeekFrom::Current(0))));
}
ret
} }
#[no_mangle] #[no_mangle]
@ -131,17 +135,11 @@ pub extern "C" fn ecall_file_set_len(fd: usize, len: usize) -> i32 {
let mut file = files[&fd].0.lock().unwrap(); let mut file = files[&fd].0.lock().unwrap();
println!("set_len fd = {}, len = {}", fd, len); println!("set_len fd = {}, len = {}", fd, len);
let current_len = match file.seek(SeekFrom::End(0)) { let current_len = try_io!(file.seek(SeekFrom::End(0))) as usize;
Ok(len) => len as usize,
Err(_) => return -1,
};
if current_len < len { if current_len < len {
let mut zeros = Vec::<u8>::new(); let mut zeros = Vec::<u8>::new();
zeros.resize(len - current_len, 0); zeros.resize(len - current_len, 0);
match file.write(zeros.as_slice()) { try_io!(file.write(zeros.as_slice()));
Ok(_) => {}
Err(_) => return -2,
}
} }
// TODO: how to shrink a file? // TODO: how to shrink a file?
0 0

Loading…
Cancel
Save