Rev 3022 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
Rev 3022 | Rev 4055 | ||
---|---|---|---|
Line 50... | Line 50... | ||
50 | #include <arch/context.h> |
50 | #include <arch/context.h> |
51 | #include <arch/fpu_context.h> |
51 | #include <arch/fpu_context.h> |
52 | #include <arch/cpu.h> |
52 | #include <arch/cpu.h> |
53 | #include <mm/tlb.h> |
53 | #include <mm/tlb.h> |
54 | #include <proc/scheduler.h> |
54 | #include <proc/scheduler.h> |
- | 55 | #include <udebug/udebug.h> |
|
- | 56 | #include <ipc/kbox.h> |
|
- | 57 | ||
- | 58 | #define TASK_NAME_BUFLEN 20 |
|
55 | 59 | ||
56 | struct thread; |
60 | struct thread; |
57 | 61 | ||
58 | /** Task structure. */ |
62 | /** Task structure. */ |
59 | typedef struct task { |
63 | typedef struct task { |
Line 64... | Line 68... | ||
64 | * |
68 | * |
65 | * Must be acquired before threads_lock and thread lock of any of its |
69 | * Must be acquired before threads_lock and thread lock of any of its |
66 | * threads. |
70 | * threads. |
67 | */ |
71 | */ |
68 | SPINLOCK_DECLARE(lock); |
72 | SPINLOCK_DECLARE(lock); |
69 | 73 | ||
70 | char *name; |
74 | char name[TASK_NAME_BUFLEN]; |
71 | /** List of threads contained in this task. */ |
75 | /** List of threads contained in this task. */ |
72 | link_t th_head; |
76 | link_t th_head; |
73 | /** Address space. */ |
77 | /** Address space. */ |
74 | as_t *as; |
78 | as_t *as; |
75 | /** Unique identity of task. */ |
79 | /** Unique identity of task. */ |
Line 91... | Line 95... | ||
91 | /** |
95 | /** |
92 | * Active asynchronous messages. It is used for limiting uspace to |
96 | * Active asynchronous messages. It is used for limiting uspace to |
93 | * certain extent. |
97 | * certain extent. |
94 | */ |
98 | */ |
95 | atomic_t active_calls; |
99 | atomic_t active_calls; |
- | 100 | ||
- | 101 | #ifdef CONFIG_UDEBUG |
|
- | 102 | /** Debugging stuff. */ |
|
- | 103 | udebug_task_t udebug; |
|
96 | 104 | ||
- | 105 | /** Kernel answerbox. */ |
|
- | 106 | kbox_t kb; |
|
- | 107 | #endif |
|
- | 108 | ||
97 | /** Architecture specific task data. */ |
109 | /** Architecture specific task data. */ |
98 | task_arch_t arch; |
110 | task_arch_t arch; |
99 | 111 | ||
100 | /** |
112 | /** |
101 | * Serializes access to the B+tree of task's futexes. This mutex is |
113 | * Serializes access to the B+tree of task's futexes. This mutex is |
Line 114... | Line 126... | ||
114 | 126 | ||
115 | extern void task_init(void); |
127 | extern void task_init(void); |
116 | extern void task_done(void); |
128 | extern void task_done(void); |
117 | extern task_t *task_create(as_t *as, char *name); |
129 | extern task_t *task_create(as_t *as, char *name); |
118 | extern void task_destroy(task_t *t); |
130 | extern void task_destroy(task_t *t); |
119 | extern task_t *task_run_program(void *program_addr, char *name); |
- | |
120 | extern task_t *task_find_by_id(task_id_t id); |
131 | extern task_t *task_find_by_id(task_id_t id); |
121 | extern int task_kill(task_id_t id); |
132 | extern int task_kill(task_id_t id); |
122 | extern uint64_t task_get_accounting(task_t *t); |
133 | extern uint64_t task_get_accounting(task_t *t); |
123 | 134 | ||
124 | extern void cap_set(task_t *t, cap_t caps); |
135 | extern void cap_set(task_t *t, cap_t caps); |
Line 131... | Line 142... | ||
131 | #ifndef task_destroy_arch |
142 | #ifndef task_destroy_arch |
132 | extern void task_destroy_arch(task_t *t); |
143 | extern void task_destroy_arch(task_t *t); |
133 | #endif |
144 | #endif |
134 | 145 | ||
135 | extern unative_t sys_task_get_id(task_id_t *uspace_task_id); |
146 | extern unative_t sys_task_get_id(task_id_t *uspace_task_id); |
- | 147 | extern unative_t sys_task_set_name(const char *uspace_name, size_t name_len); |
|
136 | 148 | ||
137 | #endif |
149 | #endif |
138 | 150 | ||
139 | /** @} |
151 | /** @} |
140 | */ |
152 | */ |