aboutsummaryrefslogtreecommitdiffstats
path: root/mpm
diff options
context:
space:
mode:
Diffstat (limited to 'mpm')
-rw-r--r--mpm/python/usrp_mpm/mpmlog.py16
1 files changed, 16 insertions, 0 deletions
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):