mirror of
				https://git.eden-emu.dev/eden-emu/eden.git
				synced 2025-10-26 07:53:19 +00:00 
			
		
		
		
	hle: kernel: KSession: Improve implementation of CloneCurrentObject.
This commit is contained in:
		
							parent
							
								
									1e211a1b15
								
							
						
					
					
						commit
						14e52144e2
					
				
					 1 changed files with 10 additions and 2 deletions
				
			
		|  | @ -26,15 +26,23 @@ void Controller::CloneCurrentObject(Kernel::HLERequestContext& ctx) { | |||
|     // TODO(bunnei): This is just creating a new handle to the same Session. I assume this is wrong
 | ||||
|     // and that we probably want to actually make an entirely new Session, but we still need to
 | ||||
|     // verify this on hardware.
 | ||||
| 
 | ||||
|     LOG_DEBUG(Service, "called"); | ||||
| 
 | ||||
|     auto session = ctx.Session()->GetParent(); | ||||
| 
 | ||||
|     // Open a reference to the session to simulate a new one being created.
 | ||||
|     session->Open(); | ||||
|     session->GetClientSession().Open(); | ||||
|     session->GetServerSession().Open(); | ||||
| 
 | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1, IPC::ResponseBuilder::Flags::AlwaysMoveHandles}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushMoveObjects(ctx.Session()->GetParent()->GetClientSession()); | ||||
|     rb.PushMoveObjects(session->GetClientSession()); | ||||
| } | ||||
| 
 | ||||
| void Controller::CloneCurrentObjectEx(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_WARNING(Service, "(STUBBED) called, using CloneCurrentObject"); | ||||
|     LOG_DEBUG(Service, "called"); | ||||
| 
 | ||||
|     CloneCurrentObject(ctx); | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei