aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib')
-rw-r--r--host/lib/utils/log.cpp95
1 files changed, 62 insertions, 33 deletions
diff --git a/host/lib/utils/log.cpp b/host/lib/utils/log.cpp
index 2b6da2297..c77e082ef 100644
--- a/host/lib/utils/log.cpp
+++ b/host/lib/utils/log.cpp
@@ -18,30 +18,31 @@
#include <uhd/utils/log.hpp>
#include <uhd/utils/static.hpp>
#include <uhd/utils/paths.hpp>
-#include <uhd/utils/tasks.hpp>
#include <uhd/transport/bounded_buffer.hpp>
#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/make_shared.hpp>
-#include <boost/thread/locks.hpp>
-#include <boost/thread/mutex.hpp>
#include <fstream>
#include <cctype>
#include <atomic>
+#include <mutex>
+#include <memory>
+#include <thread>
namespace pt = boost::posix_time;
-static const std::string PURPLE = "\033[35;1m"; // purple
-static const std::string BLUE = "\033[34;1m"; // blue
-static const std::string GREEN = "\033[32;1m"; // green
-static const std::string YELLOW = "\033[33;1m"; // yellow
-static const std::string RED = "\033[31;0m"; // red
-static const std::string BRED = "\033[31;1m"; // bright red
-static const std::string RESET_COLORS = "\033[39;0m"; // reset colors
+// Don't make these static const std::string -- we need their lifetime guaranteed!
+#define PURPLE "\033[35;1m" // purple
+#define BLUE "\033[34;1m" // blue
+#define GREEN "\033[32;1m" // green
+#define YELLOW "\033[33;1m" // yellow
+#define RED "\033[31;0m" // red
+#define BRED "\033[31;1m" // bright red
+#define RESET_COLORS "\033[39;0m" // reset colors
/***********************************************************************
* Helpers
**********************************************************************/
-static const std::string verbosity_color(const uhd::log::severity_level &level){
+static std::string verbosity_color(const uhd::log::severity_level &level){
switch(level){
case (uhd::log::trace):
return PURPLE;
@@ -60,6 +61,26 @@ static const std::string verbosity_color(const uhd::log::severity_level &level){
}
}
+static std::string verbosity_name(const uhd::log::severity_level &level){
+ switch(level){
+ case (uhd::log::trace):
+ return "TRACE";
+ case(uhd::log::debug):
+ return "DEBUG";
+ case(uhd::log::info):
+ return "INFO";
+ case(uhd::log::warning):
+ return "WARNING";
+ case(uhd::log::error):
+ return "ERROR";
+ case(uhd::log::fatal):
+ return "FATAL";
+ default:
+ return "-";
+ }
+ return "";
+}
+
//! get the relative file path from the host directory
inline std::string path_to_filename(std::string path)
{
@@ -69,32 +90,31 @@ inline std::string path_to_filename(std::string path)
/***********************************************************************
* Logger backends
**********************************************************************/
-
-
void console_log(
const uhd::log::logging_info &log_info
) {
- std::clog
+
+ std::clog
#ifdef UHD_LOG_CONSOLE_COLOR
- << verbosity_color(log_info.verbosity)
+ << verbosity_color(log_info.verbosity)
#endif
#ifdef UHD_LOG_CONSOLE_TIME
- << "[" << pt::to_simple_string(log_info.time) << "] "
+ << "[" << pt::to_simple_string(log_info.time) << "] "
#endif
#ifdef UHD_LOG_CONSOLE_THREAD
- << "[0x" << log_info.thread_id << "] "
+ << "[0x" << log_info.thread_id << "] "
#endif
#ifdef UHD_LOG_CONSOLE_SRC
- << "[" << path_to_filename(log_info.file) << ":" << log_info.line << "] "
+ << "[" << path_to_filename(log_info.file) << ":" << log_info.line << "] "
#endif
- << "[" << log_info.verbosity << "] "
- << "[" << log_info.component << "] "
+ << "[" << verbosity_name(log_info.verbosity) << "] "
+ << "[" << log_info.component << "] "
#ifdef UHD_LOG_CONSOLE_COLOR
- << RESET_COLORS
+ << RESET_COLORS
#endif
- << log_info.message
- << std::endl
- ;
+ << log_info.message
+ << std::endl
+ ;
}
/*! Helper class to implement file logging
@@ -115,7 +135,6 @@ public:
std::cerr << "Error opening log file: " << fail.what() << std::endl;
}
}
-
}
void log(const uhd::log::logging_info &log_info)
@@ -211,13 +230,16 @@ public:
}
// Launch log message consumer
- _pop_task = uhd::task::make([this](){this->pop_task();});
-
+ _pop_task = std::make_shared<std::thread>(std::thread([this](){this->pop_task();}));
}
~log_resource(void){
_exit = true;
- _pop_task.reset();
+ _pop_task->join();
+ {
+ std::lock_guard<std::mutex> l(_logmap_mutex);
+ _loggers.clear();
+ }
}
void push(const uhd::log::logging_info& log_info)
@@ -227,9 +249,12 @@ public:
void pop_task()
{
+ uhd::log::logging_info log_info;
+ log_info.message = "";
+
while (!_exit) {
- uhd::log::logging_info log_info;
if (_log_queue.pop_with_timed_wait(log_info, 1)){
+ std::lock_guard<std::mutex> l(_logmap_mutex);
for (const auto &logger : _loggers) {
auto level = logger_level.find(logger.first);
if(level != logger_level.end() && log_info.verbosity < level->second){
@@ -241,8 +266,8 @@ public:
}
// Exit procedure: Clear the queue
- uhd::log::logging_info log_info;
while (_log_queue.pop_with_haste(log_info)) {
+ std::lock_guard<std::mutex> l(_logmap_mutex);
for (const auto &logger : _loggers) {
auto level = logger_level.find(logger.first);
if (level != logger_level.end() && log_info.verbosity < level->second){
@@ -255,11 +280,12 @@ public:
void add_logger(const std::string &key, uhd::log::log_fn_t logger_fn)
{
+ std::lock_guard<std::mutex> l(_logmap_mutex);
_loggers[key] = logger_fn;
}
private:
- uhd::task::sptr _pop_task;
+ std::shared_ptr<std::thread> _pop_task;
uhd::log::severity_level _get_log_level(const std::string &log_level_str,
const uhd::log::severity_level &previous_level){
if (std::isdigit(log_level_str[0])) {
@@ -286,9 +312,10 @@ private:
return previous_level;
}
+ std::mutex _logmap_mutex;
std::atomic<bool> _exit;
std::map<std::string, uhd::log::log_fn_t> _loggers;
- uhd::transport::bounded_buffer<uhd::log::logging_info> _log_queue; // Init auf size 10 oder so
+ uhd::transport::bounded_buffer<uhd::log::logging_info> _log_queue;
};
UHD_SINGLETON_FCN(log_resource, log_rs);
@@ -296,7 +323,6 @@ UHD_SINGLETON_FCN(log_resource, log_rs);
/***********************************************************************
* The logger object implementation
**********************************************************************/
-
uhd::_log::log::log(
const uhd::log::severity_level verbosity,
const std::string &file,
@@ -326,6 +352,9 @@ uhd::_log::log::~log(void)
}
+/***********************************************************************
+ * Public API calls
+ **********************************************************************/
void
uhd::log::add_logger(const std::string &key, log_fn_t logger_fn)
{