diff --git a/os/src/mm/page_table.rs b/os/src/mm/page_table.rs index 91db66bb..a13bae23 100644 --- a/os/src/mm/page_table.rs +++ b/os/src/mm/page_table.rs @@ -102,12 +102,12 @@ impl PageTable { } result } - fn find_pte(&self, vpn: VirtPageNum) -> Option<&PageTableEntry> { + fn find_pte(&self, vpn: VirtPageNum) -> Option<&mut PageTableEntry> { let idxs = vpn.indexes(); let mut ppn = self.root_ppn; - let mut result: Option<&PageTableEntry> = None; + let mut result: Option<&mut PageTableEntry> = None; for i in 0..3 { - let pte = &ppn.get_pte_array()[idxs[i]]; + let pte = &mut ppn.get_pte_array()[idxs[i]]; if i == 2 { result = Some(pte); break; @@ -127,7 +127,7 @@ impl PageTable { } #[allow(unused)] pub fn unmap(&mut self, vpn: VirtPageNum) { - let pte = self.find_pte_create(vpn).unwrap(); + let pte = self.find_pte(vpn).unwrap(); assert!(pte.is_valid(), "vpn {:?} is invalid before unmapping", vpn); *pte = PageTableEntry::empty(); } @@ -198,4 +198,5 @@ pub fn translated_refmut(token: usize, ptr: *mut T) -> &'static mut T { let va = ptr as usize; //println!("translated_refmut: before translate_va"); page_table.translate_va(VirtAddr::from(va)).unwrap().get_mut() -} \ No newline at end of file +} +