summaryrefslogtreecommitdiff
path: root/kernel/asm.s
diff options
context:
space:
mode:
authorJake Mannens <jake72360@gmail.com>2018-07-12 01:01:10 +1000
committerJake Mannens <jake72360@gmail.com>2018-07-12 01:01:10 +1000
commit778301ab212d9bb8ffa527491cbc93955eb0cb92 (patch)
treee62a2ee8180966d4fe41f80ba74f63977e51fcff /kernel/asm.s
parent6a6d5142d19638177c79c45d828f4b95db14799c (diff)
Task state information is no longer manually saved on context switch.
Since the kernel now has it's own stack unique to each address space, we can now rely on hardware task switching to *also* save the task states. To accomplish this, most of the code in switch_to() has been elimated. This includes; the clearing of the busy flag in the old TSS on each switch, setting the TR register to null prior to each switch and calling save_state() (which has also been removed entirely), to copy the state information. Modified the for loop in reschedule() to account for the fact that the switch_to() function may now return (which it *always* does when returning to the task). For the same reason, switch_to() must also be careful to preserve registers such as EBX and actually make a return following the far jump. Added basic definitions for task states in sched.h. These are; running, interruptible, uninterruptible, zombie and stopped. These states will (possibly) be used in the future to implement blocking system calls.
Diffstat (limited to 'kernel/asm.s')
-rw-r--r--kernel/asm.s14
1 files changed, 4 insertions, 10 deletions
diff --git a/kernel/asm.s b/kernel/asm.s
index 6d35334..fc36171 100644
--- a/kernel/asm.s
+++ b/kernel/asm.s
@@ -11,6 +11,7 @@ extern save_state
switch_to:
push ebp
mov ebp, esp
+ push ebx
; abort if we're switching to the current task
mov ebx, [ctask]
cmp ebx, [ebp+12]
@@ -18,16 +19,6 @@ switch_to:
pop ebp
ret
.skip:
- ; clear the busy flag in the current TSS
- mov eax, 0
- str ax
- add ax, gdt+5
- mov byte [eax], 0x89
- ; set the current TSS to null so it won't be overwritten by the switch
- mov ax, 0
- ltr ax
- ; copy the saved state into the previous TSS
- call save_state
; update ctask and ctaskn
mov ebx, [ebp+12]
mov [ctask], ebx
@@ -39,6 +30,9 @@ switch_to:
shl ebx, 3
mov [.tmp+4], bx
jmp far [.tmp]
+ pop ebx
+ pop ebp
+ ret
.tmp:
dq 0