From cf1ede9129c13c9f3f55a0bd9a750312208c3cc6 Mon Sep 17 00:00:00 2001 From: jsjtxietian Date: Tue, 6 Feb 2024 11:29:44 +0800 Subject: [PATCH] Fix data race regarding `prof_time` in `AudioDriver` and `AudioServer` --- servers/audio_server.cpp | 6 +++--- servers/audio_server.h | 14 +++++++------- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/servers/audio_server.cpp b/servers/audio_server.cpp index b46befd502a..f340f7bbf8c 100644 --- a/servers/audio_server.cpp +++ b/servers/audio_server.cpp @@ -316,7 +316,7 @@ void AudioServer::_driver_process(int p_frames, int32_t *p_buffer) { } #ifdef DEBUG_ENABLED - prof_time += OS::get_singleton()->get_ticks_usec() - prof_ticks; + prof_time.add(OS::get_singleton()->get_ticks_usec() - prof_ticks); #endif } @@ -1400,7 +1400,7 @@ void AudioServer::update() { // Driver time includes server time + effects times // Server time includes effects times uint64_t driver_time = AudioDriver::get_singleton()->get_profiling_time(); - uint64_t server_time = prof_time; + uint64_t server_time = prof_time.get(); // Subtract the server time from the driver time if (driver_time > server_time) { @@ -1459,7 +1459,7 @@ void AudioServer::update() { } AudioDriver::get_singleton()->reset_profiling_time(); - prof_time = 0; + prof_time.set(0); #endif for (CallbackItem *ci : update_callback_list) { diff --git a/servers/audio_server.h b/servers/audio_server.h index 4606299c477..a7b764d1a58 100644 --- a/servers/audio_server.h +++ b/servers/audio_server.h @@ -52,8 +52,8 @@ class AudioDriver { uint64_t _last_mix_frames = 0; #ifdef DEBUG_ENABLED - uint64_t prof_ticks = 0; - uint64_t prof_time = 0; + SafeNumeric prof_ticks; + SafeNumeric prof_time; #endif protected: @@ -69,8 +69,8 @@ protected: int _get_configured_mix_rate(); #ifdef DEBUG_ENABLED - _FORCE_INLINE_ void start_counting_ticks() { prof_ticks = OS::get_singleton()->get_ticks_usec(); } - _FORCE_INLINE_ void stop_counting_ticks() { prof_time += OS::get_singleton()->get_ticks_usec() - prof_ticks; } + _FORCE_INLINE_ void start_counting_ticks() { prof_ticks.set(OS::get_singleton()->get_ticks_usec()); } + _FORCE_INLINE_ void stop_counting_ticks() { prof_time.add(OS::get_singleton()->get_ticks_usec() - prof_ticks.get()); } #else _FORCE_INLINE_ void start_counting_ticks() {} _FORCE_INLINE_ void stop_counting_ticks() {} @@ -125,8 +125,8 @@ public: unsigned int get_input_size() { return input_size; } #ifdef DEBUG_ENABLED - uint64_t get_profiling_time() const { return prof_time; } - void reset_profiling_time() { prof_time = 0; } + uint64_t get_profiling_time() const { return prof_time.get(); } + void reset_profiling_time() { prof_time.set(0); } #endif AudioDriver() {} @@ -183,7 +183,7 @@ private: uint64_t mix_count = 0; uint64_t mix_frames = 0; #ifdef DEBUG_ENABLED - uint64_t prof_time = 0; + SafeNumeric prof_time; #endif float channel_disable_threshold_db = 0.0f;