mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu-mainline.git
				synced 2025-03-21 01:53:15 +00:00 
			
		
		
		
	Merge pull request #3659 from bunnei/time-calc-standard-user
service: time: Implement CalculateStandardUserSystemClockDifferenceByUser.
This commit is contained in:
		
						commit
						db67e017cb
					
				@ -29,7 +29,7 @@ Time::Time(std::shared_ptr<Module> module, Core::System& system, const char* nam
 | 
			
		||||
        {300, &Time::CalculateMonotonicSystemClockBaseTimePoint, "CalculateMonotonicSystemClockBaseTimePoint"},
 | 
			
		||||
        {400, &Time::GetClockSnapshot, "GetClockSnapshot"},
 | 
			
		||||
        {401, &Time::GetClockSnapshotFromSystemClockContext, "GetClockSnapshotFromSystemClockContext"},
 | 
			
		||||
        {500, nullptr, "CalculateStandardUserSystemClockDifferenceByUser"},
 | 
			
		||||
        {500, &Time::CalculateStandardUserSystemClockDifferenceByUser, "CalculateStandardUserSystemClockDifferenceByUser"},
 | 
			
		||||
        {501, &Time::CalculateSpanBetween, "CalculateSpanBetween"},
 | 
			
		||||
    };
 | 
			
		||||
    // clang-format on
 | 
			
		||||
 | 
			
		||||
@ -308,6 +308,29 @@ void Module::Interface::GetClockSnapshotFromSystemClockContext(Kernel::HLEReques
 | 
			
		||||
    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) {
 | 
			
		||||
    LOG_DEBUG(Service_Time, "called");
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -32,6 +32,7 @@ public:
 | 
			
		||||
        void CalculateMonotonicSystemClockBaseTimePoint(Kernel::HLERequestContext& ctx);
 | 
			
		||||
        void GetClockSnapshot(Kernel::HLERequestContext& ctx);
 | 
			
		||||
        void GetClockSnapshotFromSystemClockContext(Kernel::HLERequestContext& ctx);
 | 
			
		||||
        void CalculateStandardUserSystemClockDifferenceByUser(Kernel::HLERequestContext& ctx);
 | 
			
		||||
        void CalculateSpanBetween(Kernel::HLERequestContext& ctx);
 | 
			
		||||
        void GetSharedMemoryNativeHandle(Kernel::HLERequestContext& ctx);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user