blob: b24c857f6170098e3b059a3195f4d56997dc6569 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
#include <kernel/arch/generic.h>
#include <kernel/proc.h>
struct registers _sysexit_regs; // a hack
extern void _sysexit_real();
void sysexit(struct registers regs) {
_sysexit_regs = regs;
_sysexit_regs.ecx = regs.esp;
_sysexit_regs.edx = regs.eip;
_sysexit_real();
__builtin_unreachable();
}
_Noreturn void sysenter_stage2() {
uint64_t val;
struct registers *regs = &process_current->regs;
*regs = _sysexit_regs; // save the registers
regs->esp = regs->ecx; // fix them up
regs->eip = regs->edx;
val = syscall_handler(regs->eax, regs->ebx,
regs->esi, regs->edi);
regs_savereturn(&process_current->regs, val);
process_switch(process_current); // TODO process_resume
}
|