X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/92f6e64a6da763c45ff9f4ab5eafcab3d8766dcb..b60166b327a9108b07e3069fa6568a451529ffd9:/lunaix-os/includes/lunaix/mm/region.h diff --git a/lunaix-os/includes/lunaix/mm/region.h b/lunaix-os/includes/lunaix/mm/region.h index c0ecd61..d030f6d 100644 --- a/lunaix-os/includes/lunaix/mm/region.h +++ b/lunaix-os/includes/lunaix/mm/region.h @@ -2,6 +2,35 @@ #define __LUNAIX_REGION_H #include +#include +#include + +#define prev_region(vmr) list_prev(vmr, struct mm_region, head) +#define next_region(vmr) list_next(vmr, struct mm_region, head) +#define get_region(vmr_el) list_entry(vmr_el, struct mm_region, head) + +static inline int +stack_region(struct mm_region* region) { + return region->attr & REGION_TYPE_STACK; +} + +static inline int +same_region(struct mm_region* a, struct mm_region* b) { + return a->start == b->start \ + && a->end == b->end \ + && a->attr == b->attr; +} + +static inline bool +region_contains(struct mm_region* mm, ptr_t va) { + return mm->start <= va && va < mm->end; +} + +static inline size_t +region_size(struct mm_region* mm) { + return mm->end - mm->start; +} + struct mm_region* region_create(ptr_t start, ptr_t end, u32_t attr); @@ -27,4 +56,17 @@ region_copy_mm(struct proc_mm* src, struct proc_mm* dest); struct mm_region* region_dup(struct mm_region* origin); +static u32_t +region_ptattr(struct mm_region* vmr) +{ + u32_t vmr_attr = vmr->attr; + u32_t ptattr = PG_PRESENT | PG_ALLOW_USER; + + if ((vmr_attr & PROT_WRITE)) { + ptattr |= PG_WRITE; + } + + return ptattr & 0xfff; +} + #endif /* __LUNAIX_REGION_H */