From 6f368abe13bbf980b41b0209ddd5ca067761028a Mon Sep 17 00:00:00 2001 From: Yuri Kunde Schlesner Date: Tue, 6 Jun 2017 21:25:28 -0700 Subject: Service/sm: Convert 'srv:' to ServiceFramework --- src/core/hle/service/sm/sm.cpp | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) (limited to 'src/core/hle/service/sm/sm.cpp') diff --git a/src/core/hle/service/sm/sm.cpp b/src/core/hle/service/sm/sm.cpp index 361f7a0a9..5e7fc68f9 100644 --- a/src/core/hle/service/sm/sm.cpp +++ b/src/core/hle/service/sm/sm.cpp @@ -3,11 +3,13 @@ // Refer to the license.txt file included. #include +#include "common/assert.h" #include "core/hle/kernel/client_port.h" #include "core/hle/kernel/client_session.h" #include "core/hle/kernel/server_port.h" #include "core/hle/result.h" #include "core/hle/service/sm/sm.h" +#include "core/hle/service/sm/srv.h" namespace Service { namespace SM { @@ -22,6 +24,14 @@ static ResultCode ValidateServiceName(const std::string& name) { return RESULT_SUCCESS; } +void ServiceManager::InstallInterfaces(std::shared_ptr self) { + ASSERT(self->srv_interface.expired()); + + auto srv = std::make_shared(self); + srv->InstallAsNamedPort(); + self->srv_interface = srv; +} + ResultVal> ServiceManager::RegisterService( std::string name, unsigned int max_sessions) { @@ -30,7 +40,7 @@ ResultVal> ServiceManager::RegisterService Kernel::SharedPtr client_port; std::tie(server_port, client_port) = Kernel::ServerPort::CreatePortPair(max_sessions, name); - registered_services.emplace(name, std::move(client_port)); + registered_services.emplace(std::move(name), std::move(client_port)); return MakeResult>(std::move(server_port)); } @@ -53,7 +63,7 @@ ResultVal> ServiceManager::ConnectToSer return client_port->Connect(); } -std::unique_ptr g_service_manager; +std::shared_ptr g_service_manager; } // namespace SM } // namespace Service -- cgit v1.2.3