mirror of
https://github.com/ARM-software/workload-automation.git
synced 2025-01-18 12:06:08 +00:00
perf: Fix processing simpleperf stats
Currently, when processing the output of 'simpleperf stat', wa does not skip the header and tries to process part of it as a number, leading to type errors. This change skips the header (line starting with '#'). Furthermore, some events (e.g. cpu-clock or task-clock) include "(ms)" in their count value and are floats instead of integers. Because of this, when either of those is included, processing metrics fails due to assuming every metric is an integer. Then another error happens when the code tries to split the line on '(' assuming that there's only one set of those around the percentage. This change removes "(ms)" from the line before it's processed and properly determines whether 'count' is an integer or a float before attempting to convert it.
This commit is contained in:
parent
b109acac05
commit
b0f9072830
@ -267,15 +267,19 @@ class PerfInstrument(Instrument):
|
||||
def _process_simpleperf_stat_from_raw(stat_file, context, label):
|
||||
with open(stat_file) as fh:
|
||||
for line in fh:
|
||||
if '#' in line:
|
||||
if '#' in line and not line.startswith('#'):
|
||||
units = 'count'
|
||||
if "(ms)" in line:
|
||||
line = line.replace("(ms)", "")
|
||||
units = 'ms'
|
||||
tmp_line = line.split('#')[0]
|
||||
tmp_line = line.strip()
|
||||
count, metric = tmp_line.split(' ')[0], tmp_line.split(' ')[2]
|
||||
count = int(count.replace(',', ''))
|
||||
count = float(count) if "." in count else int(count.replace(',', ''))
|
||||
scaled_percentage = line.split('(')[1].strip().replace(')', '').replace('%', '')
|
||||
scaled_percentage = int(scaled_percentage)
|
||||
metric = '{}_{}'.format(label, metric)
|
||||
context.add_metric(metric, count, 'count', classifiers={'scaled from(%)': scaled_percentage})
|
||||
context.add_metric(metric, count, units, classifiers={'scaled from(%)': scaled_percentage})
|
||||
|
||||
def _process_simpleperf_record_output(self, context):
|
||||
for host_file in os.listdir(self.outdir):
|
||||
|
Loading…
Reference in New Issue
Block a user