ccb57d7b0f248255c30129e495bb36f2860cbcf1
[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(paddr >> PG_SIZE_BITS,
13                                 CEIL(size, PG_SIZE_BITS),
14                                 PP_FGLOCKED);
15     }
16
17     return ptr;
18 }
19
20 void
21 iounmap(ptr_t vaddr, u32_t size)
22 {
23     for (size_t i = 0; i < size; i += PG_SIZE) {
24         ptr_t paddr = vmm_del_mapping(VMS_SELF, vaddr + i);
25         pmm_free_page(paddr);
26     }
27 }