summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/thread.cpp
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2014-12-11 04:52:55 +0100
committerbunnei <bunneidev@gmail.com>2014-12-11 04:52:55 +0100
commit3a75c8069e9c044f6a8f2fd80c7d35ea245a9f6e (patch)
tree59d94738da7ef6f31ddbc8d4cbfbd58f578e25d8 /src/core/hle/kernel/thread.cpp
parentMerge pull request #239 from linkmauve/country-codes (diff)
parentMutex: Remove some forward declarations (diff)
downloadyuzu-3a75c8069e9c044f6a8f2fd80c7d35ea245a9f6e.tar
yuzu-3a75c8069e9c044f6a8f2fd80c7d35ea245a9f6e.tar.gz
yuzu-3a75c8069e9c044f6a8f2fd80c7d35ea245a9f6e.tar.bz2
yuzu-3a75c8069e9c044f6a8f2fd80c7d35ea245a9f6e.tar.lz
yuzu-3a75c8069e9c044f6a8f2fd80c7d35ea245a9f6e.tar.xz
yuzu-3a75c8069e9c044f6a8f2fd80c7d35ea245a9f6e.tar.zst
yuzu-3a75c8069e9c044f6a8f2fd80c7d35ea245a9f6e.zip
Diffstat (limited to 'src/core/hle/kernel/thread.cpp')
-rw-r--r--src/core/hle/kernel/thread.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/src/core/hle/kernel/thread.cpp b/src/core/hle/kernel/thread.cpp
index 1e879b45a..492b917e1 100644
--- a/src/core/hle/kernel/thread.cpp
+++ b/src/core/hle/kernel/thread.cpp
@@ -14,6 +14,7 @@
#include "core/hle/hle.h"
#include "core/hle/kernel/kernel.h"
#include "core/hle/kernel/thread.h"
+#include "core/hle/kernel/mutex.h"
#include "core/hle/result.h"
#include "core/mem_map.h"
@@ -164,6 +165,9 @@ ResultCode StopThread(Handle handle, const char* reason) {
Thread* thread = g_object_pool.Get<Thread>(handle);
if (thread == nullptr) return InvalidHandle(ErrorModule::Kernel);
+ // Release all the mutexes that this thread holds
+ ReleaseThreadMutexes(handle);
+
ChangeReadyState(thread, false);
thread->status = THREADSTATUS_DORMANT;
for (Handle waiting_handle : thread->waiting_threads) {