| 
									
										
										
										
											2018-01-13 16:22:39 -05:00
										 |  |  | // Copyright 2018 yuzu emulator team
 | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/logging/log.h"
 | 
					
						
							|  |  |  | #include "core/hle/ipc_helpers.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-03 12:09:33 -05:00
										 |  |  | #include "core/hle/kernel/session.h"
 | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  | #include "core/hle/service/sm/controller.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-19 21:41:44 -04:00
										 |  |  | namespace Service::SM { | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-15 01:24:22 -04:00
										 |  |  | void Controller::ConvertSessionToDomain(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-01-23 18:03:09 -05:00
										 |  |  |     ASSERT_MSG(!ctx.Session()->IsDomain(), "session is alread a domain"); | 
					
						
							|  |  |  |     ctx.Session()->ConvertToDomain(); | 
					
						
							| 
									
										
										
										
											2017-12-29 00:36:22 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-23 19:52:18 -05:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							| 
									
										
										
										
											2017-10-15 01:24:22 -04:00
										 |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-01-23 18:03:09 -05:00
										 |  |  |     rb.Push<u32>(1); // Converted sessions start with 1 request handler
 | 
					
						
							| 
									
										
										
										
											2017-12-29 00:36:22 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-23 18:03:09 -05:00
										 |  |  |     LOG_DEBUG(Service, "called, server_session=%d", ctx.Session()->GetObjectId()); | 
					
						
							| 
									
										
										
										
											2017-10-15 01:24:22 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-29 00:39:34 -05:00
										 |  |  | void Controller::DuplicateSession(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-02-03 12:09:33 -05:00
										 |  |  |     // 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.
 | 
					
						
							| 
									
										
										
										
											2018-01-23 22:33:30 -05:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 2, 0, 1, IPC::ResponseBuilder::Flags::AlwaysMoveHandles}; | 
					
						
							| 
									
										
										
										
											2017-12-29 00:39:34 -05:00
										 |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2018-02-03 12:09:33 -05:00
										 |  |  |     Kernel::SharedPtr<Kernel::ClientSession> session{ctx.Session()->parent->client}; | 
					
						
							|  |  |  |     rb.PushMoveObjects(session); | 
					
						
							| 
									
										
										
										
											2017-12-29 00:39:34 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-03 12:09:33 -05:00
										 |  |  |     LOG_DEBUG(Service, "called, session=%u", session->GetObjectId()); | 
					
						
							| 
									
										
										
										
											2017-12-29 00:39:34 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-17 14:41:43 -05:00
										 |  |  | void Controller::DuplicateSessionEx(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |     LOG_WARNING(Service, "(STUBBED) called, using DuplicateSession"); | 
					
						
							| 
									
										
										
										
											2018-02-03 12:09:33 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     DuplicateSession(ctx); | 
					
						
							| 
									
										
										
										
											2018-01-17 14:41:43 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  | void Controller::QueryPointerBufferSize(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2018-01-23 19:52:18 -05:00
										 |  |  |     IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  |     rb.Push(RESULT_SUCCESS); | 
					
						
							| 
									
										
										
										
											2017-10-15 01:24:22 -04:00
										 |  |  |     rb.Push<u32>(0x500); | 
					
						
							| 
									
										
										
										
											2017-12-29 00:39:34 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  |     LOG_WARNING(Service, "(STUBBED) called"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Controller::Controller() : ServiceFramework("IpcController") { | 
					
						
							|  |  |  |     static const FunctionInfo functions[] = { | 
					
						
							| 
									
										
										
										
											2017-10-15 01:24:22 -04:00
										 |  |  |         {0x00000000, &Controller::ConvertSessionToDomain, "ConvertSessionToDomain"}, | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  |         {0x00000001, nullptr, "ConvertDomainToSession"}, | 
					
						
							| 
									
										
										
										
											2017-12-29 00:39:34 -05:00
										 |  |  |         {0x00000002, &Controller::DuplicateSession, "DuplicateSession"}, | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  |         {0x00000003, &Controller::QueryPointerBufferSize, "QueryPointerBufferSize"}, | 
					
						
							| 
									
										
										
										
											2018-01-17 14:41:43 -05:00
										 |  |  |         {0x00000004, &Controller::DuplicateSessionEx, "DuplicateSessionEx"}, | 
					
						
							| 
									
										
										
										
											2017-10-14 22:18:42 -04:00
										 |  |  |     }; | 
					
						
							|  |  |  |     RegisterHandlers(functions); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-19 21:41:44 -04:00
										 |  |  | } // namespace Service::SM
 |