diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/init/main.c | 3 | ||||
-rw-r--r-- | src/kernel/proc.c | 15 | ||||
-rw-r--r-- | src/kernel/proc.h | 13 | ||||
-rw-r--r-- | src/kernel/syscalls.c | 6 |
4 files changed, 35 insertions, 2 deletions
diff --git a/src/init/main.c b/src/init/main.c index 41a6ac0..c32ac01 100644 --- a/src/init/main.c +++ b/src/init/main.c @@ -20,6 +20,9 @@ int main() { _syscall(SC_FORK, 0, 0, 0); + debuglog("i got forked. ", + sizeof("i got forked. ") - 1); + exit( "bye from init! ", sizeof("bye from init! ") - 1); } diff --git a/src/kernel/proc.c b/src/kernel/proc.c index b165878..36c88b5 100644 --- a/src/kernel/proc.c +++ b/src/kernel/proc.c @@ -4,11 +4,16 @@ #include <kernel/util.h> #include <stdint.h> +struct process *process_first; struct process *process_current; struct process *process_new() { struct process *proc = page_alloc(1); // TODO kmalloc proc->pages = pagedir_new(); + proc->state = PS_RUNNING; + proc->next = NULL; + + process_first = proc; // map the stack to the last page in memory pagedir_map(proc->pages, (void*)~PAGE_MASK, page_alloc(1), true, true); @@ -24,10 +29,11 @@ struct process *process_new() { return proc; } -struct process *process_clone(const struct process *orig) { +struct process *process_clone(struct process *orig) { struct process *clone = page_alloc(1); memcpy(clone, orig, sizeof(struct process)); clone->pages = pagedir_copy(orig->pages); + orig->next = clone; return clone; } @@ -37,3 +43,10 @@ void process_switch(struct process *proc) { pagedir_switch(proc->pages); sysexit(proc->regs); } + +struct process *process_find(enum process_state target) { + struct process *iter = process_first; + while (iter && (iter->state != target)) + iter = iter->next; + return iter; +} diff --git a/src/kernel/proc.h b/src/kernel/proc.h index 71880e6..6d1ed8c 100644 --- a/src/kernel/proc.h +++ b/src/kernel/proc.h @@ -1,14 +1,25 @@ #pragma once #include <kernel/arch/generic.h> +enum process_state { + PS_RUNNING, + PS_DEAD, +}; + struct process { void *stack_top; struct pagedir *pages; struct registers regs; + enum process_state state; + + struct process *next; }; +extern struct process *process_first; extern struct process *process_current; struct process *process_new(); -struct process *process_clone(const struct process *orig); +struct process *process_clone(struct process *orig); _Noreturn void process_switch(struct process *proc); + +struct process *process_find(enum process_state); diff --git a/src/kernel/syscalls.c b/src/kernel/syscalls.c index eff670e..3d35a4a 100644 --- a/src/kernel/syscalls.c +++ b/src/kernel/syscalls.c @@ -5,6 +5,12 @@ #include <stdint.h> _Noreturn void sc_exit(const char *msg, size_t len) { + process_current->state = PS_DEAD; + + process_current = process_find(PS_RUNNING); + if (process_current) + process_switch(process_current); + log_const("last process returned. "); panic(); } |