#include #include #include #include #include struct registers _sysexit_regs; void sysexit(struct registers regs) { _sysexit_regs = regs; _sysexit_regs.ecx = (uintptr_t) regs.esp; _sysexit_regs.edx = (uintptr_t) 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 = (userptr_t) regs->ecx; // fix them up regs->eip = (userptr_t) regs->edx; irq_interrupt_flag(false); val = _syscall(regs->eax, regs->ebx, regs->esi, regs->edi, (uintptr_t)regs->ebp); if (process_current->state == PS_RUNNING) { // TODO move to _syscall() regs_savereturn(&process_current->regs, val); process_switch(process_current); // TODO process_resume } else { process_switch_any(); } }