mirror of
				https://github.com/PabloMK7/citra.git
				synced 2025-10-31 13:50:03 +00:00 
			
		
		
		
	Service/FS_User: Stub Secure Value Functions
Stubbing these functions results in save loading fixes in games which require a secure value. An example is shown here with Animal Crossing: New Leaf: [Before](https://puu.sh/zidZC/f1523e81cb.png) [After](https://puu.sh/zifeT/57026eae44.png)
This commit is contained in:
		
							parent
							
								
									587450cd04
								
							
						
					
					
						commit
						71c7dddac4
					
				
					 1 changed files with 56 additions and 2 deletions
				
			
		|  | @ -990,6 +990,60 @@ static void GetNumSeeds(Service::Interface* self) { | ||||||
|     rb.Push<u32>(0); |     rb.Push<u32>(0); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  * FS_User::SetSaveDataSecureValue service function. | ||||||
|  |  *  Inputs: | ||||||
|  |  *      0 : 0x08650140 | ||||||
|  |  *      1-2 : Secure Value | ||||||
|  |  *      3 : Secure Value Slot | ||||||
|  |  *      4 : Title Id | ||||||
|  |  *      5 : Title Variation | ||||||
|  |  *  Outputs: | ||||||
|  |  *      0 : 0x08650140 | ||||||
|  |  *      1 : Result of function, 0 on success, otherwise error code | ||||||
|  |  */ | ||||||
|  | static void SetSaveDataSecureValue(Service::Interface* self) { | ||||||
|  |     IPC::RequestParser rp(Kernel::GetCommandBuffer(), 0x865, 5, 0); | ||||||
|  | 
 | ||||||
|  |     // TODO: Generate and Save the Secure Value
 | ||||||
|  | 
 | ||||||
|  |     LOG_WARNING(Service_FS, "(STUBBED) called"); | ||||||
|  | 
 | ||||||
|  |     IPC::RequestBuilder rb = rp.MakeBuilder(1, 0); | ||||||
|  | 
 | ||||||
|  |     rb.Push(RESULT_SUCCESS); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * FS_User::GetSaveDataSecureValue service function. | ||||||
|  |  *  Inputs: | ||||||
|  |  *      0 : 0x086600C0 | ||||||
|  |  *      1 : Secure Value Slot | ||||||
|  |  *      2 : Title Id | ||||||
|  |  *      3 : Title Variation | ||||||
|  |  *  Outputs: | ||||||
|  |  *      0 : 0x086600C0 | ||||||
|  |  *      1 : Result of function, 0 on success, otherwise error code | ||||||
|  |  *      2 : If Secure Value doesn't exist, 0, if it exists, 1 | ||||||
|  |  *      3-4 : Secure Value | ||||||
|  |  */ | ||||||
|  | static void GetSaveDataSecureValue(Service::Interface* self) { | ||||||
|  |     IPC::RequestParser rp(Kernel::GetCommandBuffer(), 0x866, 3, 0); | ||||||
|  | 
 | ||||||
|  |     u32 secure_value_slot = rp.Pop<u32>(); | ||||||
|  | 
 | ||||||
|  |     LOG_WARNING(Service_FS, "(STUBBED) called Secure Value Slot=%08X", secure_value_slot); | ||||||
|  | 
 | ||||||
|  |     IPC::RequestBuilder rb = rp.MakeBuilder(4, 0); | ||||||
|  | 
 | ||||||
|  |     rb.Push(RESULT_SUCCESS); | ||||||
|  | 
 | ||||||
|  |     // TODO: Implement Secure Value Lookup & Generation
 | ||||||
|  | 
 | ||||||
|  |     rb.Push<u8>(0); | ||||||
|  |     rb.Push<u64>(0); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| const Interface::FunctionInfo FunctionTable[] = { | const Interface::FunctionInfo FunctionTable[] = { | ||||||
|     {0x000100C6, nullptr, "Dummy1"}, |     {0x000100C6, nullptr, "Dummy1"}, | ||||||
|     {0x040100C4, nullptr, "Control"}, |     {0x040100C4, nullptr, "Control"}, | ||||||
|  | @ -1093,8 +1147,8 @@ const Interface::FunctionInfo FunctionTable[] = { | ||||||
|     {0x08620040, SetPriority, "SetPriority"}, |     {0x08620040, SetPriority, "SetPriority"}, | ||||||
|     {0x08630000, GetPriority, "GetPriority"}, |     {0x08630000, GetPriority, "GetPriority"}, | ||||||
|     {0x08640000, nullptr, "GetNandInfo"}, |     {0x08640000, nullptr, "GetNandInfo"}, | ||||||
|     {0x08650140, nullptr, "SetSaveDataSecureValue"}, |     {0x08650140, SetSaveDataSecureValue, "SetSaveDataSecureValue"}, | ||||||
|     {0x086600C0, nullptr, "GetSaveDataSecureValue"}, |     {0x086600C0, GetSaveDataSecureValue, "GetSaveDataSecureValue"}, | ||||||
|     {0x086700C4, nullptr, "ControlSecureSave"}, |     {0x086700C4, nullptr, "ControlSecureSave"}, | ||||||
|     {0x08680000, nullptr, "GetMediaType"}, |     {0x08680000, nullptr, "GetMediaType"}, | ||||||
|     {0x08690000, nullptr, "GetNandEraseCount"}, |     {0x08690000, nullptr, "GetNandEraseCount"}, | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue