From 89054db9693a3157bca3980c3d80938dc7a00904 Mon Sep 17 00:00:00 2001 From: Chao Song Date: Wed, 6 Sep 2023 13:45:37 +0800 Subject: [PATCH] sof_perf_analyzer: add skip-to-first-trace option In CI test, some traces from previous test case will apprear in the mtrace of current test case, this is a know issue. Previously, we always skip to the first valid trace of this test case, this could raise trouble for developer use of this script. This patch adds skip-to-first-trace option, for CI test, this option should be set (True), and for developer use, this option should be left as it is (False). Signed-off-by: Chao Song --- tools/sof_perf_analyzer.py | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/tools/sof_perf_analyzer.py b/tools/sof_perf_analyzer.py index 2ea231d3..609cdf21 100755 --- a/tools/sof_perf_analyzer.py +++ b/tools/sof_perf_analyzer.py @@ -120,15 +120,11 @@ def skip_to_first_trace(trace_item_gen: TraceItemGenerator) -> Optional[TraceIte test case due to mtrace is configured in deferred mode. This function consumes those traces from the generator, and return the first trace item of current test. ''' - try: - while item := next(trace_item_gen): - # On test running, the SOF firmware is reloaded to DSP, timer is reset to 0. - # The first trace must have a timestamp with integral part equals to 0. - if int(item.timestamp) == 0: - return item - except StopIteration: - return None - return None + while item := next(trace_item_gen): + # On test running, the SOF firmware is reloaded to DSP, timer is reset to 0. + # The first trace must have a timestamp with integral part equals to 0. + if int(item.timestamp) == 0: + return item def make_trace_item(fileio: TextIO) -> TraceItemGenerator: '''Filter and parse a line of trace in string form into TraceItem object, for example: @@ -169,8 +165,13 @@ def process_trace_file(): '''The top-level caller for processing the trace file''' with open(args.filename, 'r', encoding='utf8') as file: trace_item_gen = make_trace_item(file) - trace_prev = skip_to_first_trace(trace_item_gen) - if trace_prev is None: + trace_prev = None + try: + if args.skip_to_first_trace: + trace_prev = skip_to_first_trace(trace_item_gen) + else: + trace_prev = next(trace_item_gen) + except: raise Exception('No valid trace in provided file') for trace_curr in trace_item_gen: # pylint: disable=W0603 @@ -295,6 +296,10 @@ def parse_args(): help='Kernel message file captured with journalctl or other log utility') parser.add_argument('--out2csv', type=pathlib.Path, required=False, help='Output SOF performance statistics to csv file') + parser.add_argument('-s', '--skip-to-first-trace', action="store_true", default=False, + help='''In CI test, some traces from previous test case will apprear in +the mtrace of current test case, this flag is used to denote if we +want to skip those traces, for CI test, set the flag to True''') return parser.parse_args()