1 #ifndef __LUNAIX_REGION_H
2 #define __LUNAIX_REGION_H
4 #include <lunaix/mm/mm.h>
5 #include <lunaix/mm/procvm.h>
7 #define prev_region(vmr) list_prev(vmr, struct mm_region, head)
8 #define next_region(vmr) list_next(vmr, struct mm_region, head)
9 #define get_region(vmr_el) list_entry(vmr_el, struct mm_region, head)
12 stack_region(struct mm_region* region) {
13 return region->attr & REGION_TYPE_STACK;
17 same_region(struct mm_region* a, struct mm_region* b) {
18 return a->start == b->start \
20 && a->attr == b->attr;
24 region_contains(struct mm_region* mm, ptr_t va) {
25 return mm->start <= va && va < mm->end;
29 region_size(struct mm_region* mm) {
30 return mm->end - mm->start;
34 anon_region(struct mm_region* mm) {
35 return (mm->attr & REGION_ANON);
39 writable_region(struct mm_region* mm) {
40 return !!(mm->attr & (REGION_RSHARED | REGION_WRITE));
44 readable_region(struct mm_region* mm) {
45 return !!(mm->attr & (REGION_RSHARED | REGION_READ));
49 executable_region(struct mm_region* mm) {
50 return !!(mm->attr & REGION_EXEC);
54 shared_writable_region(struct mm_region* mm) {
55 return !!(mm->attr & REGION_WSHARED);
60 region_create(ptr_t start, ptr_t end, u32_t attr);
63 region_create_range(ptr_t start, size_t length, u32_t attr);
66 region_add(vm_regions_t* lead, struct mm_region* vmregion);
69 region_release(struct mm_region* region);
72 region_release_all(vm_regions_t* lead);
75 region_get(vm_regions_t* lead, unsigned long vaddr);
78 region_copy_mm(struct proc_mm* src, struct proc_mm* dest);
81 region_dup(struct mm_region* origin);
84 region_tweakpte(struct mm_region* vmr, pte_t pte)
86 return translate_vmr_prot(vmr->attr, pte);
89 #endif /* __LUNAIX_REGION_H */