aboutsummaryrefslogtreecommitdiff
path: root/kernel/features
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/features')
-rw-r--r--kernel/features/proc.asm7
-rw-r--r--kernel/features/proc.c13
2 files changed, 16 insertions, 4 deletions
diff --git a/kernel/features/proc.asm b/kernel/features/proc.asm
index 3d6bbc4..1a2ba65 100644
--- a/kernel/features/proc.asm
+++ b/kernel/features/proc.asm
@@ -1,11 +1,14 @@
%define USER_CODE_SEGMENT 0x18
%define USER_DATA_SEGMENT 0x20
%define RING3_MASK 0b11
+%define INTERRUPT_FLAG 0x200
global proc_jump_userspace
extern _esp
extern _eip
proc_jump_userspace:
+ cli
+
mov ax, USER_DATA_SEGMENT | RING3_MASK
mov ds, ax
mov es, ax
@@ -17,7 +20,9 @@ proc_jump_userspace:
push eax
pushf
- sti
+ pop eax
+ or eax, INTERRUPT_FLAG
+ push eax
push USER_CODE_SEGMENT | RING3_MASK
push dword [_eip]
diff --git a/kernel/features/proc.c b/kernel/features/proc.c
index 40a52f8..76ec16e 100644
--- a/kernel/features/proc.c
+++ b/kernel/features/proc.c
@@ -1,5 +1,6 @@
// MIT License, Copyright (c) 2020 Marvin Borner
+#include <assert.h>
#include <cpu.h>
#include <interrupts.h>
#include <load.h>
@@ -8,6 +9,7 @@
#include <proc.h>
#include <str.h>
#include <timer.h>
+#include <vesa.h>
u32 pid = 0;
struct proc *root;
@@ -26,11 +28,14 @@ void scheduler(struct regs *regs)
else
current = root;
- while (current->state == PROC_ASLEEP)
- if (!current->next)
+ while (current->state == PROC_ASLEEP) {
+ if (!current->next) {
+ assert(root->state == PROC_RUNNING || pid > 1);
current = root;
- else
+ } else {
current = current->next;
+ }
+ }
/* proc_print(); */
memcpy(regs, &current->regs, sizeof(struct regs));
@@ -104,5 +109,7 @@ void proc_init()
_eip = root->regs.eip;
_esp = root->regs.esp;
+ ((u32 *)_esp)[1] = (u32)vbe; // First argument
+
proc_jump_userspace();
}