summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2021-06-06 17:03:36 -0700
committerbunnei <bunneidev@gmail.com>2021-06-06 17:03:36 -0700
commit93f93cb8bc4cf25cbddd2918d0edec786ecce15b (patch)
treea688a862d5c8bb12f27f3e87cf14b697f282db2b /src
parent384cbe3829fadab52ac5f53d445fba4a76b8a284 (diff)
hle: kernel: k_server_session: Ensure service thread is valid before dereference.
Diffstat (limited to 'src')
-rw-r--r--src/core/hle/kernel/k_server_session.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/core/hle/kernel/k_server_session.cpp b/src/core/hle/kernel/k_server_session.cpp
index 3024395dd..96c8d7b0e 100644
--- a/src/core/hle/kernel/k_server_session.cpp
+++ b/src/core/hle/kernel/k_server_session.cpp
@@ -119,9 +119,11 @@ ResultCode KServerSession::QueueSyncRequest(KThread* thread, Core::Memory::Memor
context->PopulateFromIncomingCommandBuffer(kernel.CurrentProcess()->GetHandleTable(), cmd_buf);
- if (auto strong_ptr = manager->GetServiceThread().lock()) {
+ if (auto strong_ptr = manager->GetServiceThread().lock(); strong_ptr) {
strong_ptr->QueueSyncRequest(*parent, std::move(context));
return ResultSuccess;
+ } else {
+ ASSERT(false, "strong_ptr was nullptr!");
}
return ResultSuccess;