#include #include struct registers _sysexit_regs; // a hack extern void _sysexit_real(void); 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(void) { 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 }