summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/process.h
diff options
context:
space:
mode:
authorLioncash <mathew1800@gmail.com>2018-09-21 08:06:47 +0200
committerLioncash <mathew1800@gmail.com>2018-09-21 12:07:41 +0200
commit48b2eda492c064eeaf5af3716a9855b082eb2df7 (patch)
tree2a86155b190bfa5326f83444dab3f2b6c5c3da47 /src/core/hle/kernel/process.h
parentthread/process: Move TLS slot marking/freeing to the process class (diff)
downloadyuzu-48b2eda492c064eeaf5af3716a9855b082eb2df7.tar
yuzu-48b2eda492c064eeaf5af3716a9855b082eb2df7.tar.gz
yuzu-48b2eda492c064eeaf5af3716a9855b082eb2df7.tar.bz2
yuzu-48b2eda492c064eeaf5af3716a9855b082eb2df7.tar.lz
yuzu-48b2eda492c064eeaf5af3716a9855b082eb2df7.tar.xz
yuzu-48b2eda492c064eeaf5af3716a9855b082eb2df7.tar.zst
yuzu-48b2eda492c064eeaf5af3716a9855b082eb2df7.zip
Diffstat (limited to '')
-rw-r--r--src/core/hle/kernel/process.h27
1 files changed, 22 insertions, 5 deletions
diff --git a/src/core/hle/kernel/process.h b/src/core/hle/kernel/process.h
index 84027a31a..04d74e572 100644
--- a/src/core/hle/kernel/process.h
+++ b/src/core/hle/kernel/process.h
@@ -131,6 +131,16 @@ public:
return HANDLE_TYPE;
}
+ /// Gets the current status of the process
+ ProcessStatus GetStatus() const {
+ return status;
+ }
+
+ /// Gets the unique ID that identifies this particular process.
+ u32 GetProcessID() const {
+ return process_id;
+ }
+
/// Title ID corresponding to the process
u64 program_id;
@@ -154,11 +164,6 @@ public:
u32 allowed_processor_mask = THREADPROCESSORID_DEFAULT_MASK;
u32 allowed_thread_priority_mask = 0xFFFFFFFF;
u32 is_virtual_address_memory_enabled = 0;
- /// Current status of the process
- ProcessStatus status;
-
- /// The ID of this process
- u32 process_id = 0;
/**
* Parses a list of kernel capability descriptors (as found in the ExHeader) and applies them
@@ -171,6 +176,12 @@ public:
*/
void Run(VAddr entry_point, s32 main_thread_priority, u32 stack_size);
+ /**
+ * Prepares a process for termination by stopping all of its threads
+ * and clearing any other resources.
+ */
+ void PrepareForTermination();
+
void LoadModule(SharedPtr<CodeSet> module_, VAddr base_addr);
///////////////////////////////////////////////////////////////////////////////////////////////
@@ -195,6 +206,12 @@ private:
explicit Process(KernelCore& kernel);
~Process() override;
+ /// Current status of the process
+ ProcessStatus status;
+
+ /// The ID of this process
+ u32 process_id = 0;
+
// Memory used to back the allocations in the regular heap. A single vector is used to cover
// the entire virtual address space extents that bound the allocations, including any holes.
// This makes deallocation and reallocation of holes fast and keeps process memory contiguous