git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' of github.com:Minep/lunaix-os
[lunaix-os.git]
/
lunaix-os
/
includes
/
lunaix
/
mm
/
mm.h
diff --git
a/lunaix-os/includes/lunaix/mm/mm.h
b/lunaix-os/includes/lunaix/mm/mm.h
index 5e31e519165791067bcbb9a19f984b8200f1dfba..d5b8edd40b6fa41ac0fa8f3cf650f2fdcff99e90 100644
(file)
--- a/
lunaix-os/includes/lunaix/mm/mm.h
+++ b/
lunaix-os/includes/lunaix/mm/mm.h
@@
-1,20
+1,12
@@
#ifndef __LUNAIX_MM_H
#define __LUNAIX_MM_H
#ifndef __LUNAIX_MM_H
#define __LUNAIX_MM_H
-#include <lunaix/ds/llist.h>
-#include <lunaix/ds/mutex.h>
-#include <lunaix/fs.h>
#include <lunaix/types.h>
#include <lunaix/types.h>
+#include <lunaix/ds/llist.h>
-#include <
usr/sys/mann_flags
.h>
+#include <
sys/mm/memory
.h>
-typedef struct
-{
- void* start;
- void* brk;
- void* max_addr;
- mutex_t lock;
-} heap_context_t;
+#include <usr/lunaix/mann_flags.h>
/**
* @brief 私有区域,该区域中的页无法进行任何形式的共享。
/**
* @brief 私有区域,该区域中的页无法进行任何形式的共享。
@@
-45,20
+37,38
@@
typedef struct
#define REGION_EXEC PROT_EXEC
#define REGION_ANON MAP_ANON
#define REGION_RW REGION_READ | REGION_WRITE
#define REGION_EXEC PROT_EXEC
#define REGION_ANON MAP_ANON
#define REGION_RW REGION_READ | REGION_WRITE
+#define REGION_KERNEL (1 << 31)
-#define REGION_TYPE_CODE (1 << 16);
-#define REGION_TYPE_GENERAL (2 << 16);
-#define REGION_TYPE_HEAP (3 << 16);
-#define REGION_TYPE_STACK (4 << 16);
+#define REGION_TYPE_CODE (1 << 16)
+#define REGION_TYPE_GENERAL (2 << 16)
+#define REGION_TYPE_HEAP (3 << 16)
+#define REGION_TYPE_STACK (4 << 16)
+#define REGION_TYPE_VARS (5 << 16)
struct mm_region
{
struct llist_header head; // must be first field!
struct mm_region
{
struct llist_header head; // must be first field!
+ struct proc_mm* proc_vms;
+
+ // file mapped to this region
struct v_file* mfile;
struct v_file* mfile;
- u32_t offset;
+ // mapped file offset
+ off_t foff;
+ // mapped file length
+ u32_t flen; // XXX it seems that we don't need this actually..
+
ptr_t start;
ptr_t end;
u32_t attr;
ptr_t start;
ptr_t end;
u32_t attr;
+
+ void** index; // fast reference, to accelerate access to this very region.
+
+ void* data;
+ // when a region is copied
+ void (*region_copied)(struct mm_region*);
+ // when a region is unmapped
+ void (*destruct_region)(struct mm_region*);
};
};
+
#endif /* __LUNAIX_MM_H */
#endif /* __LUNAIX_MM_H */