Rev 2089 | 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. */ |