# Copyright 2017 The Chromium OS Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. import glob import os import logging import subprocess def chrome_vmodule_flag(): """Return vmodule flag for chrome to enable VDAs/VEAs/JDAs/V4L2IP logs""" logging_patterns = ['*/media/gpu/*video_decode_accelerator.cc=2', '*/media/gpu/*video_encode_accelerator.cc=2', '*/media/gpu/*jpeg_decode_accelerator.cc=2', '*/media/gpu/*image_processor.cc=2', '*/media/gpu/v4l2/v4l2_device.cc=2'] chrome_video_vmodule_flag = '--vmodule=' + ','.join(logging_patterns) logging.info('chrome video vmodule flag: %s', chrome_video_vmodule_flag) return chrome_video_vmodule_flag def video_log_wrapper(func): """ Return decorator that make verbose video logs enable before test and make them disable after completing test. @param func: function, the test function, e.g., run_once @returns decorator function """ vlog = VideoLog() #videobuf2 log files = glob.glob('/sys/module/videobuf2_*/parameters/debug') vlog.add_log(files, ['1'] * len(files), ['0'] * len(files), 'videobuf2 log') #s5p_mfc log fpath = '/sys/module/s5p_mfc/parameters/debug' if os.path.exists(fpath): vlog.add_log([fpath], ['1'], ['0'], 's5p_mfc log') #rk3399 log #rk3399 debug level is controlled by bits. #Here, 3 means to enable log level 0 and 1. fpath = '/sys/module/rockchip_vpu/parameters/debug' if os.path.exists(fpath): vlog.add_log([fpath], ['3'], ['0'], 'rk3399 log') #rk3288 log #rk3288 debug level is controlled by bits. #Here, 3 means to enable log level 0 and 1. fpath = '/sys/module/rk3288_vpu/parameters/debug' if os.path.exists(fpath): vlog.add_log([fpath], ['3'], ['0'], 'rk3288 log') #go2001 log fpath = '/sys/module/go2001/parameters/go2001_debug_level' if os.path.exists(fpath): vlog.add_log([fpath], ['1'], ['0'], 'go2001 log') def call(*args, **kwargs): """ Enable logs before the test, execute the test and disable logs after the test. In any case, it is guranteed to disable logs. """ with vlog: return func(*args, **kwargs) return call def cmdexec_with_log(cmd, info_message): """ Execute command, logging infomation message. @param cmd: string, command to be executed @param info_message: string, the messages to be shown in log message """ try: logging.info('%s : %s', info_message, cmd) subprocess.check_call(cmd, shell=True) except subprocess.CalledProcessError: logging.warning('Fail to execute command [%s] : %s', info_message, cmd) class VideoLog: """ Enable/Disable video logs. """ def __init__(self): self.logs = [] def add_log(self, files, enable_values, disable_values, log_name): """ Add new log @param files: list of string, file paths @param enable_values: list of string, the list of value to write to each file path for enabling @param disable_values: list of string, the list of value to write to each file path for disabling @param log_name: string, name to be shown in log message """ self.logs.append({'files': files, 'enable values': enable_values, 'disable values': disable_values, 'log name': log_name}) def __enter__(self): """Enable logs""" for log in self.logs: log_name = log['log name'] for f, ev in zip(log['files'], log['enable values']): cmdexec_with_log('echo %s > %s' % (ev, f), '%s enable' % log_name) def __exit__(self, exception_type, exception_value, traceback): """Disable logs""" for log in self.logs: log_name = log['log name'] for f, dv in zip(log['files'], log['disable values']): cmdexec_with_log('echo %s > %s' % (dv, f), '%s disable' % log_name)