diff --git a/Kernel/Syscalls/waitid.cpp b/Kernel/Syscalls/waitid.cpp index de0948745e..f94025d917 100644 --- a/Kernel/Syscalls/waitid.cpp +++ b/Kernel/Syscalls/waitid.cpp @@ -32,9 +32,12 @@ KResultOr Process::sys$waitid(Userspaceppid() != Process::current().pid()) { + if (!waitee_process) + return ECHILD; + bool waitee_is_child = waitee_process->ppid() == Process::current().pid(); + bool waitee_is_our_tracee = waitee_process->has_tracee_thread(Process::current().pid()); + if (!waitee_is_child && !waitee_is_our_tracee) return ECHILD; - } waitee = waitee_process.release_nonnull(); break; }