2016-08-14 23:58:35 +02:00
|
|
|
//! Filesystem syscalls
|
|
|
|
|
2016-08-15 05:38:32 +02:00
|
|
|
use scheme::Scheme;
|
|
|
|
|
2016-08-15 02:16:56 +02:00
|
|
|
use super::{Error, Result};
|
2016-08-14 23:58:35 +02:00
|
|
|
|
|
|
|
/// Read syscall
|
|
|
|
pub fn read(fd: usize, buf: &mut [u8]) -> Result<usize> {
|
|
|
|
println!("Read {}: {}", fd, buf.len());
|
2016-08-15 03:17:55 +02:00
|
|
|
if let Some(file) = unsafe { &mut ::context::CONTEXT }.files.get(fd) {
|
|
|
|
println!("{:?}", file);
|
|
|
|
Ok(0)
|
|
|
|
} else {
|
|
|
|
Err(Error::BadFile)
|
|
|
|
}
|
2016-08-14 23:58:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Write syscall
|
|
|
|
pub fn write(fd: usize, buf: &[u8]) -> Result<usize> {
|
|
|
|
println!("Write {}: {}", fd, buf.len());
|
2016-08-15 02:16:56 +02:00
|
|
|
if let Some(file) = unsafe { &mut ::context::CONTEXT }.files.get(fd) {
|
|
|
|
println!("{:?}: {:?}", file, ::core::str::from_utf8(buf));
|
|
|
|
Ok(buf.len())
|
|
|
|
} else {
|
|
|
|
Err(Error::BadFile)
|
|
|
|
}
|
2016-08-14 23:58:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Open syscall
|
|
|
|
pub fn open(path: &[u8], flags: usize) -> Result<usize> {
|
|
|
|
println!("Open {:?}: {:X}", ::core::str::from_utf8(path), flags);
|
2016-08-15 05:38:32 +02:00
|
|
|
let file = unsafe { &mut ::scheme::SCHEME }.open(path, flags)?;
|
2016-08-15 02:16:56 +02:00
|
|
|
if let Some(fd) = unsafe { &mut ::context::CONTEXT }.add_file(::context::file::File {
|
|
|
|
scheme: 0,
|
2016-08-15 05:38:32 +02:00
|
|
|
number: file
|
2016-08-15 02:16:56 +02:00
|
|
|
}) {
|
|
|
|
Ok(fd)
|
|
|
|
} else {
|
|
|
|
Err(Error::TooManyFiles)
|
|
|
|
}
|
2016-08-14 23:58:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Close syscall
|
|
|
|
pub fn close(fd: usize) -> Result<usize> {
|
|
|
|
println!("Close {}", fd);
|
|
|
|
Ok(0)
|
|
|
|
}
|