From 13d8e33d9ae3ea4ccf0e16e24d5fbfaccd36e918 Mon Sep 17 00:00:00 2001 From: eladash Date: Fri, 3 May 2019 10:15:31 +0300 Subject: [PATCH] Return ESRCH if ppu thread ID was not found in sys_cond_signal_to --- rpcs3/Emu/Cell/lv2/sys_cond.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/rpcs3/Emu/Cell/lv2/sys_cond.cpp b/rpcs3/Emu/Cell/lv2/sys_cond.cpp index 36a5d6f41a..ccb02e26b4 100644 --- a/rpcs3/Emu/Cell/lv2/sys_cond.cpp +++ b/rpcs3/Emu/Cell/lv2/sys_cond.cpp @@ -154,6 +154,11 @@ error_code sys_cond_signal_to(ppu_thread& ppu, u32 cond_id, u32 thread_id) const auto cond = idm::check(cond_id, [&](lv2_cond& cond) -> cpu_thread* { + if (!idm::check_unlocked>(thread_id)) + { + return (cpu_thread*)(1); + } + if (cond.waiters) { std::lock_guard lock(cond.mutex->mutex); @@ -169,7 +174,7 @@ error_code sys_cond_signal_to(ppu_thread& ppu, u32 cond_id, u32 thread_id) return cpu; } - return (cpu_thread*)(1); + return (cpu_thread*)(2); } } } @@ -177,12 +182,12 @@ error_code sys_cond_signal_to(ppu_thread& ppu, u32 cond_id, u32 thread_id) return nullptr; }); - if (!cond) + if (!cond || cond.ret == (cpu_thread*)(1)) { return CELL_ESRCH; } - if (cond.ret && cond.ret != (cpu_thread*)(1)) + if (cond.ret && cond.ret != (cpu_thread*)(2)) { cond->awake(*cond.ret); }