aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/utils/log.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/utils/log.cpp')
-rw-r--r--host/lib/utils/log.cpp21
1 files changed, 16 insertions, 5 deletions
diff --git a/host/lib/utils/log.cpp b/host/lib/utils/log.cpp
index 64e3e8e44..df18ce97f 100644
--- a/host/lib/utils/log.cpp
+++ b/host/lib/utils/log.cpp
@@ -11,10 +11,10 @@
#include <uhd/utils/log_add.hpp>
#include <uhd/utils/paths.hpp>
#include <uhd/utils/static.hpp>
+#include <uhd/utils/thread.hpp>
#include <uhd/version.hpp>
#include <uhdlib/utils/isatty.hpp>
#include <boost/date_time/posix_time/posix_time.hpp>
-#include <memory>
#include <atomic>
#include <cctype>
#include <fstream>
@@ -22,8 +22,7 @@
#include <mutex>
#include <thread>
-namespace pt = boost::posix_time;
-constexpr double READ_TIMEOUT = 0.5; // Waiting time to read from the queue
+namespace pt = boost::posix_time;
// Don't make these static const std::string -- we need their lifetime guaranteed!
#define PURPLE "\033[0;35m" // purple
@@ -40,6 +39,15 @@ constexpr double READ_TIMEOUT = 0.5; // Waiting time to read from the queue
* Helpers
**********************************************************************/
namespace {
+
+#ifdef BOOST_MSVC
+constexpr double READ_TIMEOUT = 0.5; // Waiting time to read from the queue
+#endif
+
+constexpr char LOG_THREAD_NAME[] = "uhd_log";
+constexpr char LOG_THREAD_NAME_FP[] = "uhd_log_fastpath";
+constexpr char LOG_THREAD_NAME_FP_DUMMY[] = "uhd_log_fp_dummy";
+
std::string verbosity_color(const uhd::log::severity_level& level)
{
static const bool tty = uhd::is_a_tty(2); // is stderr a tty?
@@ -204,14 +212,15 @@ public:
{
std::ostringstream sys_info;
sys_info << BOOST_PLATFORM << "; " << BOOST_COMPILER << "; "
- << "Boost_" << BOOST_VERSION << "; "
- << uhd::get_component() << "_" << uhd::get_version_string();
+ << "Boost_" << BOOST_VERSION << "; " << uhd::get_component() << "_"
+ << 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(); }));
+ uhd::set_thread_name(_pop_task.get(), LOG_THREAD_NAME);
// Fastpath message consumer
#ifndef UHD_LOG_FASTPATH_DISABLE
@@ -227,9 +236,11 @@ public:
if (enable_fastpath) {
_pop_fastpath_task = std::make_shared<std::thread>(
std::thread([this]() { this->pop_fastpath_task(); }));
+ uhd::set_thread_name(_pop_fastpath_task.get(), LOG_THREAD_NAME_FP);
} else {
_pop_fastpath_task = std::make_shared<std::thread>(
std::thread([this]() { this->pop_fastpath_dummy_task(); }));
+ uhd::set_thread_name(_pop_fastpath_task.get(), LOG_THREAD_NAME_FP_DUMMY);
_publish_log_msg("Fastpath logging disabled at runtime.");
}
#else