diff options
author | Subv <subv2112@gmail.com> | 2016-06-18 20:39:26 +0200 |
---|---|---|
committer | Subv <subv2112@gmail.com> | 2016-12-01 05:04:00 +0100 |
commit | c5e7e0fa26fc793c8b9f3effe25586f7fb57953e (patch) | |
tree | 2acac9450de6b1d8cc42d89f9aa08759d77f9cd9 /src/core/hle/service/service.cpp | |
parent | Kernel/HLE: Service::Interface no longer inherits from any Kernel object, and is now its own standalone class. (diff) | |
download | yuzu-c5e7e0fa26fc793c8b9f3effe25586f7fb57953e.tar yuzu-c5e7e0fa26fc793c8b9f3effe25586f7fb57953e.tar.gz yuzu-c5e7e0fa26fc793c8b9f3effe25586f7fb57953e.tar.bz2 yuzu-c5e7e0fa26fc793c8b9f3effe25586f7fb57953e.tar.lz yuzu-c5e7e0fa26fc793c8b9f3effe25586f7fb57953e.tar.xz yuzu-c5e7e0fa26fc793c8b9f3effe25586f7fb57953e.tar.zst yuzu-c5e7e0fa26fc793c8b9f3effe25586f7fb57953e.zip |
Diffstat (limited to 'src/core/hle/service/service.cpp')
-rw-r--r-- | src/core/hle/service/service.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/src/core/hle/service/service.cpp b/src/core/hle/service/service.cpp index abfc1806b..56e4f8734 100644 --- a/src/core/hle/service/service.cpp +++ b/src/core/hle/service/service.cpp @@ -61,7 +61,9 @@ static std::string MakeFunctionString(const char* name, const char* port_name, return function_string; } -ResultCode Interface::HandleSyncRequest() { +ResultCode Interface::HandleSyncRequest(Kernel::SharedPtr<Kernel::ServerSession> server_session) { + // TODO(Subv): Make use of the server_session in the HLE service handlers to distinguish which session triggered each command. + u32* cmd_buff = Kernel::GetCommandBuffer(); auto itr = m_functions.find(cmd_buff[0]); @@ -97,12 +99,12 @@ void Interface::Register(const FunctionInfo* functions, size_t n) { // Module interface static void AddNamedPort(Interface* interface_) { - auto client_port = Kernel::ClientPort::CreateForHLE(interface_->GetMaxSessions(), std::unique_ptr<Interface>(interface_)); + auto client_port = Kernel::ClientPort::CreateForHLE(interface_->GetMaxSessions(), std::shared_ptr<Interface>(interface_)); g_kernel_named_ports.emplace(interface_->GetPortName(), client_port); } void AddService(Interface* interface_) { - auto client_port = Kernel::ClientPort::CreateForHLE(interface_->GetMaxSessions(), std::unique_ptr<Interface>(interface_)); + auto client_port = Kernel::ClientPort::CreateForHLE(interface_->GetMaxSessions(), std::shared_ptr<Interface>(interface_)); g_srv_services.emplace(interface_->GetPortName(), client_port); } |