From 38da198aa14daef3b4dfb83d13e82bde91b98a8d Mon Sep 17 00:00:00 2001
From: Subv <subv2112@gmail.com>
Date: Sat, 10 Jan 2015 11:34:50 -0500
Subject: [PATCH] SVC: Wake up the thread after the delay in WaitSync1

---
 src/core/hle/svc.cpp | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

diff --git a/src/core/hle/svc.cpp b/src/core/hle/svc.cpp
index d3b4483ca..5c6a3be80 100644
--- a/src/core/hle/svc.cpp
+++ b/src/core/hle/svc.cpp
@@ -120,9 +120,6 @@ static Result CloseHandle(Handle handle) {
 
 /// Wait for a handle to synchronize, timeout after the specified nanoseconds
 static Result WaitSynchronization1(Handle handle, s64 nano_seconds) {
-    // TODO(bunnei): Do something with nano_seconds, currently ignoring this
-    bool wait_infinite = (nano_seconds == -1); // Used to wait until a thread has terminated
-
     SharedPtr<Kernel::Object> object = Kernel::g_handle_table.GetGeneric(handle);
     if (object == nullptr)
         return InvalidHandle(ErrorModule::Kernel).raw;
@@ -134,6 +131,8 @@ static Result WaitSynchronization1(Handle handle, s64 nano_seconds) {
 
     // Check for next thread to schedule
     if (wait.Succeeded() && *wait) {
+        // Create an event to wake the thread up after the specified nanosecond delay has passed
+        Kernel::WakeThreadAfterDelay(Kernel::GetCurrentThread(), nano_seconds);
         HLE::Reschedule(__func__);
     }