1 /* Public domain. */ 2 3 #ifndef _LINUX_MM_H 4 #define _LINUX_MM_H 5 6 #include <sys/types.h> 7 #include <sys/param.h> 8 #include <sys/malloc.h> 9 #include <sys/stdint.h> 10 #include <sys/atomic.h> 11 #include <machine/cpu.h> 12 #include <uvm/uvm_extern.h> 13 #include <linux/fs.h> 14 #include <linux/shrinker.h> 15 #include <linux/overflow.h> 16 #include <asm/pgtable.h> 17 18 #define PageHighMem(x) 0 19 20 #define page_to_phys(page) (VM_PAGE_TO_PHYS(page)) 21 #define page_to_pfn(pp) (VM_PAGE_TO_PHYS(pp) / PAGE_SIZE) 22 #define pfn_to_page(pfn) (PHYS_TO_VM_PAGE(ptoa(pfn))) 23 #define nth_page(page, n) (&(page)[(n)]) 24 #define offset_in_page(off) ((vaddr_t)(off) & PAGE_MASK) 25 #define set_page_dirty(page) atomic_clearbits_int(&page->pg_flags, PG_CLEAN) 26 27 #define PAGE_ALIGN(addr) (((addr) + PAGE_MASK) & ~PAGE_MASK) 28 29 #define PFN_UP(x) (((x) + PAGE_SIZE-1) >> PAGE_SHIFT) 30 #define PFN_DOWN(x) ((x) >> PAGE_SHIFT) 31 #define PFN_PHYS(x) ((x) << PAGE_SHIFT) 32 33 bool is_vmalloc_addr(const void *); 34 35 static inline void * 36 kvmalloc(size_t size, gfp_t flags) 37 { 38 return malloc(size, M_DRM, flags); 39 } 40 41 static inline void * 42 kvmalloc_array(size_t n, size_t size, int flags) 43 { 44 if (n != 0 && SIZE_MAX / n < size) 45 return NULL; 46 return malloc(n * size, M_DRM, flags); 47 } 48 49 static inline void * 50 kvcalloc(size_t n, size_t size, int flags) 51 { 52 return kvmalloc_array(n, size, flags | M_ZERO); 53 } 54 55 static inline void * 56 kvzalloc(size_t size, int flags) 57 { 58 return malloc(size, M_DRM, flags | M_ZERO); 59 } 60 61 static inline void 62 kvfree(const void *objp) 63 { 64 free((void *)objp, M_DRM, 0); 65 } 66 67 static inline long 68 si_mem_available(void) 69 { 70 return uvmexp.free; 71 } 72 73 #define MAX_ORDER 11 74 75 static inline unsigned int 76 get_order(size_t size) 77 { 78 return flsl((size - 1) >> PAGE_SHIFT); 79 } 80 81 static inline int 82 totalram_pages(void) 83 { 84 return uvmexp.npages; 85 } 86 87 #endif 88