d030f6d2fb6adfad5e6a7ff5a16f3098b4bb66a5
[lunaix-os.git] / lunaix-os / includes / lunaix / mm / region.h
1 #ifndef __LUNAIX_REGION_H
2 #define __LUNAIX_REGION_H
3
4 #include <lunaix/mm/mm.h>
5 #include <lunaix/mm/page.h>
6 #include <lunaix/mm/procvm.h>
7
8 #define prev_region(vmr) list_prev(vmr, struct mm_region, head)
9 #define next_region(vmr) list_next(vmr, struct mm_region, head)
10 #define get_region(vmr_el) list_entry(vmr_el, struct mm_region, head)
11
12 static inline int
13 stack_region(struct mm_region* region) {
14     return region->attr & REGION_TYPE_STACK;
15 }
16
17 static inline int
18 same_region(struct mm_region* a, struct mm_region* b) {
19     return a->start == b->start \
20             && a->end == b->end \
21             && a->attr == b->attr;
22 }
23
24 static inline bool
25 region_contains(struct mm_region* mm, ptr_t va) {
26     return mm->start <= va && va < mm->end;
27 }
28
29 static inline size_t
30 region_size(struct mm_region* mm) {
31     return mm->end - mm->start;
32 }
33
34
35 struct mm_region*
36 region_create(ptr_t start, ptr_t end, u32_t attr);
37
38 struct mm_region*
39 region_create_range(ptr_t start, size_t length, u32_t attr);
40
41 void
42 region_add(vm_regions_t* lead, struct mm_region* vmregion);
43
44 void
45 region_release(struct mm_region* region);
46
47 void
48 region_release_all(vm_regions_t* lead);
49
50 struct mm_region*
51 region_get(vm_regions_t* lead, unsigned long vaddr);
52
53 void
54 region_copy_mm(struct proc_mm* src, struct proc_mm* dest);
55
56 struct mm_region*
57 region_dup(struct mm_region* origin);
58
59 static u32_t
60 region_ptattr(struct mm_region* vmr)
61 {
62     u32_t vmr_attr = vmr->attr;
63     u32_t ptattr = PG_PRESENT | PG_ALLOW_USER;
64
65     if ((vmr_attr & PROT_WRITE)) {
66         ptattr |= PG_WRITE;
67     }
68
69     return ptattr & 0xfff;
70 }
71
72 #endif /* __LUNAIX_REGION_H */