Files
rocm-systems/src/utils/logger.py
T
2024-04-01 14:30:21 -05:00

133 строки
4.9 KiB
Python

##############################################################################bl
# MIT License
#
# Copyright (c) 2021 - 2024 Advanced Micro Devices, Inc. All Rights Reserved.
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in all
# copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
##############################################################################el
import logging
import os
import sys
from utils.utils import trace_logger
# Define the colors
BLACK, RED, GREEN, YELLOW, BLUE, MAGENTA, CYAN, WHITE = range(8)
RESET_SEQ = "\033[0m"
COLOR_SEQ = "\033[%dm"
COLORS = {
"WARNING": YELLOW,
"INFO": WHITE,
"DEBUG": BLUE,
"CRITICAL": RED,
"ERROR": RED,
"TRACE": MAGENTA,
}
# Define the formatter
class ColoredFormatter(logging.Formatter):
def format(self, record):
levelname = record.levelname
if levelname in COLORS:
if levelname == "WARNING" or levelname == "ERROR" or levelname == "DEBUG":
log_fmt = f"{COLOR_SEQ % (30 + COLORS[levelname])}%(levelname)s: %(message)s{RESET_SEQ}"
else:
log_fmt = f"{COLOR_SEQ % (30 + COLORS[levelname])}%(message)s{RESET_SEQ}"
formatter = logging.Formatter(log_fmt)
return formatter.format(record)
class PlainFormatter(logging.Formatter):
def format(self, record):
if record.levelno == logging.ERROR:
self._style._fmt = "%(levelname)s %(message)s"
else:
self._style._fmt = "%(message)s"
return logging.Formatter.format(self, record)
# Setup console handler - provided as separate function to be called
# prior to argument parsing
def setup_console_handler():
# register a trace level logger
logging.TRACE = logging.DEBUG - 5
logging.addLevelName(logging.TRACE, "TRACE")
setattr(logging, "TRACE", logging.TRACE)
setattr(logging, "trace", trace_logger)
formatter = ColoredFormatter()
console_handler = logging.StreamHandler(sys.stdout)
console_handler.setFormatter(formatter)
console_handler.set_name("console")
logging.getLogger().addHandler(console_handler)
# Setup file handler - enabled in profile mode
def setup_file_handler(loglevel, workload_dir):
filename = os.path.join(workload_dir, "log.txt")
file_handler = logging.FileHandler(filename, "w")
file_loglevel = min([loglevel, logging.INFO])
file_handler.setLevel(file_loglevel)
file_handler.setFormatter(logging.Formatter("%(message)s"))
logging.getLogger().addHandler(file_handler)
# Setup logger priority - called after argument parsing
def setup_logging_priority(verbosity, quietmode, appmode):
# set loglevel based on selected verbosity and quietmode
levels = [logging.INFO, logging.DEBUG, logging.TRACE]
if quietmode:
loglevel = logging.ERROR
else:
loglevel = levels[min(verbosity, len(levels) - 1)] # cap to last level index
# optional: override of default loglevel via env variable which takes precedence
if "OMNIPERF_LOGLEVEL" in os.environ.keys():
loglevel = os.environ["OMNIPERF_LOGLEVEL"]
if loglevel in {"DEBUG", "debug"}:
loglevel = logging.DEBUG
elif loglevel in {"TRACE", "trace"}:
loglevel = logging.TRACE
elif loglevel in {"INFO", "info"}:
loglevel = logging.INFO
elif loglevel in {"ERROR", "error"}:
loglevel = logging.ERROR
else:
print("Ignoring unsupported OMNIPERF_LOGLEVEL setting (%s)" % loglevel)
sys.exit(1)
# update console loglevel based on command-line args/env settings
for handler in logging.getLogger().handlers:
if handler.get_name() == "console":
handler.setLevel(loglevel)
# set global loglevel to min of console/file settings in profile mode
if appmode == "profile":
global_loglevel = min([logging.INFO, loglevel])
logging.getLogger().setLevel(global_loglevel)
else:
logging.getLogger().setLevel(loglevel)
return loglevel