summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/k_client_session.cpp
diff options
context:
space:
mode:
authorLiam <byteslice@airmail.cc>2023-12-06 23:29:32 +0100
committerLiam <byteslice@airmail.cc>2023-12-06 23:33:00 +0100
commit40bb176c396b7af6ca50d2e26561cbb20d2e40d1 (patch)
tree2c2ed0803aee8dedecc5eaa7d1d56490b93d4665 /src/core/hle/kernel/k_client_session.cpp
parentMerge pull request #12236 from liamwhite/cpu-refactor (diff)
downloadyuzu-40bb176c396b7af6ca50d2e26561cbb20d2e40d1.tar
yuzu-40bb176c396b7af6ca50d2e26561cbb20d2e40d1.tar.gz
yuzu-40bb176c396b7af6ca50d2e26561cbb20d2e40d1.tar.bz2
yuzu-40bb176c396b7af6ca50d2e26561cbb20d2e40d1.tar.lz
yuzu-40bb176c396b7af6ca50d2e26561cbb20d2e40d1.tar.xz
yuzu-40bb176c396b7af6ca50d2e26561cbb20d2e40d1.tar.zst
yuzu-40bb176c396b7af6ca50d2e26561cbb20d2e40d1.zip
Diffstat (limited to '')
-rw-r--r--src/core/hle/kernel/k_client_session.cpp24
1 files changed, 17 insertions, 7 deletions
diff --git a/src/core/hle/kernel/k_client_session.cpp b/src/core/hle/kernel/k_client_session.cpp
index 72b66270d..472e8571c 100644
--- a/src/core/hle/kernel/k_client_session.cpp
+++ b/src/core/hle/kernel/k_client_session.cpp
@@ -10,9 +10,7 @@
namespace Kernel {
-static constexpr u32 MessageBufferSize = 0x100;
-
-KClientSession::KClientSession(KernelCore& kernel) : KAutoObjectWithSlabHeapAndContainer{kernel} {}
+KClientSession::KClientSession(KernelCore& kernel) : KAutoObject{kernel} {}
KClientSession::~KClientSession() = default;
void KClientSession::Destroy() {
@@ -22,18 +20,30 @@ void KClientSession::Destroy() {
void KClientSession::OnServerClosed() {}
-Result KClientSession::SendSyncRequest() {
+Result KClientSession::SendSyncRequest(uintptr_t address, size_t size) {
+ // Create a session request.
+ KSessionRequest* request = KSessionRequest::Create(m_kernel);
+ R_UNLESS(request != nullptr, ResultOutOfResource);
+ SCOPE_EXIT({ request->Close(); });
+
+ // Initialize the request.
+ request->Initialize(nullptr, address, size);
+
+ // Send the request.
+ R_RETURN(m_parent->OnRequest(request));
+}
+
+Result KClientSession::SendAsyncRequest(KEvent* event, uintptr_t address, size_t size) {
// Create a session request.
KSessionRequest* request = KSessionRequest::Create(m_kernel);
R_UNLESS(request != nullptr, ResultOutOfResource);
SCOPE_EXIT({ request->Close(); });
// Initialize the request.
- request->Initialize(nullptr, GetInteger(GetCurrentThread(m_kernel).GetTlsAddress()),
- MessageBufferSize);
+ request->Initialize(event, address, size);
// Send the request.
- R_RETURN(m_parent->GetServerSession().OnRequest(request));
+ R_RETURN(m_parent->OnRequest(request));
}
} // namespace Kernel