From 61715e5d329bf9df968adc3381a23ea2549c3f2b Mon Sep 17 00:00:00 2001 From: iphydf Date: Mon, 28 Mar 2022 21:52:43 +0000 Subject: [PATCH] refactor: Store time in Mono_Time in milliseconds. Conversion to seconds happens in `mono_time_get`, and a new function `mono_time_get_ms` allows code to retrieve monotonic time in milliseconds. --- .../docker/tox-bootstrapd.sha256 | 2 +- toxcore/mono_time.c | 29 +++++++++++-------- toxcore/mono_time.h | 19 ++++++++---- 3 files changed, 32 insertions(+), 18 deletions(-) diff --git a/other/bootstrap_daemon/docker/tox-bootstrapd.sha256 b/other/bootstrap_daemon/docker/tox-bootstrapd.sha256 index 5df2d65f0e8..2dc41156668 100644 --- a/other/bootstrap_daemon/docker/tox-bootstrapd.sha256 +++ b/other/bootstrap_daemon/docker/tox-bootstrapd.sha256 @@ -1 +1 @@ -b3fb4157d7fc6cd3455f40020bb6b69e5bab4bbdb6ce66d5bc7095146ba5a49e /usr/local/bin/tox-bootstrapd +fafcb972b575499414311fa6b397262eac542b8d185551e62bb0262e8d7f751b /usr/local/bin/tox-bootstrapd diff --git a/toxcore/mono_time.c b/toxcore/mono_time.c index 176dbf17e53..7b21e324f96 100644 --- a/toxcore/mono_time.c +++ b/toxcore/mono_time.c @@ -161,7 +161,7 @@ Mono_Time *mono_time_new(mono_time_current_time_cb *current_time_callback, void // Maximum reproducibility. Never return time = 0. mono_time->base_time = 1; #else - mono_time->base_time = (uint64_t)time(nullptr) - (current_time_monotonic(mono_time) / 1000ULL); + mono_time->base_time = (uint64_t)time(nullptr) * 1000ULL - current_time_monotonic(mono_time); #endif mono_time_update(mono_time); @@ -184,14 +184,13 @@ void mono_time_free(Mono_Time *mono_time) void mono_time_update(Mono_Time *mono_time) { - uint64_t cur_time = 0; #ifdef OS_WIN32 /* we actually want to update the overflow state of mono_time here */ pthread_mutex_lock(&mono_time->last_clock_lock); mono_time->last_clock_update = true; #endif - cur_time = mono_time->current_time_callback(mono_time->user_data) / 1000ULL; - cur_time += mono_time->base_time; + const uint64_t cur_time = + mono_time->base_time + mono_time->current_time_callback(mono_time->user_data); #ifdef OS_WIN32 pthread_mutex_unlock(&mono_time->last_clock_lock); #endif @@ -201,17 +200,22 @@ void mono_time_update(Mono_Time *mono_time) pthread_rwlock_unlock(mono_time->time_update_lock); } -uint64_t mono_time_get(const Mono_Time *mono_time) +uint64_t mono_time_get_ms(const Mono_Time *mono_time) { -#ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION +#ifndef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION // Fuzzing is only single thread for now, no locking needed */ - return mono_time->cur_time; -#else pthread_rwlock_rdlock(mono_time->time_update_lock); +#endif const uint64_t cur_time = mono_time->cur_time; +#ifndef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION pthread_rwlock_unlock(mono_time->time_update_lock); - return cur_time; #endif + return cur_time; +} + +uint64_t mono_time_get(const Mono_Time *mono_time) +{ + return mono_time_get_ms(mono_time) / 1000ULL; } bool mono_time_is_timeout(const Mono_Time *mono_time, uint64_t timestamp, uint64_t timeout) @@ -231,9 +235,10 @@ void mono_time_set_current_time_callback(Mono_Time *mono_time, } } -/** - * Return current monotonic time in milliseconds (ms). The starting point is - * unspecified. +/** @brief Return current monotonic time in milliseconds (ms). + * + * The starting point is unspecified and in particular is likely not comparable + * to the return value of `mono_time_get_ms()`. */ uint64_t current_time_monotonic(Mono_Time *mono_time) { diff --git a/toxcore/mono_time.h b/toxcore/mono_time.h index 5a36724715c..f38a90baa07 100644 --- a/toxcore/mono_time.h +++ b/toxcore/mono_time.h @@ -60,8 +60,16 @@ void mono_time_free(Mono_Time *mono_time); non_null() void mono_time_update(Mono_Time *mono_time); -/** - * Return unix time since epoch in seconds. +/** @brief Return current monotonic time in milliseconds (ms). + * + * The starting point is UNIX epoch as measured by `time()` in `mono_time_new()`. + */ +non_null() +uint64_t mono_time_get_ms(const Mono_Time *mono_time); + +/** @brief Return a monotonically increasing time in seconds. + * + * The starting point is UNIX epoch as measured by `time()` in `mono_time_new()`. */ non_null() uint64_t mono_time_get(const Mono_Time *mono_time); @@ -72,9 +80,10 @@ uint64_t mono_time_get(const Mono_Time *mono_time); non_null() bool mono_time_is_timeout(const Mono_Time *mono_time, uint64_t timestamp, uint64_t timeout); -/** - * Return current monotonic time in milliseconds (ms). The starting point is - * unspecified. +/** @brief Return current monotonic time in milliseconds (ms). + * + * The starting point is unspecified and in particular is likely not comparable + * to the return value of `mono_time_get_ms()`. */ non_null() uint64_t current_time_monotonic(Mono_Time *mono_time);