diff options
| author | liamwhite <liamwhite@users.noreply.github.com> | 2024-01-25 15:40:09 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-01-25 15:40:09 -0500 |
| commit | eb9036d75beb1455a564d90217dfb10d927d6ed3 (patch) | |
| tree | 23a91696df5b019c7c759eaa7516c8b5b5c63450 /src/core/hle/service/hle_ipc.cpp | |
| parent | 6e67b25af902868d1eb6abba6d1c991816a515f7 (diff) | |
| parent | 01a2d978ebc24aa517048f941f53213db9de722e (diff) | |
Merge pull request #12783 from liamwhite/cmif-generation
service: add template serializer for method calls
Diffstat (limited to 'src/core/hle/service/hle_ipc.cpp')
| -rw-r--r-- | src/core/hle/service/hle_ipc.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/src/core/hle/service/hle_ipc.cpp b/src/core/hle/service/hle_ipc.cpp index e491dd260..50e1ed756 100644 --- a/src/core/hle/service/hle_ipc.cpp +++ b/src/core/hle/service/hle_ipc.cpp @@ -501,6 +501,22 @@ bool HLERequestContext::CanWriteBuffer(std::size_t buffer_index) const { } } +void HLERequestContext::AddMoveInterface(SessionRequestHandlerPtr s) { + ASSERT(Kernel::GetCurrentProcess(kernel).GetResourceLimit()->Reserve( + Kernel::LimitableResource::SessionCountMax, 1)); + + auto* session = Kernel::KSession::Create(kernel); + session->Initialize(nullptr, 0); + Kernel::KSession::Register(kernel, session); + + auto& server = manager.lock()->GetServerManager(); + auto next_manager = std::make_shared<Service::SessionRequestManager>(kernel, server); + next_manager->SetSessionHandler(std::move(s)); + server.RegisterSession(&session->GetServerSession(), next_manager); + + AddMoveObject(&session->GetClientSession()); +} + std::string HLERequestContext::Description() const { if (!command_header) { return "No command header available"; |
