summaryrefslogtreecommitdiff
path: root/src/common/arm64
diff options
context:
space:
mode:
authorGravatar Kelebek12023-10-29 13:50:55 +0000
committerGravatar Kelebek12024-01-24 04:26:55 +0000
commite4915fb7d2077584a11a15141bc81d28ed2b0125 (patch)
tree1783055dc2e98eaf9099e8e7b194b55f8f607747 /src/common/arm64
parentMerge pull request #12678 from german77/settings_impl (diff)
downloadyuzu-e4915fb7d2077584a11a15141bc81d28ed2b0125.tar.gz
yuzu-e4915fb7d2077584a11a15141bc81d28ed2b0125.tar.xz
yuzu-e4915fb7d2077584a11a15141bc81d28ed2b0125.zip
Rework time service to fix time passing offline.
Diffstat (limited to 'src/common/arm64')
-rw-r--r--src/common/arm64/native_clock.cpp24
-rw-r--r--src/common/arm64/native_clock.h10
2 files changed, 14 insertions, 20 deletions
diff --git a/src/common/arm64/native_clock.cpp b/src/common/arm64/native_clock.cpp
index f437d7187..76ffb74ba 100644
--- a/src/common/arm64/native_clock.cpp
+++ b/src/common/arm64/native_clock.cpp
@@ -30,27 +30,27 @@ NativeClock::NativeClock() {
30} 30}
31 31
32std::chrono::nanoseconds NativeClock::GetTimeNS() const { 32std::chrono::nanoseconds NativeClock::GetTimeNS() const {
33 return std::chrono::nanoseconds{MultiplyHigh(GetHostTicksElapsed(), ns_cntfrq_factor)}; 33 return std::chrono::nanoseconds{MultiplyHigh(GetUptime(), ns_cntfrq_factor)};
34} 34}
35 35
36std::chrono::microseconds NativeClock::GetTimeUS() const { 36std::chrono::microseconds NativeClock::GetTimeUS() const {
37 return std::chrono::microseconds{MultiplyHigh(GetHostTicksElapsed(), us_cntfrq_factor)}; 37 return std::chrono::microseconds{MultiplyHigh(GetUptime(), us_cntfrq_factor)};
38} 38}
39 39
40std::chrono::milliseconds NativeClock::GetTimeMS() const { 40std::chrono::milliseconds NativeClock::GetTimeMS() const {
41 return std::chrono::milliseconds{MultiplyHigh(GetHostTicksElapsed(), ms_cntfrq_factor)}; 41 return std::chrono::milliseconds{MultiplyHigh(GetUptime(), ms_cntfrq_factor)};
42} 42}
43 43
44u64 NativeClock::GetCNTPCT() const { 44s64 NativeClock::GetCNTPCT() const {
45 return MultiplyHigh(GetHostTicksElapsed(), guest_cntfrq_factor); 45 return MultiplyHigh(GetUptime(), guest_cntfrq_factor);
46} 46}
47 47
48u64 NativeClock::GetGPUTick() const { 48s64 NativeClock::GetGPUTick() const {
49 return MultiplyHigh(GetHostTicksElapsed(), gputick_cntfrq_factor); 49 return MultiplyHigh(GetUptime(), gputick_cntfrq_factor);
50} 50}
51 51
52u64 NativeClock::GetHostTicksNow() const { 52s64 NativeClock::GetUptime() const {
53 u64 cntvct_el0 = 0; 53 s64 cntvct_el0 = 0;
54 asm volatile("dsb ish\n\t" 54 asm volatile("dsb ish\n\t"
55 "mrs %[cntvct_el0], cntvct_el0\n\t" 55 "mrs %[cntvct_el0], cntvct_el0\n\t"
56 "dsb ish\n\t" 56 "dsb ish\n\t"
@@ -58,15 +58,11 @@ u64 NativeClock::GetHostTicksNow() const {
58 return cntvct_el0; 58 return cntvct_el0;
59} 59}
60 60
61u64 NativeClock::GetHostTicksElapsed() const {
62 return GetHostTicksNow();
63}
64
65bool NativeClock::IsNative() const { 61bool NativeClock::IsNative() const {
66 return true; 62 return true;
67} 63}
68 64
69u64 NativeClock::GetHostCNTFRQ() { 65s64 NativeClock::GetHostCNTFRQ() {
70 u64 cntfrq_el0 = 0; 66 u64 cntfrq_el0 = 0;
71 std::string_view board{""}; 67 std::string_view board{""};
72#ifdef ANDROID 68#ifdef ANDROID
diff --git a/src/common/arm64/native_clock.h b/src/common/arm64/native_clock.h
index a28b419f2..94bc1882e 100644
--- a/src/common/arm64/native_clock.h
+++ b/src/common/arm64/native_clock.h
@@ -17,17 +17,15 @@ public:
17 17
18 std::chrono::milliseconds GetTimeMS() const override; 18 std::chrono::milliseconds GetTimeMS() const override;
19 19
20 u64 GetCNTPCT() const override; 20 s64 GetCNTPCT() const override;
21 21
22 u64 GetGPUTick() const override; 22 s64 GetGPUTick() const override;
23 23
24 u64 GetHostTicksNow() const override; 24 s64 GetUptime() const override;
25
26 u64 GetHostTicksElapsed() const override;
27 25
28 bool IsNative() const override; 26 bool IsNative() const override;
29 27
30 static u64 GetHostCNTFRQ(); 28 static s64 GetHostCNTFRQ();
31 29
32public: 30public:
33 using FactorType = unsigned __int128; 31 using FactorType = unsigned __int128;