Merge patch series "Add 'trace wipe'"

Jerome Forissier <jerome.forissier@linaro.org> says:

This short series adds the 'trace wipe' command which clears the trace
buffer, allowing to re-start a capture from scratch.

Link: https://lore.kernel.org/r/cover.1734093566.git.jerome.forissier@linaro.org
This commit is contained in:
Tom Rini
2024-12-31 19:00:54 -06:00
5 changed files with 81 additions and 14 deletions

View File

@@ -70,6 +70,32 @@ def collect_trace(cons):
return fname, int(dm_f_time[0])
def wipe_and_collect_trace(cons):
"""Pause and wipe traces, return the number of calls (should be zero)
Args:
cons (ConsoleBase): U-Boot console
Returns:
int: the number of traced function calls reported by 'trace stats'
"""
cons.run_command('trace pause')
cons.run_command('trace wipe')
out = cons.run_command('trace stats')
# The output is something like this:
# 117,221 function sites
# 0 function calls
# 0 untracked function calls
# 0 traced function calls
# Get a dict of values from the output
lines = [line.split(maxsplit=1) for line in out.splitlines() if line]
vals = {key: val.replace(',', '') for val, key in lines}
return int(vals['traced function calls'])
def check_function(cons, fname, proftool, map_fname, trace_dat):
"""Check that the 'function' output works
@@ -304,3 +330,7 @@ def test_trace(u_boot_console):
# This allows for CI being slow to run
diff = abs(fg_time - dm_f_time)
assert diff / dm_f_time < 0.3
# Check that the trace buffer can be wiped
numcalls = wipe_and_collect_trace(cons)
assert numcalls == 0