xref: /openbsd-src/sys/dev/pci/drm/include/linux/mm.h (revision 09467b48e8bc8b4905716062da846024139afbf2)
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_address(x)		VM_PAGE_TO_PHYS(x)
21 #define page_to_phys(page)	(VM_PAGE_TO_PHYS(page))
22 #define page_to_pfn(pp)		(VM_PAGE_TO_PHYS(pp) / PAGE_SIZE)
23 #define pfn_to_page(pfn)	(PHYS_TO_VM_PAGE(ptoa(pfn)))
24 #define nth_page(page, n)	(&(page)[(n)])
25 #define offset_in_page(off)	((vaddr_t)(off) & PAGE_MASK)
26 #define set_page_dirty(page)	atomic_clearbits_int(&page->pg_flags, PG_CLEAN)
27 
28 #define PAGE_ALIGN(addr)	(((addr) + PAGE_MASK) & ~PAGE_MASK)
29 
30 #define PFN_UP(x)		(((x) + PAGE_SIZE-1) >> PAGE_SHIFT)
31 #define PFN_DOWN(x)		((x) >> PAGE_SHIFT)
32 #define PFN_PHYS(x)		((x) << PAGE_SHIFT)
33 
34 #define is_vmalloc_addr(ptr)	true
35 
36 static inline void *
37 kvmalloc(size_t size, gfp_t flags)
38 {
39 	return malloc(size, M_DRM, flags);
40 }
41 
42 static inline void *
43 kvmalloc_array(size_t n, size_t size, int flags)
44 {
45 	if (n != 0 && SIZE_MAX / n < size)
46 		return NULL;
47 	return malloc(n * size, M_DRM, flags);
48 }
49 
50 static inline void *
51 kvcalloc(size_t n, size_t size, int flags)
52 {
53 	return kvmalloc_array(n, size, flags | M_ZERO);
54 }
55 
56 static inline void *
57 kvzalloc(size_t size, int flags)
58 {
59 	return malloc(size, M_DRM, flags | M_ZERO);
60 }
61 
62 static inline void
63 kvfree(const void *objp)
64 {
65 	free((void *)objp, M_DRM, 0);
66 }
67 
68 static inline long
69 si_mem_available(void)
70 {
71 	return uvmexp.free;
72 }
73 
74 #define MAX_ORDER	11
75 
76 static inline unsigned int
77 get_order(size_t size)
78 {
79 	return flsl((size - 1) >> PAGE_SHIFT);
80 }
81 
82 #endif
83