X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/e8e64a4f1d76aaeac3defa13243505cccd25c078..ebb55b7e5f0b8f31328950ec383b77b208ffbb64:/lunaix-os/kernel/mm/mmio.c diff --git a/lunaix-os/kernel/mm/mmio.c b/lunaix-os/kernel/mm/mmio.c index 5e0d01e..dbb1870 100644 --- a/lunaix-os/kernel/mm/mmio.c +++ b/lunaix-os/kernel/mm/mmio.c @@ -1,18 +1,26 @@ #include -#include -#include +#include +#include -void* -ioremap(uintptr_t paddr, uint32_t size) +ptr_t +ioremap(ptr_t paddr, u32_t size) { - return vmm_vmap(paddr, size, PG_PREM_RW | PG_DISABLE_CACHE); + // FIXME implement a page policy interface allow to decouple the + // arch-dependent caching behaviour + + pfn_t start = pfn(paddr); + size_t npages = leaf_count(size); + + // Ensure the range is reservable (not already in use) + assert(pmm_onhold_range(start, npages)); + + ptr_t addr = vmap_range(start, npages, KERNEL_DATA); + return addr + va_offset(paddr); } -void* -iounmap(uintptr_t vaddr, uint32_t size) +void +iounmap(ptr_t vaddr, u32_t size) { - for (size_t i = 0; i < size; i += PG_SIZE) { - uintptr_t paddr = vmm_del_mapping(PD_REFERENCED, vaddr + i); - pmm_free_page(KERNEL_PID, paddr); - } + assert(vaddr >= VMAP && vaddr < VMAP_END); + vunmap_range(pfn(vaddr), leaf_count(size)); } \ No newline at end of file