From 871b01a5d91f2812f98b6ed58f024713e3b1ebe1 Mon Sep 17 00:00:00 2001 From: nyanpasu64 Date: Sun, 27 Mar 2022 22:25:40 -0700 Subject: [PATCH] Remove unnecessary atomic usage in GCAdapter.cpp You can safely read or write non-atomic integers on multiple threads, as long as every thread reading or writing it holds the same mutex while doing so (here, s_mutex). Removing the atomic accesses makes the code faster, but the actual performance difference is probably negligible. --- Source/Core/InputCommon/GCAdapter.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/Source/Core/InputCommon/GCAdapter.cpp b/Source/Core/InputCommon/GCAdapter.cpp index 973d1a1d5f..059b17a5e0 100644 --- a/Source/Core/InputCommon/GCAdapter.cpp +++ b/Source/Core/InputCommon/GCAdapter.cpp @@ -51,7 +51,8 @@ static std::mutex s_mutex; static u8 s_controller_payload[37]; static u8 s_controller_payload_swap[37]; -static std::atomic s_controller_payload_size = {0}; +// Only access with s_mutex held! +static int s_controller_payload_size = {0}; static std::thread s_adapter_input_thread; static std::thread s_adapter_output_thread; @@ -101,7 +102,7 @@ static void Read() { std::lock_guard lk(s_mutex); std::swap(s_controller_payload_swap, s_controller_payload); - s_controller_payload_size.store(payload_size); + s_controller_payload_size = payload_size; } Common::YieldCPU(); @@ -459,7 +460,7 @@ GCPadStatus Input(int chan) std::lock_guard lk(s_mutex); std::copy(std::begin(s_controller_payload), std::end(s_controller_payload), std::begin(controller_payload_copy)); - payload_size = s_controller_payload_size.load(); + payload_size = s_controller_payload_size; } GCPadStatus pad = {};