diff --git a/src/core/hle/kernel/server_session.cpp b/src/core/hle/kernel/server_session.cpp index 87d2d1ecb8..bf2e9e3764 100644 --- a/src/core/hle/kernel/server_session.cpp +++ b/src/core/hle/kernel/server_session.cpp @@ -63,6 +63,9 @@ ResultCode ServerSession::HandleSyncRequest(SharedPtr thread) { if (hle_handler != nullptr) { hle_handler->HandleSyncRequest(SharedPtr(this)); } else { + // Put the thread to sleep until the server replies, it will be awoken in + // svcReplyAndReceive. + thread->status = THREADSTATUS_WAIT_IPC; // Add the thread to the list of threads that have issued a sync request with this // server. pending_requesting_threads.push_back(std::move(thread)); diff --git a/src/core/hle/svc.cpp b/src/core/hle/svc.cpp index fe06af8f89..34b44fce14 100644 --- a/src/core/hle/svc.cpp +++ b/src/core/hle/svc.cpp @@ -241,8 +241,6 @@ static ResultCode SendSyncRequest(Kernel::Handle handle) { Core::System::GetInstance().PrepareReschedule(); - // TODO(Subv): svcSendSyncRequest should put the caller thread to sleep while the server - // responds and cause a reschedule. return session->SendSyncRequest(Kernel::GetCurrentThread()); }