mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-25 03:46:43 +08:00 
			
		
		
		
	sm:: fix lingering session initialization issues
This commit is contained in:
		
							parent
							
								
									87749d217e
								
							
						
					
					
						commit
						72e5552409
					
				| @ -147,9 +147,21 @@ public: | |||||||
|         return server_manager; |         return server_manager; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     // TODO: remove this when sm: is implemented with the proper IUserInterface
 | ||||||
|  |     // abstraction, creating a new C++ handler object for each session:
 | ||||||
|  | 
 | ||||||
|  |     bool GetIsInitializedForSm() const { | ||||||
|  |         return is_initialized_for_sm; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     void SetIsInitializedForSm() { | ||||||
|  |         is_initialized_for_sm = true; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| private: | private: | ||||||
|     bool convert_to_domain{}; |     bool convert_to_domain{}; | ||||||
|     bool is_domain{}; |     bool is_domain{}; | ||||||
|  |     bool is_initialized_for_sm{}; | ||||||
|     SessionRequestHandlerPtr session_handler; |     SessionRequestHandlerPtr session_handler; | ||||||
|     std::vector<SessionRequestHandlerPtr> domain_handlers; |     std::vector<SessionRequestHandlerPtr> domain_handlers; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -112,7 +112,7 @@ ResultVal<Kernel::KPort*> ServiceManager::GetServicePort(const std::string& name | |||||||
| void SM::Initialize(Kernel::HLERequestContext& ctx) { | void SM::Initialize(Kernel::HLERequestContext& ctx) { | ||||||
|     LOG_DEBUG(Service_SM, "called"); |     LOG_DEBUG(Service_SM, "called"); | ||||||
| 
 | 
 | ||||||
|     is_initialized = true; |     ctx.GetManager()->SetIsInitializedForSm(); | ||||||
| 
 | 
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2}; |     IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|     rb.Push(ResultSuccess); |     rb.Push(ResultSuccess); | ||||||
| @ -159,7 +159,7 @@ static std::string PopServiceName(IPC::RequestParser& rp) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ResultVal<Kernel::KClientSession*> SM::GetServiceImpl(Kernel::HLERequestContext& ctx) { | ResultVal<Kernel::KClientSession*> SM::GetServiceImpl(Kernel::HLERequestContext& ctx) { | ||||||
|     if (!is_initialized) { |     if (!ctx.GetManager()->GetIsInitializedForSm()) { | ||||||
|         return ERR_NOT_INITIALIZED; |         return ERR_NOT_INITIALIZED; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -168,6 +168,11 @@ ResultVal<Kernel::KClientSession*> SM::GetServiceImpl(Kernel::HLERequestContext& | |||||||
| 
 | 
 | ||||||
|     // Find the named port.
 |     // Find the named port.
 | ||||||
|     auto port_result = service_manager.GetServicePort(name); |     auto port_result = service_manager.GetServicePort(name); | ||||||
|  |     if (port_result.Code() == ERR_INVALID_NAME) { | ||||||
|  |         LOG_ERROR(Service_SM, "Invalid service name '{}'", name); | ||||||
|  |         return ERR_INVALID_NAME; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     if (port_result.Failed()) { |     if (port_result.Failed()) { | ||||||
|         LOG_INFO(Service_SM, "Waiting for service {} to become available", name); |         LOG_INFO(Service_SM, "Waiting for service {} to become available", name); | ||||||
|         ctx.SetIsDeferred(); |         ctx.SetIsDeferred(); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user