diff --git a/src/scheme/live.rs b/src/scheme/live.rs
index a88d5c208981fa0c8e371c29af0a509e85d06f86..6cc6963838e7e9fbd7e8c9745530da2b5e55e17b 100644
--- a/src/scheme/live.rs
+++ b/src/scheme/live.rs
@@ -11,6 +11,10 @@ use syscall::error::*;
 use syscall::flag::{MODE_DIR, MODE_FILE};
 use syscall::scheme::{calc_seek_offset_usize, Scheme};
 
+use crate::memory::Frame;
+use crate::paging::{ActivePageTable, Page, PageFlags, PhysicalAddress, TableKind, VirtualAddress};
+use crate::paging::mapper::PageFlushAll;
+
 static mut LIST: [u8; 2] = [b'0', b'\n'];
 
 struct Handle {
@@ -47,8 +51,23 @@ impl DiskScheme {
         }
 
         if phys > 0 && size > 0 {
-            // Live disk pages already mapped
+            // Ensure live disk pages are mapped
             let virt = phys + crate::PHYS_OFFSET;
+            unsafe {
+                let mut active_table = ActivePageTable::new(TableKind::Kernel);
+                let flush_all = PageFlushAll::new();
+                let start_page = Page::containing_address(VirtualAddress::new(virt));
+                let end_page = Page::containing_address(VirtualAddress::new(virt + size - 1));
+                for page in Page::range_inclusive(start_page, end_page) {
+                    if active_table.translate_page(page).is_none() {
+                        let frame = Frame::containing_address(PhysicalAddress::new(page.start_address().data() - crate::PHYS_OFFSET));
+                        let flags = PageFlags::new().write(true);
+                        let result = active_table.map_to(page, frame, flags);
+                        flush_all.consume(result);
+                    }
+                }
+                flush_all.flush();
+            }
             Some(DiskScheme {
                 next_id: AtomicUsize::new(0),
                 list: Arc::new(RwLock::new(unsafe { &mut LIST })),