[libcamera-devel] [PATCH 3/3] utils: libtuning: Add logging parameters to argparse

Paul Elder paul.elder at ideasonboard.com
Tue Nov 29 06:33:26 CET 2022


Add command line arguments for log levels and log output file.

Signed-off-by: Paul Elder <paul.elder at ideasonboard.com>
---
 utils/tuning/libtuning/libtuning.py | 32 +++++++++++++++++++++++++----
 1 file changed, 28 insertions(+), 4 deletions(-)

diff --git a/utils/tuning/libtuning/libtuning.py b/utils/tuning/libtuning/libtuning.py
index d34d98ab..b2c40ba4 100644
--- a/utils/tuning/libtuning/libtuning.py
+++ b/utils/tuning/libtuning/libtuning.py
@@ -6,6 +6,7 @@
 
 import argparse
 from pathlib import Path
+import sys
 
 import libtuning as lt
 from libtuning.logger import Logger
@@ -150,10 +151,24 @@ class Tuner(object):
         # options, so simply return an empty configuration if none is provided.
         parser.add_argument('-c', '--config', type=str, default='',
                             help='Config file (optional)')
-        # \todo Check if we really need this or if stderr is good enough, or if
-        # we want a better logging infrastructure with log levels
-        parser.add_argument('-l', '--log', type=str, default=None,
-                            help='Output log file (optional)')
+        parser.add_argument('-l', '--log', type=str, default=sys.stderr,
+                            help='Output log file (optional). Default is stderr.')
+        parser.add_argument('-ll', '--log_levels', type=str, default='',
+                            help='''Output log levels (optional).
+                                    A comma-separated list of module names and
+                                    their log levels (in integer form, where
+                                    debug=0, info=1, warn=2, error=3, and
+                                    fatal=4), in the format: "{module name}:{log
+                                    level},{module name}:{log_level}...", and so
+                                    on. Any module that is not specified will use the
+                                    default log level, or the default can be
+                                    specified with the log name "*". For the
+                                    purposes of logging, module names are the
+                                    same as class names, or the file name for
+                                    components that are not classes. This
+                                    parameter can also be simply set to a
+                                    single integer to set the log levels for
+                                    all components.''')
         parser.add_argument('-dd', '--debug_dir', type=str, default=None,
                             help='''Debug output directory (optional).
                                     If the directory does not exist, it will be
@@ -205,6 +220,12 @@ class Tuner(object):
             if not debug_dir.is_dir():
                 debug_dir.mkdir()
 
+        # Prepare logging
+        if args.log is not sys.stderr:
+            Logger.log_file = open(args.log, mode='a')
+
+        Logger.set_log_levels(args.log_levels)
+
         # Validate modules and set debug
         for module in self.modules:
             if not module.validate_config(self.config):
@@ -237,4 +258,7 @@ class Tuner(object):
 
         self.generator.write(args.output, self.output, self.output_order)
 
+        if Logger.log_file is not sys.stderr:
+            Logger.log_file.close()
+
         return 0
-- 
2.35.1



More information about the libcamera-devel mailing list