|
|
@ -3,11 +3,11 @@
|
|
|
|
use ucore_memory::memory_set::*;
|
|
|
|
use ucore_memory::memory_set::*;
|
|
|
|
use ucore_memory::paging::*;
|
|
|
|
use ucore_memory::paging::*;
|
|
|
|
|
|
|
|
|
|
|
|
type VirtAddr=usize;
|
|
|
|
type VirtAddr = usize;
|
|
|
|
type PhysAddr=usize;
|
|
|
|
type PhysAddr = usize;
|
|
|
|
|
|
|
|
|
|
|
|
use alloc::alloc::{alloc, Layout};
|
|
|
|
use alloc::alloc::{alloc, Layout};
|
|
|
|
use memory::alloc_stack;
|
|
|
|
use memory::{active_table, alloc_frame, alloc_stack, dealloc_frame};
|
|
|
|
|
|
|
|
|
|
|
|
/// TODO
|
|
|
|
/// TODO
|
|
|
|
pub struct ActivePageTable {
|
|
|
|
pub struct ActivePageTable {
|
|
|
@ -36,7 +36,7 @@ impl PageTable for ActivePageTable {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// For testing with mock
|
|
|
|
// For testing with mock
|
|
|
|
fn get_page_slice_mut<'a,'b>(&'a mut self, addr: VirtAddr) -> &'b mut [u8] {
|
|
|
|
fn get_page_slice_mut<'a, 'b>(&'a mut self, addr: VirtAddr) -> &'b mut [u8] {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -82,7 +82,6 @@ impl Entry for PageEntry {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn clear_accessed(&mut self) {
|
|
|
|
fn clear_accessed(&mut self) {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -99,7 +98,6 @@ impl Entry for PageEntry {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn target(&self) -> PhysAddr {
|
|
|
|
fn target(&self) -> PhysAddr {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -108,7 +106,6 @@ impl Entry for PageEntry {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// For Copy-on-write extension
|
|
|
|
// For Copy-on-write extension
|
|
|
|
fn writable_shared(&self) -> bool {
|
|
|
|
fn writable_shared(&self) -> bool {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
@ -126,7 +123,6 @@ impl Entry for PageEntry {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// For Swap extension
|
|
|
|
// For Swap extension
|
|
|
|
fn swapped(&self) -> bool {
|
|
|
|
fn swapped(&self) -> bool {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
@ -136,7 +132,6 @@ impl Entry for PageEntry {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn user(&self) -> bool {
|
|
|
|
fn user(&self) -> bool {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -152,7 +147,6 @@ impl Entry for PageEntry {
|
|
|
|
fn set_execute(&mut self, value: bool) {
|
|
|
|
fn set_execute(&mut self, value: bool) {
|
|
|
|
unimplemented!()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord)]
|
|
|
|
#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord)]
|
|
|
@ -186,14 +180,16 @@ impl InactivePageTable for InactivePageTable0 {
|
|
|
|
type Active = ActivePageTable;
|
|
|
|
type Active = ActivePageTable;
|
|
|
|
|
|
|
|
|
|
|
|
fn new() -> Self {
|
|
|
|
fn new() -> Self {
|
|
|
|
unsafe {let layout = Layout::new::<u64>();
|
|
|
|
unsafe {
|
|
|
|
let ptr = alloc(layout);
|
|
|
|
let layout = Layout::new::<u64>();
|
|
|
|
let frame = MockFrame::of_addr(*ptr as usize);
|
|
|
|
let ptr = alloc(layout);
|
|
|
|
InactivePageTable0 { p4_frame: frame }}
|
|
|
|
let frame = MockFrame::of_addr(*ptr as usize);
|
|
|
|
|
|
|
|
InactivePageTable0 { p4_frame: frame }
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn new_bare() -> Self {
|
|
|
|
fn new_bare() -> Self {
|
|
|
|
Self::new()
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn edit(&mut self, f: impl FnOnce(&mut Self::Active)) {
|
|
|
|
fn edit(&mut self, f: impl FnOnce(&mut Self::Active)) {
|
|
|
@ -201,11 +197,11 @@ impl InactivePageTable for InactivePageTable0 {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
unsafe fn activate(&self) {
|
|
|
|
unsafe fn activate(&self) {
|
|
|
|
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
unsafe fn with(&self, f: impl FnOnce()) {
|
|
|
|
unsafe fn with(&self, f: impl FnOnce()) {
|
|
|
|
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn token(&self) -> usize {
|
|
|
|
fn token(&self) -> usize {
|
|
|
@ -213,11 +209,11 @@ impl InactivePageTable for InactivePageTable0 {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn alloc_frame() -> Option<PhysAddr> {
|
|
|
|
fn alloc_frame() -> Option<PhysAddr> {
|
|
|
|
unimplemented!()
|
|
|
|
alloc_frame()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn dealloc_frame(target: PhysAddr) {
|
|
|
|
fn dealloc_frame(target: PhysAddr) {
|
|
|
|
|
|
|
|
dealloc_frame(target)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn alloc_stack() -> Stack {
|
|
|
|
fn alloc_stack() -> Stack {
|
|
|
|