hle: kernel: service_thread: Take reference to KServerSession on service request.
This commit is contained in:
parent
e33ffdc555
commit
6418a42884
@ -74,21 +74,17 @@ void ServiceThread::Impl::QueueSyncRequest(KSession& session,
|
|||||||
{
|
{
|
||||||
std::unique_lock lock{queue_mutex};
|
std::unique_lock lock{queue_mutex};
|
||||||
|
|
||||||
|
auto* server_session{&session.GetServerSession()};
|
||||||
|
|
||||||
// Open a reference to the session to ensure it is not closes while the service request
|
// Open a reference to the session to ensure it is not closes while the service request
|
||||||
// completes asynchronously.
|
// completes asynchronously.
|
||||||
session.Open();
|
server_session->Open();
|
||||||
|
|
||||||
requests.emplace([session_ptr{&session}, context{std::move(context)}]() {
|
requests.emplace([server_session, context{std::move(context)}]() {
|
||||||
// Close the reference.
|
// Close the reference.
|
||||||
SCOPE_EXIT({ session_ptr->Close(); });
|
SCOPE_EXIT({ server_session->Close(); });
|
||||||
|
|
||||||
// If the session has been closed, we are done.
|
|
||||||
if (session_ptr->IsServerClosed()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Complete the service request.
|
// Complete the service request.
|
||||||
KScopedAutoObject server_session{&session_ptr->GetServerSession()};
|
|
||||||
server_session->CompleteSyncRequest(*context);
|
server_session->CompleteSyncRequest(*context);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user