X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/d251b620d312e819923e55e223e0eb43b72a3bc6..09a115a4c07e26b3a978c693c0d6d17abea80479:/lunaix-os/kernel/mm/vmm.c diff --git a/lunaix-os/kernel/mm/vmm.c b/lunaix-os/kernel/mm/vmm.c index 1453c89..6e134fd 100644 --- a/lunaix-os/kernel/mm/vmm.c +++ b/lunaix-os/kernel/mm/vmm.c @@ -51,7 +51,9 @@ vmm_set_mapping(uintptr_t mnt, } // This must be writable - l1pt->entry[l1_inx] = NEW_L1_ENTRY(attr | PG_WRITE, new_l1pt_pa); + l1pt->entry[l1_inx] = + NEW_L1_ENTRY(attr | PG_WRITE | PG_PRESENT, new_l1pt_pa); + memset((void*)l2pt, 0, PG_SIZE); } else { x86_pte_t pte = l2pt->entry[l2_inx]; @@ -64,6 +66,10 @@ vmm_set_mapping(uintptr_t mnt, cpu_invplg(va); } + if ((options & VMAP_NOMAP)) { + return 1; + } + l2pt->entry[l2_inx] = NEW_L2_ENTRY(attr, pa); return 1; } @@ -122,6 +128,25 @@ vmm_lookup(uintptr_t va, v_mapping* mapping) return 0; } +void* +vmm_v2p(void* va) +{ + uint32_t l1_index = L1_INDEX(va); + uint32_t l2_index = L2_INDEX(va); + + x86_page_table* l1pt = (x86_page_table*)L1_BASE_VADDR; + x86_pte_t l1pte = l1pt->entry[l1_index]; + + if (l1pte) { + x86_pte_t* l2pte = + &((x86_page_table*)L2_VADDR(l1_index))->entry[l2_index]; + if (l2pte) { + return PG_ENTRY_ADDR(*l2pte) | ((uintptr_t)va & 0xfff); + } + } + return 0; +} + void* vmm_mount_pd(uintptr_t mnt, void* pde) {