service/sm: Eliminate dependency on the global system instance
This commit is contained in:
		
							parent
							
								
									fcd0925ecf
								
							
						
					
					
						commit
						78b1bc3b61
					
				@ -178,7 +178,7 @@ struct System::Impl {
 | 
			
		||||
        arp_manager.ResetAll();
 | 
			
		||||
 | 
			
		||||
        telemetry_session = std::make_unique<Core::TelemetrySession>();
 | 
			
		||||
        service_manager = std::make_shared<Service::SM::ServiceManager>();
 | 
			
		||||
        service_manager = std::make_shared<Service::SM::ServiceManager>(kernel);
 | 
			
		||||
 | 
			
		||||
        Service::Init(service_manager, system);
 | 
			
		||||
        GDBStub::DeferStart();
 | 
			
		||||
 | 
			
		||||
@ -19,7 +19,7 @@ constexpr ResultCode ERR_ALREADY_REGISTERED(ErrorModule::SM, 4);
 | 
			
		||||
constexpr ResultCode ERR_INVALID_NAME(ErrorModule::SM, 6);
 | 
			
		||||
constexpr ResultCode ERR_SERVICE_NOT_REGISTERED(ErrorModule::SM, 7);
 | 
			
		||||
 | 
			
		||||
ServiceManager::ServiceManager() = default;
 | 
			
		||||
ServiceManager::ServiceManager(Kernel::KernelCore& kernel_) : kernel{kernel_} {}
 | 
			
		||||
ServiceManager::~ServiceManager() = default;
 | 
			
		||||
 | 
			
		||||
void ServiceManager::InvokeControlRequest(Kernel::HLERequestContext& context) {
 | 
			
		||||
@ -48,8 +48,8 @@ void ServiceManager::InstallInterfaces(std::shared_ptr<ServiceManager> self,
 | 
			
		||||
    self->controller_interface = std::make_unique<Controller>();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
ResultVal<std::shared_ptr<Kernel::ServerPort>> ServiceManager::RegisterService(
 | 
			
		||||
    std::string name, unsigned int max_sessions) {
 | 
			
		||||
ResultVal<std::shared_ptr<Kernel::ServerPort>> ServiceManager::RegisterService(std::string name,
 | 
			
		||||
                                                                               u32 max_sessions) {
 | 
			
		||||
 | 
			
		||||
    CASCADE_CODE(ValidateServiceName(name));
 | 
			
		||||
 | 
			
		||||
@ -58,7 +58,6 @@ ResultVal<std::shared_ptr<Kernel::ServerPort>> ServiceManager::RegisterService(
 | 
			
		||||
        return ERR_ALREADY_REGISTERED;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    auto& kernel = Core::System::GetInstance().Kernel();
 | 
			
		||||
    auto [server_port, client_port] =
 | 
			
		||||
        Kernel::ServerPort::CreatePortPair(kernel, max_sessions, name);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -48,11 +48,11 @@ class ServiceManager {
 | 
			
		||||
public:
 | 
			
		||||
    static void InstallInterfaces(std::shared_ptr<ServiceManager> self, Kernel::KernelCore& kernel);
 | 
			
		||||
 | 
			
		||||
    ServiceManager();
 | 
			
		||||
    explicit ServiceManager(Kernel::KernelCore& kernel_);
 | 
			
		||||
    ~ServiceManager();
 | 
			
		||||
 | 
			
		||||
    ResultVal<std::shared_ptr<Kernel::ServerPort>> RegisterService(std::string name,
 | 
			
		||||
                                                                   unsigned int max_sessions);
 | 
			
		||||
                                                                   u32 max_sessions);
 | 
			
		||||
    ResultCode UnregisterService(const std::string& name);
 | 
			
		||||
    ResultVal<std::shared_ptr<Kernel::ClientPort>> GetServicePort(const std::string& name);
 | 
			
		||||
    ResultVal<std::shared_ptr<Kernel::ClientSession>> ConnectToService(const std::string& name);
 | 
			
		||||
@ -79,6 +79,9 @@ private:
 | 
			
		||||
 | 
			
		||||
    /// Map of registered services, retrieved using GetServicePort or ConnectToService.
 | 
			
		||||
    std::unordered_map<std::string, std::shared_ptr<Kernel::ClientPort>> registered_services;
 | 
			
		||||
 | 
			
		||||
    /// Kernel context
 | 
			
		||||
    Kernel::KernelCore& kernel;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
} // namespace Service::SM
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user