[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <00441b6d-176f-4dd4-862d-08d414dfec66@linux.ibm.com>
Date: Mon, 30 Jun 2025 09:52:21 +0200
From: Thomas Richter <tmricht@...ux.ibm.com>
To: Ian Rogers <irogers@...gle.com>, Peter Zijlstra <peterz@...radead.org>,
Ingo Molnar <mingo@...hat.com>,
Arnaldo Carvalho de Melo <acme@...nel.org>,
Namhyung Kim <namhyung@...nel.org>,
Mark Rutland <mark.rutland@....com>,
Alexander Shishkin <alexander.shishkin@...ux.intel.com>,
Jiri Olsa <jolsa@...nel.org>, Adrian Hunter <adrian.hunter@...el.com>,
Kan Liang <kan.liang@...ux.intel.com>,
James Clark <james.clark@...aro.org>, linux-perf-users@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH v1] perf test annotate: Use --percent-limit rather than
head to reduce output
On 6/28/25 03:58, Ian Rogers wrote:
> The annotate test was sped up by Thomas Richter
> <tmricht@...ux.ibm.com> in commit
> 658a8805cb60 ("perf test: Speed up test case 70 annotate basic tests")
> by reducing the annotate output using head. This causes flakes on
> hybrid machines where the first event dumped may not have the samples
> for the test within it. Rather than reduce the output using `head`
> switch to `--percent-limit 10` which will stop annotate dumping
> functions that have an overhead of less than 10%, the noploop program
> should be using more.
>
> Add the missing objdump option for the pipe mode version of the
> objdump with a command test.
>
> Signed-off-by: Ian Rogers <irogers@...gle.com>
> ---
> tools/perf/tests/shell/annotate.sh | 15 ++++++++-------
> 1 file changed, 8 insertions(+), 7 deletions(-)
>
> diff --git a/tools/perf/tests/shell/annotate.sh b/tools/perf/tests/shell/annotate.sh
> index 16a1ccd06089..689de58e9238 100755
> --- a/tools/perf/tests/shell/annotate.sh
> +++ b/tools/perf/tests/shell/annotate.sh
> @@ -53,21 +53,22 @@ test_basic() {
> # Generate the annotated output file
> if [ "x${mode}" == "xBasic" ]
> then
> - perf annotate --no-demangle -i "${perfdata}" --stdio 2> /dev/null > "${perfout}"
> + perf annotate --no-demangle -i "${perfdata}" --stdio --percent-limit 10 2> /dev/null > "${perfout}"
> else
> - perf annotate --no-demangle -i - --stdio 2> /dev/null < "${perfdata}" > "${perfout}"
> + perf annotate --no-demangle -i - --stdio 2> /dev/null --percent-limit 10 < "${perfdata}" > "${perfout}"
> fi
>
> # check if it has the target symbol
> - if ! head -250 "${perfout}" | grep -q "${testsym}"
> + if ! grep -q "${testsym}" "${perfout}"
> then
> echo "${mode} annotate [Failed: missing target symbol]"
> + cat "${perfout}"
> err=1
> return
> fi
>
> # check if it has the disassembly lines
> - if ! head -250 "${perfout}" | grep -q "${disasm_regex}"
> + if ! grep -q "${disasm_regex}" "${perfout}"
> then
> echo "${mode} annotate [Failed: missing disasm output from default disassembler]"
> err=1
> @@ -92,11 +93,11 @@ test_basic() {
> # check one more with external objdump tool (forced by --objdump option)
> if [ "x${mode}" == "xBasic" ]
> then
> - perf annotate --no-demangle -i "${perfdata}" --objdump=objdump 2> /dev/null > "${perfout}"
> + perf annotate --no-demangle -i "${perfdata}" --percent-limit 10 --objdump=objdump 2> /dev/null > "${perfout}"
> else
> - perf annotate --no-demangle -i - "${testsym}" 2> /dev/null < "${perfdata}" > "${perfout}"
> + perf annotate --no-demangle -i - "${testsym}" --percent-limit 10 --objdump=objdump 2> /dev/null < "${perfdata}" > "${perfout}"
> fi
> - if ! head -250 "${perfout}" | grep -q -m 3 "${disasm_regex}"
> + if ! grep -q -m 3 "${disasm_regex}" "${perfout}"
> then
> echo "${mode} annotate [Failed: missing disasm output from non default disassembler (using --objdump)]"
> err=1
Works ok on s390
Tested-by: Thomas Richter <tmricht@...ux.ibm.com>
--
Thomas Richter, Dept 3303, IBM s390 Linux Development, Boeblingen, Germany
--
IBM Deutschland Research & Development GmbH
Vorsitzender des Aufsichtsrats: Wolfgang Wendt
Geschäftsführung: David Faller
Sitz der Gesellschaft: Böblingen / Registergericht: Amtsgericht Stuttgart, HRB 243294
Powered by blists - more mailing lists