43cc9e166ad2c0d2f288c997dfc2ec63c0a2fb69
[lunaix-os.git] / lunaix-os / kernel / mm / mmio.c
1 #include <lunaix/mm/mmio.h>
2 #include <lunaix/mm/pmm.h>
3 #include <lunaix/mm/vmm.h>
4 #include <lunaix/spike.h>
5
6 void*
7 ioremap(ptr_t paddr, u32_t size)
8 {
9     void* ptr = vmap(paddr, size, PG_PREM_RW | PG_DISABLE_CACHE, 0);
10
11     if (ptr) {
12         pmm_mark_chunk_occupied(KERNEL_PID,
13                                 paddr >> PG_SIZE_BITS,
14                                 CEIL(size, PG_SIZE_BITS),
15                                 PP_FGLOCKED);
16     }
17
18     return ptr;
19 }
20
21 void
22 iounmap(ptr_t vaddr, u32_t size)
23 {
24     for (size_t i = 0; i < size; i += PG_SIZE) {
25         ptr_t paddr = vmm_del_mapping(VMS_SELF, vaddr + i);
26         pmm_free_page(KERNEL_PID, paddr);
27     }
28 }