summaryrefslogtreecommitdiff
path: root/kernel/src
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/src')
-rw-r--r--kernel/src/check/panic.c50
-rw-r--r--kernel/src/scheduler/process.c0
-rw-r--r--kernel/src/scheduler/switch.S44
3 files changed, 57 insertions, 37 deletions
diff --git a/kernel/src/check/panic.c b/kernel/src/check/panic.c
index ac40078..b5e02a2 100644
--- a/kernel/src/check/panic.c
+++ b/kernel/src/check/panic.c
@@ -15,33 +15,33 @@ __attribute__((noreturn)) void panic(uint64_t rsp, const char *s, ...)
va_end(list);
if (rsp) {
- uint64_t seg = *(uint64_t *)(rsp + SEG_OFF);
+ regs_t *regs = (regs_t *)rsp;
printf("info regs:\n");
- printf("rax: 0x%x; ", *(uint64_t *)(rsp + RAX_OFF));
- printf("rbx: 0x%x; ", *(uint64_t *)(rsp + RBX_OFF));
- printf("rcx: 0x%x; ", *(uint64_t *)(rsp + RCX_OFF));
- printf("rdx: 0x%x; ", *(uint64_t *)(rsp + RDX_OFF));
- printf("rdi: 0x%x; ", *(uint64_t *)(rsp + RDI_OFF));
- printf("rsi: 0x%x; ", *(uint64_t *)(rsp + RSI_OFF));
- printf("rsp: 0x%x; ", *(uint64_t *)(rsp + RSP_OFF));
- printf("rbp: 0x%x; ", *(uint64_t *)(rsp + RBP_OFF));
- printf("r8: 0x%x; ", *(uint64_t *)(rsp + R8_OFF));
- printf("r9: 0x%x; ", *(uint64_t *)(rsp + R9_OFF));
- printf("r10: 0x%x; ", *(uint64_t *)(rsp + R10_OFF));
- printf("r11: 0x%x; ", *(uint64_t *)(rsp + R11_OFF));
- printf("r12: 0x%x; ", *(uint64_t *)(rsp + R12_OFF));
- printf("r13: 0x%x; ", *(uint64_t *)(rsp + R13_OFF));
- printf("r14: 0x%x; ", *(uint64_t *)(rsp + R14_OFF));
- printf("r15: 0x%x; ", *(uint64_t *)(rsp + R15_OFF));
- printf("rip: 0x%x; ", *(uint64_t *)(rsp + RIP_OFF));
- printf("cs: 0x%x; ", *(uint64_t *)(rsp + CS_OFF));
- printf("ds: 0x%x; ", seg >> 48);
- printf("ss: 0x%x; ", *(uint64_t *)(rsp + SS_OFF));
- printf("es: 0x%x; ", (seg >> 32) & 0xFFFF);
- printf("fs: 0x%x; ", (seg >> 16) & 0xFFFF);
- printf("gs: 0x%x; ", seg & 0xFFFF);
- printf("rflags: 0x%x; ", *(uint64_t *)(rsp + RFLAGS_OFF));
+ printf("rax: 0x%x; ", regs->rax);
+ printf("rbx: 0x%x; ", regs->rbx);
+ printf("rcx: 0x%x; ", regs->rcx);
+ printf("rdx: 0x%x; ", regs->rdx);
+ printf("rdi: 0x%x; ", regs->rdi);
+ printf("rsi: 0x%x; ", regs->rsi);
+ printf("rsp: 0x%x; ", regs->rsp);
+ printf("rbp: 0x%x; ", regs->rbp);
+ printf("r8: 0x%x; ", regs->r8);
+ printf("r9: 0x%x; ", regs->r9);
+ printf("r10: 0x%x; ", regs->r10);
+ printf("r11: 0x%x; ", regs->r11);
+ printf("r12: 0x%x; ", regs->r12);
+ printf("r13: 0x%x; ", regs->r13);
+ printf("r14: 0x%x; ", regs->r14);
+ printf("r15: 0x%x; ", regs->r15);
+ printf("rip: 0x%x; ", regs->rip);
+ printf("cs: 0x%x; ", regs->cs);
+ printf("ds: 0x%x; ", regs->seg >> 48);
+ printf("ss: 0x%x; ", regs->ss);
+ printf("es: 0x%x; ", (regs->seg >> 32) & 0xFFFF);
+ printf("fs: 0x%x; ", (regs->seg >> 16) & 0xFFFF);
+ printf("gs: 0x%x; ", regs->seg & 0xFFFF);
+ printf("rflags: 0x%x; ", regs->rflags);
}
disable_interrupts();
diff --git a/kernel/src/scheduler/process.c b/kernel/src/scheduler/process.c
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/kernel/src/scheduler/process.c
diff --git a/kernel/src/scheduler/switch.S b/kernel/src/scheduler/switch.S
index f4d0e79..4e216e0 100644
--- a/kernel/src/scheduler/switch.S
+++ b/kernel/src/scheduler/switch.S
@@ -1,18 +1,38 @@
#include "x86_64_regs.S"
-.global context_switch
-context_switch:
- /* switch rsp to old task's %rsp */
+/* %rdi - irq's rsp */
+/* %rsi - task's rsp */
+.global save_to_rsp
+save_context_to_rsp:
+ mov %rsi, %rsp
+ push SS_OFF(%rdi)
+ push RSP_OFF(%rdi)
+ push RFLAGS_OFF(%rdi)
+ push CS_OFF(%rdi)
+ push RIP_OFF(%rdi)
+ push $0
+ push RAX_OFF(%rdi)
+ push RCX_OFF(%rdi)
+ push RDX_OFF(%rdi)
+ push RSI_OFF(%rdi)
+ push RDI_OFF(%rdi)
+ push R8_OFF(%rdi)
+ push R9_OFF(%rdi)
+ push R10_OFF(%rdi)
+ push R11_OFF(%rdi)
+ push SEG_OFF(%rdi)
+ push RBX_OFF(%rdi)
+ push RBP_OFF(%rdi)
+ push R12_OFF(%rdi)
+ push R13_OFF(%rdi)
+ push R14_OFF(%rdi)
+ push R15_OFF(%rdi)
- /* save all old task's registers */
- push_caller_saved
- push_callee_saved
-
- /* save old task's rsp & rip */
- call schedule
- /* get new task's rsp & rip */
-
- /* restore all new task's registers */
+/* %rdi - task's rsp */
+.global restore_from_rsp
+restore_context_from_rsp:
+ mov %rdi, %rsp
pop_callee_saved
pop_caller_saved
+ add $8, %rsp
iretq