diff options
author | dzwdz | 2024-07-22 20:49:58 +0200 |
---|---|---|
committer | dzwdz | 2024-07-22 20:49:58 +0200 |
commit | 2be2236e99e5aed779b820b540d72dffb47da406 (patch) | |
tree | 771913557b89e20c825bcc1fb29baa74c801e896 /src/kernel/proc.c | |
parent | acf0c1333d620821820b2246e1c7acc0aaf0bd44 (diff) |
kernel: explicitly store process RIP and RFLAGS
Once again, needed for the interrupt return syscall.
Seems to have made the kernel slower in timebench?
Diffstat (limited to 'src/kernel/proc.c')
-rw-r--r-- | src/kernel/proc.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/kernel/proc.c b/src/kernel/proc.c index 6cc1679..a22f632 100644 --- a/src/kernel/proc.c +++ b/src/kernel/proc.c @@ -40,7 +40,7 @@ Proc *proc_seed(void *data, size_t datalen) { for (uintptr_t off = 0; off < datalen; off += PAGE_SIZE) pagedir_map(proc_first->pages, init_base + off, data + off, true, true); - proc_first->regs.rcx = (uintptr_t)init_base; // SYSRET jumps to %rcx + proc_first->regs.rip = (uintptr_t)init_base; // proc_first->regs.r11 |= 1<<9; /* enable interrupts */ return proc_first; @@ -372,12 +372,12 @@ void proc_intr(Proc *p, const char *buf, size_t len) { /* save old rsp,rip */ struct intr_data d; void __user *sp = p->regs.rsp - 128 - sizeof(d); - d.ip = (void __user *)p->regs.rcx; + d.ip = (void __user *)p->regs.rip; d.sp = p->regs.rsp; pcpy_to(p, sp, &d, sizeof(d)); /* switch to intr handler */ - p->regs.rcx = (uint64_t)p->intr_fn; + p->regs.rip = (uint64_t)p->intr_fn; p->regs.rsp = sp; } |