impl BlockedDevice for ucore::Device

master
WangRunji 7 years ago
parent 0d39ec0428
commit e56b22fa74

@ -12,6 +12,7 @@ use alloc::heap::{Alloc, AllocErr, Layout};
use core::mem::{size_of, self}; use core::mem::{size_of, self};
use core::ptr; use core::ptr;
use vfs; use vfs;
use blocked_device::BlockedDevice;
/// Lang items for bare lib /// Lang items for bare lib
mod lang { mod lang {
@ -330,56 +331,40 @@ impl IoBuf {
} }
} }
impl vfs::Device for Device { impl BlockedDevice for Device {
fn read_at(&mut self, offset: usize, buf: &mut [u8]) -> Option<usize> { fn block_size_log2(&self) -> u8 {
if self.blocksize != 4096 { if self.blocksize != 4096 {
unimplemented!("block_size != 4096 is not supported yet"); unimplemented!("block_size != 4096 is not supported yet");
} }
let begin_block = offset / 4096; 12
let end_block = (offset + buf.len() - 1) / 4096; // inclusive }
let begin_offset = offset % 4096;
let end_offset = (offset + buf.len() - 1) % 4096; fn read_at(&mut self, block_id: usize, buf: &mut [u8]) -> bool {
assert_eq!(begin_block, end_block, "more than 1 block is not supported yet"); assert!(buf.len() >= 4096);
use core::mem::uninitialized;
let mut block_buf: [u8; 4096] = unsafe{ uninitialized() };
let mut io_buf = IoBuf { let mut io_buf = IoBuf {
base: block_buf.as_mut_ptr(), base: buf.as_mut_ptr(),
offset: (begin_block * 4096) as i32, offset: (block_id * 4096) as i32,
len: 4096, len: 4096,
resident: 4096, resident: 4096,
}; };
let ret = (self.io)(self, &mut io_buf, false); let ret = (self.io)(self, &mut io_buf, false);
assert_eq!(ret, ErrorCode::Ok); assert_eq!(ret, ErrorCode::Ok);
assert_eq!(io_buf.resident, 0); assert_eq!(io_buf.resident, 0);
buf.copy_from_slice(&block_buf[begin_offset .. end_offset+1]); true
Some(buf.len())
} }
fn write_at(&mut self, offset: usize, buf: &[u8]) -> Option<usize> { fn write_at(&mut self, block_id: usize, buf: &[u8]) -> bool {
if self.blocksize != 4096 { assert!(buf.len() >= 4096);
unimplemented!("block_size != 4096 is not supported yet");
}
let begin_block = offset / 4096;
let end_block = (offset + buf.len() - 1) / 4096; // inclusive
let begin_offset = offset % 4096;
let end_offset = (offset + buf.len() - 1) % 4096;
assert_eq!(begin_block, end_block, "more than 1 block is not supported yet");
use core::mem::uninitialized;
let mut block_buf: [u8; 4096] = unsafe{ uninitialized() };
let mut io_buf = IoBuf { let mut io_buf = IoBuf {
base: block_buf.as_mut_ptr(), base: buf.as_ptr() as *mut _,
offset: (begin_block * 4096) as i32, offset: (block_id * 4096) as i32,
len: 4096, len: 4096,
resident: 4096, resident: 4096,
}; };
block_buf[begin_offset .. end_offset+1].copy_from_slice(&buf);
let ret = (self.io)(self, &mut io_buf, true); let ret = (self.io)(self, &mut io_buf, true);
assert_eq!(ret, ErrorCode::Ok); assert_eq!(ret, ErrorCode::Ok);
assert_eq!(io_buf.resident, 0); assert_eq!(io_buf.resident, 0);
Some(buf.len()) true
} }
} }

Loading…
Cancel
Save