summaryrefslogtreecommitdiff
path: root/src/kernel/task
diff options
context:
space:
mode:
authorAlex AUVOLAT <alexis211@gmail.com>2012-05-19 16:38:56 +0200
committerAlex AUVOLAT <alexis211@gmail.com>2012-05-19 16:38:56 +0200
commitd502fce7d4db492690e39c72fc029aa05a65057d (patch)
treea5797a97212fff8142dc7f61792facca07c904eb /src/kernel/task
parent8e07c1db6ba4bedd0f8fe537a6fb0ca80e5d25f4 (diff)
downloadTCE-d502fce7d4db492690e39c72fc029aa05a65057d.tar.gz
TCE-d502fce7d4db492690e39c72fc029aa05a65057d.zip
More improvements in FWIK - more strings, Dir class, ...
Diffstat (limited to 'src/kernel/task')
-rw-r--r--src/kernel/task/task.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/kernel/task/task.cpp b/src/kernel/task/task.cpp
index 03425b5..5dea33b 100644
--- a/src/kernel/task/task.cpp
+++ b/src/kernel/task/task.cpp
@@ -68,7 +68,6 @@ void tasking_updateKernelPagetable(uint32_t idx, page_table *table, uint32_t tab
/* Called when a timer IRQ fires. Does a context switch. */
void schedule() {
- //if (processes == 0) PANIC("No processes are running !");
asm volatile("cli");
uint32_t esp, ebp, eip;
@@ -205,6 +204,7 @@ void process_exit(size_t retval) {
(its address is the value given for EIP).
It switches to user mode if necessary and calls the entry point. */
static void thread_run(void* u_esp, thread *thread, thread_entry entry_point, void *data) {
+ asm volatile("cli");
pagedir_switch(thread->process->pagedir);
if (thread->process->privilege >= PL_USER) { //User mode !
uint32_t *stack = (uint32_t*)u_esp;
@@ -237,6 +237,7 @@ static void thread_run(void* u_esp, thread *thread, thread_entry entry_point, vo
push %%eax; \
pushl $0x1B; \
push %%ecx; \
+ sti; \
iret; \
" : : "b"(esp), "c"(eip));
} else {