summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel
diff options
context:
space:
mode:
authorLiam <byteslice@airmail.cc>2022-12-06 22:13:42 +0100
committerLiam <byteslice@airmail.cc>2022-12-06 22:13:42 +0100
commit9704acb982eb3dfb4b2b6a090f5613d4ac57b196 (patch)
treeffc2dd5818b94e61e09eed5388cb821c90dc0896 /src/core/hle/kernel
parentMerge pull request #9393 from liamwhite/more-vulkan (diff)
downloadyuzu-9704acb982eb3dfb4b2b6a090f5613d4ac57b196.tar
yuzu-9704acb982eb3dfb4b2b6a090f5613d4ac57b196.tar.gz
yuzu-9704acb982eb3dfb4b2b6a090f5613d4ac57b196.tar.bz2
yuzu-9704acb982eb3dfb4b2b6a090f5613d4ac57b196.tar.lz
yuzu-9704acb982eb3dfb4b2b6a090f5613d4ac57b196.tar.xz
yuzu-9704acb982eb3dfb4b2b6a090f5613d4ac57b196.tar.zst
yuzu-9704acb982eb3dfb4b2b6a090f5613d4ac57b196.zip
Diffstat (limited to 'src/core/hle/kernel')
-rw-r--r--src/core/hle/kernel/kernel.cpp14
1 files changed, 9 insertions, 5 deletions
diff --git a/src/core/hle/kernel/kernel.cpp b/src/core/hle/kernel/kernel.cpp
index 288f97df5..0eb74a422 100644
--- a/src/core/hle/kernel/kernel.cpp
+++ b/src/core/hle/kernel/kernel.cpp
@@ -104,12 +104,16 @@ struct KernelCore::Impl {
}
void CloseCurrentProcess() {
- (*current_process).Finalize();
- // current_process->Close();
- // TODO: The current process should be destroyed based on accurate ref counting after
+ KProcess* old_process = current_process.exchange(nullptr);
+ if (old_process == nullptr) {
+ return;
+ }
+
+ // old_process->Close();
+ // TODO: The process should be destroyed based on accurate ref counting after
// calling Close(). Adding a manual Destroy() call instead to avoid a memory leak.
- (*current_process).Destroy();
- current_process = nullptr;
+ old_process->Finalize();
+ old_process->Destroy();
}
void Shutdown() {