mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu.git
				synced 2025-05-12 00:45:25 +00:00 
			
		
		
		
	Merge pull request #157 from bunnei/fix-duplicate-session
controller: DuplicateSession should return a ClientSession.
This commit is contained in:
		
						commit
						abc4be8e0f
					
				| @ -4,6 +4,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "common/logging/log.h" | #include "common/logging/log.h" | ||||||
| #include "core/hle/ipc_helpers.h" | #include "core/hle/ipc_helpers.h" | ||||||
|  | #include "core/hle/kernel/session.h" | ||||||
| #include "core/hle/service/sm/controller.h" | #include "core/hle/service/sm/controller.h" | ||||||
| 
 | 
 | ||||||
| namespace Service { | namespace Service { | ||||||
| @ -21,17 +22,21 @@ void Controller::ConvertSessionToDomain(Kernel::HLERequestContext& ctx) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Controller::DuplicateSession(Kernel::HLERequestContext& ctx) { | void Controller::DuplicateSession(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.
 | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1, IPC::ResponseBuilder::Flags::AlwaysMoveHandles}; |     IPC::ResponseBuilder rb{ctx, 2, 0, 1, IPC::ResponseBuilder::Flags::AlwaysMoveHandles}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.PushMoveObjects(ctx.Session()); |     Kernel::SharedPtr<Kernel::ClientSession> session{ctx.Session()->parent->client}; | ||||||
|  |     rb.PushMoveObjects(session); | ||||||
| 
 | 
 | ||||||
|     LOG_DEBUG(Service, "called"); |     LOG_DEBUG(Service, "called, session=%u", session->GetObjectId()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Controller::DuplicateSessionEx(Kernel::HLERequestContext& ctx) { | void Controller::DuplicateSessionEx(Kernel::HLERequestContext& ctx) { | ||||||
|     DuplicateSession(ctx); |  | ||||||
| 
 |  | ||||||
|     LOG_WARNING(Service, "(STUBBED) called, using DuplicateSession"); |     LOG_WARNING(Service, "(STUBBED) called, using DuplicateSession"); | ||||||
|  | 
 | ||||||
|  |     DuplicateSession(ctx); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Controller::QueryPointerBufferSize(Kernel::HLERequestContext& ctx) { | void Controller::QueryPointerBufferSize(Kernel::HLERequestContext& ctx) { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 bunnei
						bunnei