mirror of
				https://git.eden-emu.dev/eden-emu/eden.git
				synced 2025-10-26 02:03:27 +00:00 
			
		
		
		
	service: Update function tables
This commit is contained in:
		
							parent
							
								
									51b91cc0d9
								
							
						
					
					
						commit
						9338a6a1cf
					
				
					 27 changed files with 285 additions and 157 deletions
				
			
		|  | @ -12,7 +12,7 @@ | |||
| 
 | ||||
| namespace Service::SM { | ||||
| 
 | ||||
| void Controller::ConvertSessionToDomain(Kernel::HLERequestContext& ctx) { | ||||
| void Controller::ConvertCurrentObjectToDomain(Kernel::HLERequestContext& ctx) { | ||||
|     ASSERT_MSG(ctx.Session()->IsSession(), "Session is already a domain"); | ||||
|     LOG_DEBUG(Service, "called, server_session={}", ctx.Session()->GetObjectId()); | ||||
|     ctx.Session()->ConvertToDomain(); | ||||
|  | @ -22,7 +22,7 @@ void Controller::ConvertSessionToDomain(Kernel::HLERequestContext& ctx) { | |||
|     rb.Push<u32>(1); // Converted sessions start with 1 request handler
 | ||||
| } | ||||
| 
 | ||||
| void Controller::DuplicateSession(Kernel::HLERequestContext& ctx) { | ||||
| 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.
 | ||||
|  | @ -33,10 +33,10 @@ void Controller::DuplicateSession(Kernel::HLERequestContext& ctx) { | |||
|     rb.PushMoveObjects(ctx.Session()->GetParent()->Client()); | ||||
| } | ||||
| 
 | ||||
| void Controller::DuplicateSessionEx(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_WARNING(Service, "(STUBBED) called, using DuplicateSession"); | ||||
| void Controller::CloneCurrentObjectEx(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_WARNING(Service, "(STUBBED) called, using CloneCurrentObject"); | ||||
| 
 | ||||
|     DuplicateSession(ctx); | ||||
|     CloneCurrentObject(ctx); | ||||
| } | ||||
| 
 | ||||
| void Controller::QueryPointerBufferSize(Kernel::HLERequestContext& ctx) { | ||||
|  | @ -47,13 +47,14 @@ void Controller::QueryPointerBufferSize(Kernel::HLERequestContext& ctx) { | |||
|     rb.Push<u16>(0x1000); | ||||
| } | ||||
| 
 | ||||
| // https://switchbrew.org/wiki/IPC_Marshalling
 | ||||
| Controller::Controller() : ServiceFramework("IpcController") { | ||||
|     static const FunctionInfo functions[] = { | ||||
|         {0x00000000, &Controller::ConvertSessionToDomain, "ConvertSessionToDomain"}, | ||||
|         {0x00000001, nullptr, "ConvertDomainToSession"}, | ||||
|         {0x00000002, &Controller::DuplicateSession, "DuplicateSession"}, | ||||
|         {0x00000000, &Controller::ConvertCurrentObjectToDomain, "ConvertCurrentObjectToDomain"}, | ||||
|         {0x00000001, nullptr, "CopyFromCurrentDomain"}, | ||||
|         {0x00000002, &Controller::CloneCurrentObject, "CloneCurrentObject"}, | ||||
|         {0x00000003, &Controller::QueryPointerBufferSize, "QueryPointerBufferSize"}, | ||||
|         {0x00000004, &Controller::DuplicateSessionEx, "DuplicateSessionEx"}, | ||||
|         {0x00000004, &Controller::CloneCurrentObjectEx, "CloneCurrentObjectEx"}, | ||||
|     }; | ||||
|     RegisterHandlers(functions); | ||||
| } | ||||
|  |  | |||
|  | @ -14,9 +14,9 @@ public: | |||
|     ~Controller() override; | ||||
| 
 | ||||
| private: | ||||
|     void ConvertSessionToDomain(Kernel::HLERequestContext& ctx); | ||||
|     void DuplicateSession(Kernel::HLERequestContext& ctx); | ||||
|     void DuplicateSessionEx(Kernel::HLERequestContext& ctx); | ||||
|     void ConvertCurrentObjectToDomain(Kernel::HLERequestContext& ctx); | ||||
|     void CloneCurrentObject(Kernel::HLERequestContext& ctx); | ||||
|     void CloneCurrentObjectEx(Kernel::HLERequestContext& ctx); | ||||
|     void QueryPointerBufferSize(Kernel::HLERequestContext& ctx); | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 VolcaEM
						VolcaEM