From 7816843dfbe9ca5767267ef359270e063acacde8 Mon Sep 17 00:00:00 2001 From: Nekotekina Date: Wed, 16 Jul 2014 22:29:26 +0400 Subject: [PATCH] Little fix --- rpcs3/Emu/SysCalls/lv2/sys_time.cpp | 5 +++-- rpcs3/Emu/SysCalls/lv2/sys_time.h | 2 ++ 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/rpcs3/Emu/SysCalls/lv2/sys_time.cpp b/rpcs3/Emu/SysCalls/lv2/sys_time.cpp index df4d2b109a..aada49f665 100644 --- a/rpcs3/Emu/SysCalls/lv2/sys_time.cpp +++ b/rpcs3/Emu/SysCalls/lv2/sys_time.cpp @@ -35,7 +35,8 @@ u64 get_time() LARGE_INTEGER cycle; QueryPerformanceCounter(&cycle); - return cycle.QuadPart * timebase_frequency / freq.value; + u64 sec = cycle.QuadPart / freq.value; + return sec * timebase_frequency + (cycle.QuadPart % freq.value) * timebase_frequency / freq.value; #else struct timespec ts; if (!clock_gettime(CLOCK_MONOTONIC, &ts)) @@ -50,7 +51,7 @@ u64 get_time() // Returns some relative time in microseconds, don't change this fact u64 get_system_time() { - return get_time() / (timebase_frequency / 1000000); + return get_time() / (timebase_frequency / MHZ); } diff --git a/rpcs3/Emu/SysCalls/lv2/sys_time.h b/rpcs3/Emu/SysCalls/lv2/sys_time.h index 921504cb42..3ebdefb7da 100644 --- a/rpcs3/Emu/SysCalls/lv2/sys_time.h +++ b/rpcs3/Emu/SysCalls/lv2/sys_time.h @@ -1,5 +1,7 @@ #pragma once +#define MHZ (10000000) + // Auxiliary functions u64 get_time(); u64 get_system_time();