summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/thread.cpp
diff options
context:
space:
mode:
authorLioncash <mathew1800@gmail.com>2019-03-16 04:28:29 +0100
committerLioncash <mathew1800@gmail.com>2019-03-16 04:58:31 +0100
commitc892cf01fad0c1fdeb6fc4644000c026176fe05a (patch)
tree4a4b6aac7d872c204fb4b9d4279f041d04939d15 /src/core/hle/kernel/thread.cpp
parentMerge pull request #2211 from lioncash/arbiter (diff)
downloadyuzu-c892cf01fad0c1fdeb6fc4644000c026176fe05a.tar
yuzu-c892cf01fad0c1fdeb6fc4644000c026176fe05a.tar.gz
yuzu-c892cf01fad0c1fdeb6fc4644000c026176fe05a.tar.bz2
yuzu-c892cf01fad0c1fdeb6fc4644000c026176fe05a.tar.lz
yuzu-c892cf01fad0c1fdeb6fc4644000c026176fe05a.tar.xz
yuzu-c892cf01fad0c1fdeb6fc4644000c026176fe05a.tar.zst
yuzu-c892cf01fad0c1fdeb6fc4644000c026176fe05a.zip
Diffstat (limited to 'src/core/hle/kernel/thread.cpp')
-rw-r--r--src/core/hle/kernel/thread.cpp13
1 files changed, 8 insertions, 5 deletions
diff --git a/src/core/hle/kernel/thread.cpp b/src/core/hle/kernel/thread.cpp
index eb54d6651..2e712c9cb 100644
--- a/src/core/hle/kernel/thread.cpp
+++ b/src/core/hle/kernel/thread.cpp
@@ -68,11 +68,6 @@ void Thread::Stop() {
owner_process->FreeTLSSlot(tls_address);
}
-void WaitCurrentThread_Sleep() {
- Thread* thread = GetCurrentThread();
- thread->SetStatus(ThreadStatus::WaitSleep);
-}
-
void ExitCurrentThread() {
Thread* thread = GetCurrentThread();
thread->Stop();
@@ -391,6 +386,14 @@ void Thread::SetActivity(ThreadActivity value) {
}
}
+void Thread::Sleep(s64 nanoseconds) {
+ // Sleep current thread and check for next thread to schedule
+ SetStatus(ThreadStatus::WaitSleep);
+
+ // Create an event to wake the thread up after the specified nanosecond delay has passed
+ WakeAfterDelay(nanoseconds);
+}
+
////////////////////////////////////////////////////////////////////////////////////////////////////
/**