summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/thread.h
diff options
context:
space:
mode:
authorLuke Street <luke.street@encounterpc.com>2018-12-03 18:25:27 +0100
committerLuke Street <luke.street@encounterpc.com>2018-12-04 07:23:50 +0100
commit3e75175d0242090902e4b383086e3f5ac6cf3f73 (patch)
treec6ff5eb9787f21284a5748ad210c866d32e04bcd /src/core/hle/kernel/thread.h
parentMerge pull request #1852 from VPeruS/fix-format-string (diff)
downloadyuzu-3e75175d0242090902e4b383086e3f5ac6cf3f73.tar
yuzu-3e75175d0242090902e4b383086e3f5ac6cf3f73.tar.gz
yuzu-3e75175d0242090902e4b383086e3f5ac6cf3f73.tar.bz2
yuzu-3e75175d0242090902e4b383086e3f5ac6cf3f73.tar.lz
yuzu-3e75175d0242090902e4b383086e3f5ac6cf3f73.tar.xz
yuzu-3e75175d0242090902e4b383086e3f5ac6cf3f73.tar.zst
yuzu-3e75175d0242090902e4b383086e3f5ac6cf3f73.zip
Diffstat (limited to '')
-rw-r--r--src/core/hle/kernel/thread.h14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/core/hle/kernel/thread.h b/src/core/hle/kernel/thread.h
index d384d50db..268bf845b 100644
--- a/src/core/hle/kernel/thread.h
+++ b/src/core/hle/kernel/thread.h
@@ -44,6 +44,7 @@ enum ThreadProcessorId : s32 {
enum class ThreadStatus {
Running, ///< Currently running
Ready, ///< Ready to run
+ Paused, ///< Paused by SetThreadActivity or debug
WaitHLEEvent, ///< Waiting for hle event to finish
WaitSleep, ///< Waiting due to a SleepThread SVC
WaitIPC, ///< Waiting for the reply from an IPC request
@@ -60,6 +61,11 @@ enum class ThreadWakeupReason {
Timeout // The thread was woken up due to a wait timeout.
};
+enum class ThreadActivity : u32 {
+ Normal = 0,
+ Paused = 1,
+};
+
class Thread final : public WaitObject {
public:
using TLSMemory = std::vector<u8>;
@@ -370,6 +376,12 @@ public:
return affinity_mask;
}
+ ThreadActivity GetActivity() const {
+ return activity;
+ }
+
+ void SetActivity(ThreadActivity value);
+
private:
explicit Thread(KernelCore& kernel);
~Thread() override;
@@ -438,6 +450,8 @@ private:
TLSMemoryPtr tls_memory = std::make_shared<TLSMemory>();
std::string name;
+
+ ThreadActivity activity = ThreadActivity::Normal;
};
/**