Rev 2089 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 2089 | Rev 2106 | ||
---|---|---|---|
Line 34... | Line 34... | ||
34 | 34 | ||
35 | #ifndef KERN_AS_HT_H_ |
35 | #ifndef KERN_AS_HT_H_ |
36 | #define KERN_AS_HT_H_ |
36 | #define KERN_AS_HT_H_ |
37 | 37 | ||
38 | #include <mm/mm.h> |
38 | #include <mm/mm.h> |
39 | #include <arch/mm/asid.h> |
- | |
40 | #include <adt/list.h> |
39 | #include <adt/list.h> |
41 | #include <adt/btree.h> |
- | |
42 | #include <synch/mutex.h> |
40 | #include <arch/types.h> |
43 | 41 | ||
44 | /** Address space structure. |
- | |
45 | * |
- | |
46 | * as_t contains the list of as_areas of userspace accessible |
- | |
47 | * pages for one or more tasks. Ranges of kernel memory pages are not |
- | |
48 | * supposed to figure in the list as they are shared by all tasks and |
- | |
49 | * set up during system initialization. |
- | |
50 | */ |
- | |
51 | typedef struct { |
42 | typedef struct { |
52 | /** Protected by asidlock. */ |
- | |
53 | link_t inactive_as_with_asid_link; |
43 | } as_genarch_t; |
54 | 44 | ||
55 | mutex_t lock; |
45 | struct as; |
56 | 46 | ||
57 | /** Number of references (i.e tasks that reference this as). */ |
- | |
58 | count_t refcount; |
- | |
59 | - | ||
60 | /** Number of processors on wich is this address space active. */ |
- | |
61 | count_t cpu_refcount; |
- | |
62 | - | ||
63 | /** B+tree of address space areas. */ |
- | |
64 | btree_t as_area_btree; |
- | |
65 | - | ||
66 | /** Address space identifier. Constant on architectures that do not support ASIDs.*/ |
- | |
67 | asid_t asid; |
- | |
68 | - | ||
69 | /** Architecture specific content. */ |
- | |
70 | as_arch_t arch; |
- | |
71 | } as_t; |
- | |
72 | - | ||
73 | typedef struct { |
47 | typedef struct pte { |
74 | link_t link; /**< Page hash table link. */ |
48 | link_t link; /**< Page hash table link. */ |
75 | as_t *as; /**< Address space. */ |
49 | struct as *as; /**< Address space. */ |
76 | uintptr_t page; /**< Virtual memory page. */ |
50 | uintptr_t page; /**< Virtual memory page. */ |
77 | uintptr_t frame; /**< Physical memory frame. */ |
51 | uintptr_t frame; /**< Physical memory frame. */ |
78 | unsigned g : 1; /**< Global page. */ |
52 | unsigned g : 1; /**< Global page. */ |
79 | unsigned x : 1; /**< Execute. */ |
53 | unsigned x : 1; /**< Execute. */ |
80 | unsigned w : 1; /**< Writable. */ |
54 | unsigned w : 1; /**< Writable. */ |