From fa765de7db4ab0933578e986c967d6e8eea60170 Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Tue, 14 Nov 2017 21:55:08 -0800 Subject: mpm: Run C++ logger through central logging Reviewed-By: Mark Meserve --- mpm/python/usrp_mpm/mpmlog.py | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/mpm/python/usrp_mpm/mpmlog.py b/mpm/python/usrp_mpm/mpmlog.py index af3018b32..94c23fc22 100644 --- a/mpm/python/usrp_mpm/mpmlog.py +++ b/mpm/python/usrp_mpm/mpmlog.py @@ -72,6 +72,12 @@ class MPMLogger(logging.getLoggerClass()): """ def __init__(self, *args, **kwargs): logging.Logger.__init__(self, *args, **kwargs) + self.cpp_log_buf = None + try: + import usrp_mpm.libpyusrp_periphs as lib + self.cpp_log_buf = lib.types.log_buf.make_singleton() + except ImportError: + pass def trace(self, *args, **kwargs): """ Extends logging for super-high verbosity """ @@ -113,6 +119,16 @@ def get_main_logger( )) default_log_level = max(1, default_log_level - (default_log_level % 10)) LOGGER.setLevel(default_log_level) + # Connect to C++ logging: + if LOGGER.cpp_log_buf is not None: + lib_logger = LOGGER.getChild('lib') + def log_from_cpp(): + " Callback for logging from C++ " + log_level, component, message = LOGGER.cpp_log_buf.pop() + if log_level: + lib_logger.log(log_level, "[%s] %s", + component, message.strip()) + LOGGER.cpp_log_buf.set_notify_callback(log_from_cpp) return LOGGER def get_logger(child_name): -- cgit v1.2.3