mirror of
https://github.com/Lime3DS/Lime3DS
synced 2025-01-09 13:43:27 +00:00
06a2e0b591
The error code 0xC920181A will be returned by svcReplyAndReceive when the wakeup callback runs. This lets LLE services be properly notified of clients closing the connection so they can end their handler threads instead of letting them linger indefinitely, taking up connection slots in their parent port.
55 lines
2 KiB
C++
55 lines
2 KiB
C++
// Copyright 2016 Citra Emulator Project
|
|
// Licensed under GPLv2 or any later version
|
|
// Refer to the license.txt file included.
|
|
|
|
#include "common/assert.h"
|
|
|
|
#include "core/hle/kernel/client_session.h"
|
|
#include "core/hle/kernel/errors.h"
|
|
#include "core/hle/kernel/hle_ipc.h"
|
|
#include "core/hle/kernel/server_session.h"
|
|
#include "core/hle/kernel/session.h"
|
|
#include "core/hle/kernel/thread.h"
|
|
|
|
namespace Kernel {
|
|
|
|
ClientSession::ClientSession() = default;
|
|
ClientSession::~ClientSession() {
|
|
// This destructor will be called automatically when the last ClientSession handle is closed by
|
|
// the emulated application.
|
|
|
|
// Local references to ServerSession and SessionRequestHandler are necessary to guarantee they
|
|
// will be kept alive until after ClientDisconnected() returns.
|
|
SharedPtr<ServerSession> server = parent->server;
|
|
if (server) {
|
|
std::shared_ptr<SessionRequestHandler> hle_handler = server->hle_handler;
|
|
if (hle_handler)
|
|
hle_handler->ClientDisconnected(server);
|
|
|
|
// Clean up the list of client threads with pending requests, they are unneeded now that the
|
|
// client endpoint is closed.
|
|
server->pending_requesting_threads.clear();
|
|
server->currently_handling = nullptr;
|
|
}
|
|
|
|
parent->client = nullptr;
|
|
|
|
if (server) {
|
|
// Notify any threads waiting on the ServerSession that the endpoint has been closed. Note
|
|
// that this call has to happen after `Session::client` has been set to nullptr to let the
|
|
// ServerSession know that the client endpoint has been closed.
|
|
server->WakeupAllWaitingThreads();
|
|
}
|
|
}
|
|
|
|
ResultCode ClientSession::SendSyncRequest(SharedPtr<Thread> thread) {
|
|
// Keep ServerSession alive until we're done working with it.
|
|
SharedPtr<ServerSession> server = parent->server;
|
|
if (server == nullptr)
|
|
return ERR_SESSION_CLOSED_BY_REMOTE;
|
|
|
|
// Signal the server session that new data is available
|
|
return server->HandleSyncRequest(std::move(thread));
|
|
}
|
|
|
|
} // namespace
|