From 14aa8e3708ae7e82158e01e8b7957cd6dd691ffd Mon Sep 17 00:00:00 2001 From: Andreas Kling Date: Mon, 1 Mar 2021 19:47:16 +0100 Subject: [PATCH] Kernel: Oops, SC_abort was actually calling sys$exit_thread() --- Kernel/Syscall.cpp | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/Kernel/Syscall.cpp b/Kernel/Syscall.cpp index 6e1dbcabce7..14f85b4c397 100644 --- a/Kernel/Syscall.cpp +++ b/Kernel/Syscall.cpp @@ -102,11 +102,19 @@ KResultOr handle(RegisterState& regs, FlatPtr function, FlatPtr arg1, F process.tracer_trap(*current_thread, regs); // this triggers SIGTRAP and stops the thread! } - if (function == SC_exit) + switch (function) { + case SC_abort: + process.sys$abort(); + break; + case SC_exit: process.sys$exit(arg1); - else + break; + case SC_exit_thread: process.sys$exit_thread(arg1); - VERIFY_NOT_REACHED(); + break; + default: + VERIFY_NOT_REACHED(); + } } if (function == SC_fork || function == SC_sigreturn) {