From a48f80b33a9859da52dfbcebf0bc69e80c1bb8e5 Mon Sep 17 00:00:00 2001 From: "Matthias P. Braendli" Date: Mon, 19 Feb 2018 11:37:09 +0100 Subject: Replace boost thread in ManagementServer --- src/ManagementServer.cpp | 33 ++++++++++++++++----------------- src/ManagementServer.h | 17 ++++++++--------- 2 files changed, 24 insertions(+), 26 deletions(-) (limited to 'src') diff --git a/src/ManagementServer.cpp b/src/ManagementServer.cpp index 25a3f49..d42a205 100644 --- a/src/ManagementServer.cpp +++ b/src/ManagementServer.cpp @@ -35,11 +35,12 @@ #include #include #include -#include #include #include "ManagementServer.h" #include "Log.h" +using namespace std; + #define MIN_FILL_BUFFER_UNDEF (-1) /* For silence detection, we count the number of occurrences the audio level @@ -125,7 +126,7 @@ ManagementServer& get_mgmt_server() void ManagementServer::registerInput(InputStat* is) { - boost::mutex::scoped_lock lock(m_statsmutex); + unique_lock lock(m_statsmutex); std::string id(is->get_name()); @@ -141,7 +142,7 @@ void ManagementServer::registerInput(InputStat* is) void ManagementServer::unregisterInput(std::string id) { - boost::mutex::scoped_lock lock(m_statsmutex); + unique_lock lock(m_statsmutex); if (m_inputStats.count(id) == 1) { m_inputStats.erase(id); @@ -151,7 +152,7 @@ void ManagementServer::unregisterInput(std::string id) bool ManagementServer::isInputRegistered(std::string& id) { - boost::mutex::scoped_lock lock(m_statsmutex); + unique_lock lock(m_statsmutex); if (m_inputStats.count(id) == 0) { etiLog.level(error) << @@ -164,7 +165,7 @@ bool ManagementServer::isInputRegistered(std::string& id) std::string ManagementServer::getStatConfigJSON() { - boost::mutex::scoped_lock lock(m_statsmutex); + unique_lock lock(m_statsmutex); std::ostringstream ss; ss << "{ \"config\" : [\n"; @@ -190,7 +191,7 @@ std::string ManagementServer::getStatConfigJSON() std::string ManagementServer::getValuesJSON() { - boost::mutex::scoped_lock lock(m_statsmutex); + unique_lock lock(m_statsmutex); std::ostringstream ss; ss << "{ \"values\" : {\n"; @@ -218,8 +219,7 @@ std::string ManagementServer::getValuesJSON() void ManagementServer::restart() { - m_restarter_thread = boost::thread(&ManagementServer::restart_thread, - this, 0); + m_restarter_thread = thread(&ManagementServer::restart_thread, this, 0); } // This runs in a separate thread, because @@ -230,11 +230,10 @@ void ManagementServer::restart_thread(long) m_running = false; if (m_listenport) { - m_thread.interrupt(); m_thread.join(); } - m_thread = boost::thread(&ManagementServer::serverThread, this); + m_thread = thread(&ManagementServer::serverThread, this); } void ManagementServer::serverThread() @@ -284,7 +283,7 @@ void ManagementServer::handle_message(zmq::message_t& zmq_message) answer << getValuesJSON(); } else if (data == "getptree") { - boost::unique_lock lock(m_configmutex); + unique_lock lock(m_configmutex); boost::property_tree::json_parser::write_json(answer, m_pt); } else { @@ -305,7 +304,7 @@ void ManagementServer::handle_message(zmq::message_t& zmq_message) void ManagementServer::update_ptree(const boost::property_tree::ptree& pt) { if (m_running) { - boost::unique_lock lock(m_configmutex); + unique_lock lock(m_configmutex); m_pt = pt; } } @@ -341,7 +340,7 @@ void InputStat::registerAtServer() void InputStat::notifyBuffer(long bufsize) { - boost::mutex::scoped_lock lock(m_mutex); + unique_lock lock(m_mutex); m_buffer_fill_stats.push_back(bufsize); @@ -360,7 +359,7 @@ void InputStat::notifyBuffer(long bufsize) void InputStat::notifyPeakLevels(int peak_left, int peak_right) { - boost::mutex::scoped_lock lock(m_mutex); + unique_lock lock(m_mutex); m_peaks_left.push_back(peak_left); m_peaks_right.push_back(peak_right); @@ -411,7 +410,7 @@ void InputStat::notifyPeakLevels(int peak_left, int peak_right) void InputStat::notifyUnderrun(void) { - boost::mutex::scoped_lock lock(m_mutex); + unique_lock lock(m_mutex); // Statistics m_num_underruns++; @@ -431,7 +430,7 @@ void InputStat::notifyUnderrun(void) void InputStat::notifyOverrun(void) { - boost::mutex::scoped_lock lock(m_mutex); + unique_lock lock(m_mutex); // Statistics m_num_overruns++; @@ -449,7 +448,7 @@ std::string InputStat::encodeValuesJSON() const int16_t int16_max = std::numeric_limits::max(); - boost::mutex::scoped_lock lock(m_mutex); + unique_lock lock(m_mutex); int peak_left = 0; int peak_right = 0; diff --git a/src/ManagementServer.h b/src/ManagementServer.h index 885565a..f8d722e 100644 --- a/src/ManagementServer.h +++ b/src/ManagementServer.h @@ -56,7 +56,8 @@ #include #include #include -#include +#include +#include #include #include #include @@ -128,7 +129,7 @@ class InputStat std::chrono::time_point m_time_last_event; // The mutex that has to be held during all notify and readout - mutable boost::mutex m_mutex; + mutable std::mutex m_mutex; }; class ManagementServer @@ -144,8 +145,6 @@ class ManagementServer { m_running = false; m_fault = false; - - // TODO notify m_thread.join(); } @@ -156,7 +155,7 @@ class ManagementServer { m_listenport = listenport; if (m_listenport > 0) { - m_thread = boost::thread(&ManagementServer::serverThread, this); + m_thread = std::thread(&ManagementServer::serverThread, this); } } @@ -195,8 +194,8 @@ class ManagementServer // serverThread runs in a separate thread std::atomic m_running; std::atomic m_fault; - boost::thread m_thread; - boost::thread m_restarter_thread; + std::thread m_thread; + std::thread m_restarter_thread; /******* Statistics Data ********/ std::map m_inputStats; @@ -215,10 +214,10 @@ class ManagementServer std::string getValuesJSON(); // mutex for accessing the map - boost::mutex m_statsmutex; + std::mutex m_statsmutex; /******** Configuration Data *******/ - boost::mutex m_configmutex; + std::mutex m_configmutex; boost::property_tree::ptree m_pt; }; -- cgit v1.2.3