forked from eden-emu/eden
		
	acc_u0: Implement ListAllUsers.
This commit is contained in:
		
							parent
							
								
									db11c9a0b9
								
							
						
					
					
						commit
						dc0a137e5b
					
				
					 2 changed files with 15 additions and 2 deletions
				
			
		|  | @ -9,6 +9,9 @@ | ||||||
| namespace Service { | namespace Service { | ||||||
| namespace Account { | namespace Account { | ||||||
| 
 | 
 | ||||||
|  | using Uid = std::array<u64, 2>; | ||||||
|  | static constexpr Uid DEFAULT_USER_ID{0x10ull, 0x20ull}; | ||||||
|  | 
 | ||||||
| class IProfile final : public ServiceFramework<IProfile> { | class IProfile final : public ServiceFramework<IProfile> { | ||||||
| public: | public: | ||||||
|     IProfile() : ServiceFramework("IProfile") { |     IProfile() : ServiceFramework("IProfile") { | ||||||
|  | @ -61,6 +64,15 @@ void ACC_U0::GetUserExistence(Kernel::HLERequestContext& ctx) { | ||||||
|     rb.Push(true); // TODO: Check when this is supposed to return true and when not
 |     rb.Push(true); // TODO: Check when this is supposed to return true and when not
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void ACC_U0::ListAllUsers(Kernel::HLERequestContext& ctx) { | ||||||
|  |     constexpr std::array<u128, 10> user_ids{DEFAULT_USER_ID}; | ||||||
|  |     const auto& output_buffer = ctx.BufferDescriptorC()[0]; | ||||||
|  |     Memory::WriteBlock(output_buffer.Address(), user_ids.data(), user_ids.size()); | ||||||
|  |     IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|  |     rb.Push(RESULT_SUCCESS); | ||||||
|  |     LOG_DEBUG(Service_ACC, "called"); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void ACC_U0::GetProfile(Kernel::HLERequestContext& ctx) { | void ACC_U0::GetProfile(Kernel::HLERequestContext& ctx) { | ||||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; |     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|  | @ -85,13 +97,13 @@ void ACC_U0::GetLastOpenedUser(Kernel::HLERequestContext& ctx) { | ||||||
|     LOG_WARNING(Service_ACC, "(STUBBED) called"); |     LOG_WARNING(Service_ACC, "(STUBBED) called"); | ||||||
|     IPC::ResponseBuilder rb{ctx, 6}; |     IPC::ResponseBuilder rb{ctx, 6}; | ||||||
|     rb.Push(RESULT_SUCCESS); |     rb.Push(RESULT_SUCCESS); | ||||||
|     rb.Push<u64>(0x0); |     rb.PushRaw(DEFAULT_USER_ID); | ||||||
|     rb.Push<u64>(0x0); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ACC_U0::ACC_U0() : ServiceFramework("acc:u0") { | ACC_U0::ACC_U0() : ServiceFramework("acc:u0") { | ||||||
|     static const FunctionInfo functions[] = { |     static const FunctionInfo functions[] = { | ||||||
|         {1, &ACC_U0::GetUserExistence, "GetUserExistence"}, |         {1, &ACC_U0::GetUserExistence, "GetUserExistence"}, | ||||||
|  |         {2, &ACC_U0::ListAllUsers, "ListAllUsers"}, | ||||||
|         {4, &ACC_U0::GetLastOpenedUser, "GetLastOpenedUser"}, |         {4, &ACC_U0::GetLastOpenedUser, "GetLastOpenedUser"}, | ||||||
|         {5, &ACC_U0::GetProfile, "GetProfile"}, |         {5, &ACC_U0::GetProfile, "GetProfile"}, | ||||||
|         {100, &ACC_U0::InitializeApplicationInfo, "InitializeApplicationInfo"}, |         {100, &ACC_U0::InitializeApplicationInfo, "InitializeApplicationInfo"}, | ||||||
|  |  | ||||||
|  | @ -28,6 +28,7 @@ public: | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     void GetUserExistence(Kernel::HLERequestContext& ctx); |     void GetUserExistence(Kernel::HLERequestContext& ctx); | ||||||
|  |     void ListAllUsers(Kernel::HLERequestContext& ctx); | ||||||
|     void GetLastOpenedUser(Kernel::HLERequestContext& ctx); |     void GetLastOpenedUser(Kernel::HLERequestContext& ctx); | ||||||
|     void GetProfile(Kernel::HLERequestContext& ctx); |     void GetProfile(Kernel::HLERequestContext& ctx); | ||||||
|     void InitializeApplicationInfo(Kernel::HLERequestContext& ctx); |     void InitializeApplicationInfo(Kernel::HLERequestContext& ctx); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei