mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-27 04:46:48 +08:00 
			
		
		
		
	service: time: Implement CalculateStandardUserSystemClockDifferenceByUser.
- Used by Animal Crossing: New Horizons.
This commit is contained in:
		
							parent
							
								
									7e4a132a77
								
							
						
					
					
						commit
						eb676c343a
					
				| @ -29,7 +29,7 @@ Time::Time(std::shared_ptr<Module> module, Core::System& system, const char* nam | |||||||
|         {300, &Time::CalculateMonotonicSystemClockBaseTimePoint, "CalculateMonotonicSystemClockBaseTimePoint"}, |         {300, &Time::CalculateMonotonicSystemClockBaseTimePoint, "CalculateMonotonicSystemClockBaseTimePoint"}, | ||||||
|         {400, &Time::GetClockSnapshot, "GetClockSnapshot"}, |         {400, &Time::GetClockSnapshot, "GetClockSnapshot"}, | ||||||
|         {401, &Time::GetClockSnapshotFromSystemClockContext, "GetClockSnapshotFromSystemClockContext"}, |         {401, &Time::GetClockSnapshotFromSystemClockContext, "GetClockSnapshotFromSystemClockContext"}, | ||||||
|         {500, nullptr, "CalculateStandardUserSystemClockDifferenceByUser"}, |         {500, &Time::CalculateStandardUserSystemClockDifferenceByUser, "CalculateStandardUserSystemClockDifferenceByUser"}, | ||||||
|         {501, &Time::CalculateSpanBetween, "CalculateSpanBetween"}, |         {501, &Time::CalculateSpanBetween, "CalculateSpanBetween"}, | ||||||
|     }; |     }; | ||||||
|     // clang-format on
 |     // clang-format on
 | ||||||
|  | |||||||
| @ -308,6 +308,29 @@ void Module::Interface::GetClockSnapshotFromSystemClockContext(Kernel::HLEReques | |||||||
|     ctx.WriteBuffer(&clock_snapshot, sizeof(Clock::ClockSnapshot)); |     ctx.WriteBuffer(&clock_snapshot, sizeof(Clock::ClockSnapshot)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void Module::Interface::CalculateStandardUserSystemClockDifferenceByUser( | ||||||
|  |     Kernel::HLERequestContext& ctx) { | ||||||
|  |     LOG_DEBUG(Service_Time, "called"); | ||||||
|  | 
 | ||||||
|  |     IPC::RequestParser rp{ctx}; | ||||||
|  |     const auto snapshot_a = rp.PopRaw<Clock::ClockSnapshot>(); | ||||||
|  |     const auto snapshot_b = rp.PopRaw<Clock::ClockSnapshot>(); | ||||||
|  | 
 | ||||||
|  |     auto time_span_type{Clock::TimeSpanType::FromSeconds(snapshot_b.user_context.offset - | ||||||
|  |                                                          snapshot_a.user_context.offset)}; | ||||||
|  | 
 | ||||||
|  |     if ((snapshot_b.user_context.steady_time_point.clock_source_id != | ||||||
|  |          snapshot_a.user_context.steady_time_point.clock_source_id) || | ||||||
|  |         (snapshot_b.is_automatic_correction_enabled && | ||||||
|  |          snapshot_a.is_automatic_correction_enabled)) { | ||||||
|  |         time_span_type.nanoseconds = 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     IPC::ResponseBuilder rb{ctx, (sizeof(s64) / 4) + 2}; | ||||||
|  |     rb.Push(RESULT_SUCCESS); | ||||||
|  |     rb.PushRaw(time_span_type.nanoseconds); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void Module::Interface::CalculateSpanBetween(Kernel::HLERequestContext& ctx) { | void Module::Interface::CalculateSpanBetween(Kernel::HLERequestContext& ctx) { | ||||||
|     LOG_DEBUG(Service_Time, "called"); |     LOG_DEBUG(Service_Time, "called"); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -32,6 +32,7 @@ public: | |||||||
|         void CalculateMonotonicSystemClockBaseTimePoint(Kernel::HLERequestContext& ctx); |         void CalculateMonotonicSystemClockBaseTimePoint(Kernel::HLERequestContext& ctx); | ||||||
|         void GetClockSnapshot(Kernel::HLERequestContext& ctx); |         void GetClockSnapshot(Kernel::HLERequestContext& ctx); | ||||||
|         void GetClockSnapshotFromSystemClockContext(Kernel::HLERequestContext& ctx); |         void GetClockSnapshotFromSystemClockContext(Kernel::HLERequestContext& ctx); | ||||||
|  |         void CalculateStandardUserSystemClockDifferenceByUser(Kernel::HLERequestContext& ctx); | ||||||
|         void CalculateSpanBetween(Kernel::HLERequestContext& ctx); |         void CalculateSpanBetween(Kernel::HLERequestContext& ctx); | ||||||
|         void GetSharedMemoryNativeHandle(Kernel::HLERequestContext& ctx); |         void GetSharedMemoryNativeHandle(Kernel::HLERequestContext& ctx); | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user