aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib')
-rw-r--r--host/lib/utils/log.cpp301
1 files changed, 133 insertions, 168 deletions
diff --git a/host/lib/utils/log.cpp b/host/lib/utils/log.cpp
index 8126d46b7..f2f0e24ff 100644
--- a/host/lib/utils/log.cpp
+++ b/host/lib/utils/log.cpp
@@ -5,19 +5,19 @@
// SPDX-License-Identifier: GPL-3.0-or-later
//
+#include <uhd/transport/bounded_buffer.hpp>
#include <uhd/utils/log.hpp>
#include <uhd/utils/log_add.hpp>
-#include <uhd/utils/static.hpp>
#include <uhd/utils/paths.hpp>
-#include <uhd/transport/bounded_buffer.hpp>
+#include <uhd/utils/static.hpp>
#include <uhd/version.hpp>
#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/make_shared.hpp>
-#include <fstream>
-#include <cctype>
#include <atomic>
-#include <mutex>
+#include <cctype>
+#include <fstream>
#include <memory>
+#include <mutex>
#include <thread>
namespace pt = boost::posix_time;
@@ -35,59 +35,59 @@ namespace pt = boost::posix_time;
* Helpers
**********************************************************************/
namespace {
- std::string verbosity_color(const uhd::log::severity_level &level){
- switch(level){
+std::string verbosity_color(const uhd::log::severity_level& level)
+{
+ switch (level) {
case (uhd::log::trace):
return PURPLE;
- case(uhd::log::debug):
+ case (uhd::log::debug):
return BLUE;
- case(uhd::log::info):
+ case (uhd::log::info):
return GREEN;
- case(uhd::log::warning):
+ case (uhd::log::warning):
return YELLOW;
- case(uhd::log::error):
+ case (uhd::log::error):
return RED;
- case(uhd::log::fatal):
+ case (uhd::log::fatal):
return BRED;
default:
return RESET_COLORS;
- }
}
+}
- std::string verbosity_name(const uhd::log::severity_level &level){
- switch(level){
+std::string verbosity_name(const uhd::log::severity_level& level)
+{
+ switch (level) {
case (uhd::log::trace):
return "TRACE";
- case(uhd::log::debug):
+ case (uhd::log::debug):
return "DEBUG";
- case(uhd::log::info):
+ case (uhd::log::info):
return "INFO";
- case(uhd::log::warning):
+ case (uhd::log::warning):
return "WARNING";
- case(uhd::log::error):
+ case (uhd::log::error):
return "ERROR";
- case(uhd::log::fatal):
+ case (uhd::log::fatal):
return "FATAL";
default:
return "-";
- }
- }
-
- //! get the relative file path from the host directory
- inline std::string path_to_filename(std::string path)
- {
- return path.substr(path.find_last_of("/\\") + 1);
}
+}
+//! get the relative file path from the host directory
+inline std::string path_to_filename(std::string path)
+{
+ return path.substr(path.find_last_of("/\\") + 1);
}
+} // namespace
+
/***********************************************************************
* Logger backends
**********************************************************************/
-void console_log(
- const uhd::log::logging_info &log_info
-) {
-
+void console_log(const uhd::log::logging_info& log_info)
+{
std::clog
#ifdef UHD_LOG_CONSOLE_COLOR
<< verbosity_color(log_info.verbosity)
@@ -106,9 +106,7 @@ void console_log(
#ifdef UHD_LOG_CONSOLE_COLOR
<< RESET_COLORS
#endif
- << log_info.message
- << std::endl
- ;
+ << log_info.message << std::endl;
}
/*! Helper class to implement file logging
@@ -119,29 +117,27 @@ void console_log(
class file_logger_backend
{
public:
- file_logger_backend(const std::string &file_path)
+ file_logger_backend(const std::string& file_path)
{
_file_stream.exceptions(std::ofstream::failbit | std::ofstream::badbit);
- if (!file_path.empty()){
+ if (!file_path.empty()) {
try {
- _file_stream.open(file_path.c_str(), std::fstream::out | std::fstream::app);
- } catch (const std::ofstream::failure& fail){
+ _file_stream.open(
+ file_path.c_str(), std::fstream::out | std::fstream::app);
+ } catch (const std::ofstream::failure& fail) {
std::cerr << "Error opening log file: " << fail.what() << std::endl;
}
}
}
- void log(const uhd::log::logging_info &log_info)
+ void log(const uhd::log::logging_info& log_info)
{
- if (_file_stream.is_open()){
- _file_stream
- << pt::to_simple_string(log_info.time) << ","
- << "0x" << log_info.thread_id << ","
- << path_to_filename(log_info.file) << ":" << log_info.line << ","
- << log_info.verbosity << ","
- << log_info.component << ","
- << log_info.message
- << std::endl;
+ if (_file_stream.is_open()) {
+ _file_stream << pt::to_simple_string(log_info.time) << ","
+ << "0x" << log_info.thread_id << ","
+ << path_to_filename(log_info.file) << ":" << log_info.line << ","
+ << log_info.verbosity << "," << log_info.component << ","
+ << log_info.message << std::endl;
;
}
}
@@ -149,7 +145,7 @@ public:
~file_logger_backend()
{
- if (_file_stream.is_open()){
+ if (_file_stream.is_open()) {
_file_stream.close();
}
}
@@ -165,30 +161,30 @@ private:
#define UHD_CONSOLE_LOGGER_KEY "console"
#define UHD_FILE_LOGGER_KEY "file"
-class log_resource {
+class log_resource
+{
public:
uhd::log::severity_level global_level;
- log_resource(void):
- global_level(uhd::log::off),
- _exit(false),
+ log_resource(void)
+ : global_level(uhd::log::off)
+ , _exit(false)
+ ,
#ifndef UHD_LOG_FASTPATH_DISABLE
- _fastpath_queue(10),
+ _fastpath_queue(10)
+ ,
#endif
_log_queue(10)
{
- //allow override from macro definition
+ // allow override from macro definition
#ifdef UHD_LOG_MIN_LEVEL
- this->global_level = _get_log_level(
- BOOST_STRINGIZE(UHD_LOG_MIN_LEVEL),
- this->global_level
- );
+ this->global_level =
+ _get_log_level(BOOST_STRINGIZE(UHD_LOG_MIN_LEVEL), this->global_level);
#endif
- //allow override from environment variables
- const char * log_level_env = std::getenv("UHD_LOG_LEVEL");
+ // allow override from environment variables
+ const char* log_level_env = std::getenv("UHD_LOG_LEVEL");
if (log_level_env != NULL && log_level_env[0] != '\0') {
- this->global_level =
- _get_log_level(log_level_env, this->global_level);
+ this->global_level = _get_log_level(log_level_env, this->global_level);
}
// Setup default loggers (console and file)
@@ -198,28 +194,22 @@ public:
// On boot, we print the current UHD version info:
{
std::ostringstream sys_info;
- sys_info \
- << BOOST_PLATFORM << "; "
- << BOOST_COMPILER << "; "
- << "Boost_"
- << BOOST_VERSION << "; "
- << "UHD_" << uhd::get_version_string();
+ sys_info << BOOST_PLATFORM << "; " << BOOST_COMPILER << "; "
+ << "Boost_" << BOOST_VERSION << "; "
+ << "UHD_" << uhd::get_version_string();
_publish_log_msg(sys_info.str(), uhd::log::info, "UHD");
}
// Launch log message consumer
- _pop_task = std::make_shared<std::thread>(
- std::thread([this](){this->pop_task();})
- );
+ _pop_task =
+ std::make_shared<std::thread>(std::thread([this]() { this->pop_task(); }));
// Fastpath message consumer
#ifndef UHD_LOG_FASTPATH_DISABLE
- //allow override from environment variables
- const bool enable_fastpath = [](){
- const char* disable_fastpath_env =
- std::getenv("UHD_LOG_FASTPATH_DISABLE");
- if (disable_fastpath_env != NULL
- && disable_fastpath_env[0] != '\0') {
+ // allow override from environment variables
+ const bool enable_fastpath = []() {
+ const char* disable_fastpath_env = std::getenv("UHD_LOG_FASTPATH_DISABLE");
+ if (disable_fastpath_env != NULL && disable_fastpath_env[0] != '\0') {
return false;
}
return true;
@@ -227,12 +217,10 @@ public:
if (enable_fastpath) {
_pop_fastpath_task = std::make_shared<std::thread>(
- std::thread([this](){this->pop_fastpath_task();})
- );
+ std::thread([this]() { this->pop_fastpath_task(); }));
} else {
_pop_fastpath_task = std::make_shared<std::thread>(
- std::thread([this](){this->pop_fastpath_dummy_task();})
- );
+ std::thread([this]() { this->pop_fastpath_dummy_task(); }));
_publish_log_msg("Fastpath logging disabled at runtime.");
}
#else
@@ -242,19 +230,18 @@ public:
#endif
}
- ~log_resource(void){
+ ~log_resource(void)
+ {
_exit = true;
// We push a final message to kick the pop task out of it's wait state.
// This wouldn't be necessary if pop_with_wait() could fail. Should
// that ever get fixed, we can remove this.
- auto final_message = uhd::log::logging_info(
- pt::microsec_clock::local_time(),
- uhd::log::trace,
- __FILE__,
- __LINE__,
- "LOGGING",
- boost::this_thread::get_id()
- );
+ auto final_message = uhd::log::logging_info(pt::microsec_clock::local_time(),
+ uhd::log::trace,
+ __FILE__,
+ __LINE__,
+ "LOGGING",
+ boost::this_thread::get_id());
final_message.message = "";
push(final_message);
#ifndef UHD_LOG_FASTPATH_DISABLE
@@ -279,7 +266,7 @@ public:
}
#ifndef UHD_LOG_FASTPATH_DISABLE
- void push_fastpath(const std::string &message)
+ void push_fastpath(const std::string& message)
{
// Never wait. If the buffer is full, we just don't see the message.
// Too bad.
@@ -295,7 +282,7 @@ public:
std::lock_guard<std::mutex> l(_logmap_mutex);
for (const auto& logger_pair : _loggers) {
const auto& logger = logger_pair.second;
- if (log_info.verbosity < logger.first){
+ if (log_info.verbosity < logger.first) {
continue;
}
logger.second(log_info);
@@ -346,22 +333,19 @@ public:
}
// Exit procedure: Clear the queue
- while (_fastpath_queue.pop_with_haste(msg));
+ while (_fastpath_queue.pop_with_haste(msg))
+ ;
#endif
}
- void add_logger(
- const std::string &key,
- uhd::log::log_fn_t logger_fn
- ) {
+ void add_logger(const std::string& key, uhd::log::log_fn_t logger_fn)
+ {
std::lock_guard<std::mutex> l(_logmap_mutex);
_loggers[key] = level_logfn_pair{global_level, logger_fn};
}
- void set_log_level(
- const std::string &key,
- const uhd::log::severity_level level
- ) {
+ void set_log_level(const std::string& key, const uhd::log::severity_level level)
+ {
std::lock_guard<std::mutex> l(_logmap_mutex);
_loggers[key].first = level;
}
@@ -371,22 +355,22 @@ private:
#ifndef UHD_LOG_FASTPATH_DISABLE
std::shared_ptr<std::thread> _pop_fastpath_task;
#endif
- uhd::log::severity_level _get_log_level(const std::string &log_level_str,
- const uhd::log::severity_level &previous_level){
+ 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])) {
const uhd::log::severity_level log_level_num =
uhd::log::severity_level(std::stoi(log_level_str));
- if (log_level_num >= uhd::log::trace and
- log_level_num <= uhd::log::fatal) {
+ if (log_level_num >= uhd::log::trace and log_level_num <= uhd::log::fatal) {
return log_level_num;
- }else{
- UHD_LOGGER_ERROR("LOG") << "Failed to set log level to: " << log_level_str;
+ } else {
+ UHD_LOGGER_ERROR("LOG")
+ << "Failed to set log level to: " << log_level_str;
return previous_level;
}
}
-#define if_loglevel_equal(name) \
- else if (log_level_str == #name) return uhd::log::name
+#define if_loglevel_equal(name) else if (log_level_str == #name) return uhd::log::name
if_loglevel_equal(trace);
if_loglevel_equal(debug);
if_loglevel_equal(info);
@@ -401,20 +385,15 @@ private:
{
#ifndef UHD_LOG_CONSOLE_DISABLE
uhd::log::severity_level console_level = uhd::log::trace;
-#ifdef UHD_LOG_CONSOLE_LEVEL
- console_level = _get_log_level(
- BOOST_STRINGIZE(UHD_LOG_CONSOLE_LEVEL),
- console_level
- );
-#endif
- const char* log_console_level_env =
- std::getenv("UHD_LOG_CONSOLE_LEVEL");
+# ifdef UHD_LOG_CONSOLE_LEVEL
+ console_level =
+ _get_log_level(BOOST_STRINGIZE(UHD_LOG_CONSOLE_LEVEL), console_level);
+# endif
+ const char* log_console_level_env = std::getenv("UHD_LOG_CONSOLE_LEVEL");
if (log_console_level_env != NULL && log_console_level_env[0] != '\0') {
- console_level =
- _get_log_level(log_console_level_env, console_level);
+ console_level = _get_log_level(log_console_level_env, console_level);
}
- _loggers[UHD_CONSOLE_LOGGER_KEY] =
- level_logfn_pair{console_level, &console_log};
+ _loggers[UHD_CONSOLE_LOGGER_KEY] = level_logfn_pair{console_level, &console_log};
#endif
}
@@ -423,52 +402,43 @@ private:
uhd::log::severity_level file_level = uhd::log::trace;
std::string log_file_target;
#if defined(UHD_LOG_FILE_LEVEL)
- file_level = _get_log_level(
- BOOST_STRINGIZE(UHD_LOG_FILE_LEVEL),
- file_level
- );
+ file_level = _get_log_level(BOOST_STRINGIZE(UHD_LOG_FILE_LEVEL), file_level);
#endif
#if defined(UHD_LOG_FILE)
log_file_target = BOOST_STRINGIZE(UHD_LOG_FILE);
#endif
const char* log_file_level_env = std::getenv("UHD_LOG_FILE_LEVEL");
- if (log_file_level_env != NULL && log_file_level_env[0] != '\0'){
+ if (log_file_level_env != NULL && log_file_level_env[0] != '\0') {
file_level = _get_log_level(log_file_level_env, file_level);
}
const char* log_file_env = std::getenv("UHD_LOG_FILE");
if ((log_file_env != NULL) && (log_file_env[0] != '\0')) {
log_file_target = std::string(log_file_env);
}
- if (!log_file_target.empty()){
+ if (!log_file_target.empty()) {
auto F = std::make_shared<file_logger_backend>(log_file_target);
- _loggers[UHD_FILE_LOGGER_KEY] = level_logfn_pair{
- file_level,
- [F](const uhd::log::logging_info& log_info){F->log(log_info);}
- };
+ _loggers[UHD_FILE_LOGGER_KEY] = level_logfn_pair{file_level,
+ [F](const uhd::log::logging_info& log_info) { F->log(log_info); }};
}
}
- void _publish_log_msg(
- const std::string& msg,
- const uhd::log::severity_level level=uhd::log::info,
- const std::string& component="LOGGING"
- ) {
- auto log_msg = uhd::log::logging_info(
- pt::microsec_clock::local_time(),
+ void _publish_log_msg(const std::string& msg,
+ const uhd::log::severity_level level = uhd::log::info,
+ const std::string& component = "LOGGING")
+ {
+ auto log_msg = uhd::log::logging_info(pt::microsec_clock::local_time(),
level,
__FILE__,
__LINE__,
component,
- boost::this_thread::get_id()
- );
+ boost::this_thread::get_id());
log_msg.message = msg;
_log_queue.push_with_timed_wait(log_msg, 0.25);
}
std::mutex _logmap_mutex;
std::atomic<bool> _exit;
- using level_logfn_pair =
- std::pair<uhd::log::severity_level, uhd::log::log_fn_t>;
+ using level_logfn_pair = std::pair<uhd::log::severity_level, uhd::log::log_fn_t>;
std::map<std::string, level_logfn_pair> _loggers;
#ifndef UHD_LOG_FASTPATH_DISABLE
uhd::transport::bounded_buffer<std::string> _fastpath_queue;
@@ -481,18 +451,15 @@ 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,
+uhd::_log::log::log(const uhd::log::severity_level verbosity,
+ const std::string& file,
const unsigned int line,
- const std::string &component,
- const boost::thread::id thread_id
- ) :
- _log_it(verbosity >= log_rs().global_level)
+ const std::string& component,
+ const boost::thread::id thread_id)
+ : _log_it(verbosity >= log_rs().global_level)
{
- if (_log_it){
- this->_log_info = uhd::log::logging_info(
- pt::microsec_clock::local_time(),
+ if (_log_it) {
+ this->_log_info = uhd::log::logging_info(pt::microsec_clock::local_time(),
verbosity,
file,
line,
@@ -505,20 +472,20 @@ uhd::_log::log::~log(void)
{
if (_log_it) {
this->_log_info.message = _ss.str();
- try{
+ try {
log_rs().push(this->_log_info);
+ } catch (...) {
}
- catch (...){}
}
}
#ifndef UHD_LOG_FASTPATH_DISABLE
-void uhd::_log::log_fastpath(const std::string &msg)
+void uhd::_log::log_fastpath(const std::string& msg)
{
log_rs().push_fastpath(msg);
}
#else
-void uhd::_log::log_fastpath(const std::string &)
+void uhd::_log::log_fastpath(const std::string&)
{
// nop
}
@@ -527,29 +494,27 @@ void uhd::_log::log_fastpath(const std::string &)
/***********************************************************************
* Public API calls
**********************************************************************/
-void
-uhd::log::add_logger(const std::string &key, log_fn_t logger_fn)
+void uhd::log::add_logger(const std::string& key, log_fn_t logger_fn)
{
log_rs().add_logger(key, logger_fn);
}
-void
-uhd::log::set_log_level(uhd::log::severity_level level){
+void uhd::log::set_log_level(uhd::log::severity_level level)
+{
log_rs().global_level = level;
}
-void
-uhd::log::set_logger_level(const std::string &key, uhd::log::severity_level level){
+void uhd::log::set_logger_level(const std::string& key, uhd::log::severity_level level)
+{
log_rs().set_log_level(key, level);
}
-void
-uhd::log::set_console_level(uhd::log::severity_level level){
+void uhd::log::set_console_level(uhd::log::severity_level level)
+{
set_logger_level(UHD_CONSOLE_LOGGER_KEY, level);
}
-void
-uhd::log::set_file_level(uhd::log::severity_level level){
+void uhd::log::set_file_level(uhd::log::severity_level level)
+{
set_logger_level(UHD_FILE_LOGGER_KEY, level);
}
-