summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/svc.cpp
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2018-01-07 22:55:17 +0100
committerbunnei <bunneidev@gmail.com>2018-01-07 22:55:17 +0100
commitbc8ef64804841c996aeebfe7ce23f34347a0be60 (patch)
tree79cc8d020ce8eba2eaa6355262bf8bb40db8596c /src/core/hle/kernel/svc.cpp
parentaudio: Log dropping frames as trace to reduce spam. (diff)
downloadyuzu-bc8ef64804841c996aeebfe7ce23f34347a0be60.tar
yuzu-bc8ef64804841c996aeebfe7ce23f34347a0be60.tar.gz
yuzu-bc8ef64804841c996aeebfe7ce23f34347a0be60.tar.bz2
yuzu-bc8ef64804841c996aeebfe7ce23f34347a0be60.tar.lz
yuzu-bc8ef64804841c996aeebfe7ce23f34347a0be60.tar.xz
yuzu-bc8ef64804841c996aeebfe7ce23f34347a0be60.tar.zst
yuzu-bc8ef64804841c996aeebfe7ce23f34347a0be60.zip
Diffstat (limited to 'src/core/hle/kernel/svc.cpp')
-rw-r--r--src/core/hle/kernel/svc.cpp23
1 files changed, 21 insertions, 2 deletions
diff --git a/src/core/hle/kernel/svc.cpp b/src/core/hle/kernel/svc.cpp
index 699d842fd..74643f598 100644
--- a/src/core/hle/kernel/svc.cpp
+++ b/src/core/hle/kernel/svc.cpp
@@ -520,8 +520,27 @@ static ResultCode WaitProcessWideKeyAtomic(VAddr mutex_addr, VAddr semaphore_add
}
/// Signal process wide key
-static ResultCode SignalProcessWideKey(VAddr addr, u32 target) {
- LOG_WARNING(Kernel_SVC, "(STUBBED) called, address=0x%llx, target=0x%08x", addr, target);
+static ResultCode SignalProcessWideKey(VAddr semaphore_addr, s32 target) {
+ LOG_TRACE(Kernel_SVC, "called, semaphore_addr=0x%llx, target=0x%08x", semaphore_addr, target);
+
+ // Wakeup all or one thread - Any other value is unimplemented
+ ASSERT(target == -1 || target == 1);
+
+ SharedPtr<Semaphore> semaphore = g_object_address_table.Get<Semaphore>(semaphore_addr);
+ if (!semaphore) {
+ // Create a new semaphore for the specified address if one does not already exist
+ semaphore = Semaphore::Create(semaphore_addr).Unwrap();
+ semaphore->name = Common::StringFromFormat("semaphore-%llx", semaphore_addr);
+ }
+
+ CASCADE_CODE(semaphore->Release(target));
+
+ if (semaphore->mutex_addr) {
+ // If a mutex was created for this semaphore, wait the current thread on it
+ SharedPtr<Mutex> mutex = g_object_address_table.Get<Mutex>(semaphore->mutex_addr);
+ return WaitSynchronization1(mutex, GetCurrentThread());
+ }
+
return RESULT_SUCCESS;
}