From dd3a5448343297d6adc62e739ac9b4d38831edac Mon Sep 17 00:00:00 2001 From: Benau Date: Tue, 20 Mar 2018 09:59:14 +0800 Subject: [PATCH] Use std atomic for timeout --- src/network/protocols/server_lobby.cpp | 20 ++++++++++---------- src/network/protocols/server_lobby.hpp | 2 +- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/network/protocols/server_lobby.cpp b/src/network/protocols/server_lobby.cpp index a35324532..a6e4c909c 100644 --- a/src/network/protocols/server_lobby.cpp +++ b/src/network/protocols/server_lobby.cpp @@ -319,7 +319,7 @@ void ServerLobby::asynchronousUpdate() } break; case SELECTING: - if (m_timeout < (float)StkTime::getRealTime()) + if (m_timeout.load() < (float)StkTime::getRealTime()) { auto result = handleVote(); // Remove disconnected player (if any) one last time @@ -426,7 +426,7 @@ void ServerLobby::update(int ticks) } break; case RESULT_DISPLAY: - if(StkTime::getRealTime() > m_timeout) + if(StkTime::getRealTime() > m_timeout.load()) { RaceResultGUI::getInstance()->backToLobby(); // notify the network world that it is stopped @@ -611,7 +611,7 @@ void ServerLobby::startSelection(const Event *event) m_state = SELECTING; // Will be changed after the first vote received - m_timeout = std::numeric_limits::max(); + m_timeout.store(std::numeric_limits::max()); std::make_shared()->requestStart(); Log::info("LobbyProtocol", "LatencyProtocol started."); @@ -685,7 +685,7 @@ void ServerLobby::checkIncomingConnectionRequests() m_player_ready_counter = 0; // Set the delay before the server forces all clients to exit the race // result screen and go back to the lobby - m_timeout = (float)(StkTime::getRealTime()+15.0f); + m_timeout.store((float)(StkTime::getRealTime()+15.0f)); m_state = RESULT_DISPLAY; // calculate karts ranks : @@ -1039,12 +1039,12 @@ void ServerLobby::playerVote(Event* event) return; // Check if first vote, if so start counter - if (m_timeout == std::numeric_limits::max()) + if (m_timeout.load() == std::numeric_limits::max()) { - m_timeout = (float)StkTime::getRealTime() + - UserConfigParams::m_voting_timeout; + m_timeout.store((float)StkTime::getRealTime() + + UserConfigParams::m_voting_timeout); } - float remaining_time = m_timeout - (float)StkTime::getRealTime(); + float remaining_time = m_timeout.load() - (float)StkTime::getRealTime(); if (remaining_time < 0.0f) { return; @@ -1054,7 +1054,7 @@ void ServerLobby::playerVote(Event* event) NetworkString other = NetworkString(PROTOCOL_LOBBY_ROOM); std::string name = StringUtils::wideToUtf8(event->getPeer() ->getPlayerProfiles()[0]->getName()); - other.addUInt8(LE_VOTE).addFloat(m_timeout).encodeString(name) + other.addUInt8(LE_VOTE).addFloat(m_timeout.load()).encodeString(name) .addUInt32(event->getPeer()->getHostId()); other += data; @@ -1205,7 +1205,7 @@ void ServerLobby::playerFinishedResult(Event *event) // We can't trigger the world/race exit here, since this is called // from the protocol manager thread. So instead we force the timeout // to get triggered (which is done from the main thread): - m_timeout = 0; + m_timeout.store(0); } } // playerFinishedResult diff --git a/src/network/protocols/server_lobby.hpp b/src/network/protocols/server_lobby.hpp index 691d7179f..86cc80d67 100644 --- a/src/network/protocols/server_lobby.hpp +++ b/src/network/protocols/server_lobby.hpp @@ -69,7 +69,7 @@ private: int m_player_ready_counter; /** Timeout counter for various state. */ - float m_timeout; + std::atomic m_timeout; /** Lock this mutex whenever a client is connect / disconnect or * starting race. */