From de2e84344d610aa20a88ed1c9de3b9b80bdb4f82 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Thu, 21 May 2015 19:52:26 -0400 Subject: [PATCH] Core: Convert volatile bools to atomics Converts over bools that are typically used as loop checks into atomics. --- Source/Core/Core/HW/EXI_DeviceGecko.cpp | 26 ++++++------ Source/Core/Core/HW/EXI_DeviceGecko.h | 7 ++-- .../Core/Core/HW/WiimoteReal/WiimoteReal.cpp | 42 +++++++++---------- Source/Core/Core/HW/WiimoteReal/WiimoteReal.h | 13 +++--- Source/Core/Core/NetPlayClient.cpp | 32 +++++++------- Source/Core/Core/NetPlayClient.h | 7 ++-- 6 files changed, 63 insertions(+), 64 deletions(-) diff --git a/Source/Core/Core/HW/EXI_DeviceGecko.cpp b/Source/Core/Core/HW/EXI_DeviceGecko.cpp index d1aaa14c07..f364e7b78b 100644 --- a/Source/Core/Core/HW/EXI_DeviceGecko.cpp +++ b/Source/Core/Core/HW/EXI_DeviceGecko.cpp @@ -14,7 +14,7 @@ u16 GeckoSockServer::server_port; int GeckoSockServer::client_count; std::thread GeckoSockServer::connectionThread; -volatile bool GeckoSockServer::server_running; +std::atomic GeckoSockServer::server_running; std::mutex GeckoSockServer::connection_lock; std::queue> GeckoSockServer::waiting_socks; @@ -31,13 +31,13 @@ GeckoSockServer::~GeckoSockServer() { --client_count; - client_running = false; + client_running.store(false); clientThread.join(); } if (client_count <= 0) { - server_running = false; + server_running.store(false); connectionThread.join(); } } @@ -48,14 +48,14 @@ void GeckoSockServer::GeckoConnectionWaiter() sf::TcpListener server; server_port = 0xd6ec; // "dolphin gecko" - for (int bind_tries = 0; bind_tries <= 10 && !server_running; bind_tries++) + for (int bind_tries = 0; bind_tries <= 10 && !server_running.load(); bind_tries++) { - server_running = server.listen(server_port) == sf::Socket::Done; - if (!server_running) + server_running.store(server.listen(server_port) == sf::Socket::Done); + if (!server_running.load()) server_port++; } - if (!server_running) + if (!server_running.load()) return; Core::DisplayMessage( @@ -65,7 +65,7 @@ void GeckoSockServer::GeckoConnectionWaiter() server.setBlocking(false); auto new_client = std::make_unique(); - while (server_running) + while (server_running.load()) { if (server.accept(*new_client) == sf::Socket::Done) { @@ -89,7 +89,7 @@ bool GeckoSockServer::GetAvailableSock() client = std::move(waiting_socks.front()); if (clientThread.joinable()) { - client_running = false; + client_running.store(false); clientThread.join(); recv_fifo = std::deque(); @@ -106,13 +106,13 @@ bool GeckoSockServer::GetAvailableSock() void GeckoSockServer::ClientThread() { - client_running = true; + client_running.store(true); Common::SetCurrentThreadName("Gecko Client"); client->setBlocking(false); - while (client_running) + while (client_running.load()) { bool did_nothing = true; @@ -124,7 +124,7 @@ void GeckoSockServer::ClientThread() std::size_t got = 0; if (client->receive(&data[0], ArraySize(data), got) == sf::Socket::Disconnected) - client_running = false; + client_running.store(false); if (got != 0) { @@ -141,7 +141,7 @@ void GeckoSockServer::ClientThread() send_fifo.clear(); if (client->send(&packet[0], packet.size()) == sf::Socket::Disconnected) - client_running = false; + client_running.store(false); } } // unlock transfer diff --git a/Source/Core/Core/HW/EXI_DeviceGecko.h b/Source/Core/Core/HW/EXI_DeviceGecko.h index e18b049ce9..3b60406e82 100644 --- a/Source/Core/Core/HW/EXI_DeviceGecko.h +++ b/Source/Core/Core/HW/EXI_DeviceGecko.h @@ -4,6 +4,7 @@ #pragma once +#include #include #include #include @@ -31,14 +32,14 @@ public: std::deque recv_fifo; private: - static int client_count; - volatile bool client_running; + static int client_count; + std::atomic client_running; // Only ever one server thread static void GeckoConnectionWaiter(); static u16 server_port; - static volatile bool server_running; + static std::atomic server_running; static std::thread connectionThread; static std::mutex connection_lock; static std::queue> waiting_socks; diff --git a/Source/Core/Core/HW/WiimoteReal/WiimoteReal.cpp b/Source/Core/Core/HW/WiimoteReal/WiimoteReal.cpp index ba9401df5b..388789076c 100644 --- a/Source/Core/Core/HW/WiimoteReal/WiimoteReal.cpp +++ b/Source/Core/Core/HW/WiimoteReal/WiimoteReal.cpp @@ -302,7 +302,7 @@ void Wiimote::Update() void Wiimote::Prepare(int _index) { m_index = _index; - m_need_prepare = true; + m_need_prepare.store(true); } bool Wiimote::PrepareOnThread() @@ -406,27 +406,27 @@ static unsigned int CalculateWantedBB() void WiimoteScanner::WantWiimotes(bool do_want) { - m_want_wiimotes = do_want; + m_want_wiimotes.store(do_want); } void WiimoteScanner::WantBB(bool do_want) { - m_want_bb = do_want; + m_want_bb.store(do_want); } void WiimoteScanner::StartScanning() { - if (!m_run_thread) + if (!m_run_thread.load()) { - m_run_thread = true; + m_run_thread.store(true); m_scan_thread = std::thread(&WiimoteScanner::ThreadFunc, this); } } void WiimoteScanner::StopScanning() { - m_run_thread = false; + m_run_thread.store(false); if (m_scan_thread.joinable()) { m_scan_thread.join(); @@ -448,14 +448,14 @@ void WiimoteScanner::ThreadFunc() NOTICE_LOG(WIIMOTE, "Wiimote scanning has started."); - while (m_run_thread) + while (m_run_thread.load()) { std::vector found_wiimotes; Wiimote* found_board = nullptr; //NOTICE_LOG(WIIMOTE, "In loop"); - if (m_want_wiimotes || m_want_bb) + if (m_want_wiimotes.load() || m_want_bb.load()) { FindWiimotes(found_wiimotes, found_board); } @@ -470,9 +470,10 @@ void WiimoteScanner::ThreadFunc() // TODO: this is a fairly lame place for this CheckForDisconnectedWiimotes(); - if (m_want_wiimotes) + if (m_want_wiimotes.load()) HandleFoundWiimotes(found_wiimotes); - if (m_want_bb && found_board) + + if (m_want_bb.load() && found_board) TryToConnectBalanceBoard(found_board); //std::this_thread::yield(); @@ -484,7 +485,7 @@ void WiimoteScanner::ThreadFunc() bool Wiimote::Connect() { - m_thread_ready = false; + m_thread_ready.store(false); StartThread(); WaitReady(); return IsConnected(); @@ -492,13 +493,13 @@ bool Wiimote::Connect() void Wiimote::StartThread() { - m_run_thread = true; + m_run_thread.store(true); m_wiimote_thread = std::thread(&Wiimote::ThreadFunc, this); } void Wiimote::StopThread() { - m_run_thread = false; + m_run_thread.store(false); IOWakeup(); if (m_wiimote_thread.joinable()) m_wiimote_thread.join(); @@ -506,12 +507,9 @@ void Wiimote::StopThread() void Wiimote::SetReady() { - if (!m_thread_ready) + if (!m_thread_ready.load()) { - { - std::lock_guard Guard(m_thread_ready_mutex); - m_thread_ready = true; - } + m_thread_ready.store(true); m_thread_ready_cond.notify_all(); } } @@ -519,7 +517,7 @@ void Wiimote::SetReady() void Wiimote::WaitReady() { std::unique_lock lock(m_thread_ready_mutex); - while (!m_thread_ready) + while (!m_thread_ready.load()) { m_thread_ready_cond.wait(lock); } @@ -546,11 +544,11 @@ void Wiimote::ThreadFunc() } // main loop - while (IsConnected() && m_run_thread) + while (IsConnected() && m_run_thread.load()) { - if (m_need_prepare) + if (m_need_prepare.load()) { - m_need_prepare = false; + m_need_prepare.store(false); if (!PrepareOnThread()) { ERROR_LOG(WIIMOTE, "Wiimote::PrepareOnThread failed. Disconnecting Wiimote %d.", m_index + 1); diff --git a/Source/Core/Core/HW/WiimoteReal/WiimoteReal.h b/Source/Core/Core/HW/WiimoteReal/WiimoteReal.h index 1c62002dd3..2047314392 100644 --- a/Source/Core/Core/HW/WiimoteReal/WiimoteReal.h +++ b/Source/Core/Core/HW/WiimoteReal/WiimoteReal.h @@ -4,6 +4,7 @@ #pragma once +#include #include #include #include @@ -96,11 +97,11 @@ private: std::thread m_wiimote_thread; // Whether to keep running the thread. - volatile bool m_run_thread; + std::atomic m_run_thread; // Whether to call PrepareOnThread. - volatile bool m_need_prepare; + std::atomic m_need_prepare; // Whether the thread has finished ConnectInternal. - volatile bool m_thread_ready; + std::atomic m_thread_ready; std::mutex m_thread_ready_mutex; std::condition_variable m_thread_ready_cond; @@ -134,9 +135,9 @@ private: std::thread m_scan_thread; - volatile bool m_run_thread; - volatile bool m_want_wiimotes; - volatile bool m_want_bb; + std::atomic m_run_thread; + std::atomic m_want_wiimotes; + std::atomic m_want_bb; #if defined(_WIN32) void CheckDeviceType(std::basic_string &devicepath, bool &real_wiimote, bool &is_bb); diff --git a/Source/Core/Core/NetPlayClient.cpp b/Source/Core/Core/NetPlayClient.cpp index 3bf6e743c3..3f53d58a32 100644 --- a/Source/Core/Core/NetPlayClient.cpp +++ b/Source/Core/Core/NetPlayClient.cpp @@ -26,12 +26,12 @@ NetSettings g_NetPlaySettings; NetPlayClient::~NetPlayClient() { // not perfect - if (m_is_running) + if (m_is_running.load()) StopGame(); if (is_connected) { - m_do_loop = false; + m_do_loop.store(false); m_thread.join(); } @@ -409,8 +409,7 @@ unsigned int NetPlayClient::OnData(sf::Packet& packet) case NP_MSG_DISABLE_GAME: { PanicAlertT("Other client disconnected while game is running!! NetPlay is disabled. You must manually stop the game."); - std::lock_guard lkg(m_crit.game); - m_is_running = false; + m_is_running.store(false); NetPlay_Disable(); } break; @@ -499,7 +498,7 @@ void NetPlayClient::SendAsync(sf::Packet* packet) // called from ---NETPLAY--- thread void NetPlayClient::ThreadFunc() { - while (m_do_loop) + while (m_do_loop.load()) { ENetEvent netEvent; int net; @@ -523,11 +522,11 @@ void NetPlayClient::ThreadFunc() enet_packet_destroy(netEvent.packet); break; case ENET_EVENT_TYPE_DISCONNECT: - m_is_running = false; + m_is_running.store(false); NetPlay_Disable(); m_dialog->AppendChat("< LOST CONNECTION TO SERVER >"); PanicAlertT("Lost connection to server!"); - m_do_loop = false; + m_do_loop.store(false); netEvent.peer->data = nullptr; break; @@ -636,7 +635,7 @@ bool NetPlayClient::StartGame(const std::string &path) *spac << (char *)&g_NetPlaySettings; SendAsync(spac); - if (m_is_running) + if (m_is_running.load()) { PanicAlertT("Game is already running!"); return false; @@ -644,7 +643,7 @@ bool NetPlayClient::StartGame(const std::string &path) m_dialog->AppendChat(" -- STARTING GAME -- "); - m_is_running = true; + m_is_running.store(true); NetPlay_Enable(this); ClearBuffers(); @@ -823,7 +822,7 @@ bool NetPlayClient::GetNetPads(const u8 pad_nb, GCPadStatus* pad_status) // to retrieve data for slot 1. while (!m_pad_buffer[pad_nb].Pop(*pad_status)) { - if (!m_is_running) + if (!m_is_running.load()) return false; // TODO: use a condition instead of sleeping @@ -893,7 +892,7 @@ bool NetPlayClient::WiimoteUpdate(int _number, u8* data, const u8 size) { // wait for receiving thread to push some data Common::SleepCurrentThread(1); - if (false == m_is_running) + if (!m_is_running.load()) return false; } @@ -918,7 +917,7 @@ bool NetPlayClient::WiimoteUpdate(int _number, u8* data, const u8 size) while (!m_wiimote_buffer[_number].Pop(nw)) { Common::SleepCurrentThread(1); - if (false == m_is_running) + if (!m_is_running.load()) return false; } ++tries; @@ -942,9 +941,7 @@ bool NetPlayClient::WiimoteUpdate(int _number, u8* data, const u8 size) // called from ---GUI--- thread and ---NETPLAY--- thread (client side) bool NetPlayClient::StopGame() { - std::lock_guard lkg(m_crit.game); - - if (false == m_is_running) + if (!m_is_running.load()) { PanicAlertT("Game isn't running!"); return false; @@ -952,7 +949,7 @@ bool NetPlayClient::StopGame() m_dialog->AppendChat(" -- STOPPING GAME -- "); - m_is_running = false; + m_is_running.store(false); NetPlay_Disable(); // stop game @@ -964,8 +961,9 @@ bool NetPlayClient::StopGame() // called from ---GUI--- thread void NetPlayClient::Stop() { - if (m_is_running == false) + if (!m_is_running.load()) return; + bool isPadMapped = false; for (PadMapping mapping : m_pad_map) { diff --git a/Source/Core/Core/NetPlayClient.h b/Source/Core/Core/NetPlayClient.h index 7d3bbf7d73..ce5d0ee63b 100644 --- a/Source/Core/Core/NetPlayClient.h +++ b/Source/Core/Core/NetPlayClient.h @@ -4,6 +4,7 @@ #pragma once +#include #include #include #include @@ -108,9 +109,9 @@ protected: ENetPeer* m_server; std::thread m_thread; - std::string m_selected_game; - volatile bool m_is_running; - volatile bool m_do_loop; + std::string m_selected_game; + std::atomic m_is_running; + std::atomic m_do_loop; unsigned int m_target_buffer_size;