mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

When permissions are limited running sleep without system wide isn't a good benchmark to run to achieve samples, switch to running noploop. Remove indent for non-success cases. Allow skip for the not counted case. Minor debug changes. Signed-off-by: Ian Rogers <irogers@google.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: James Clark <james.clark@linaro.org> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Kan Liang <kan.liang@linux.intel.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Weilin Wang <weilin.wang@intel.com> Link: https://lore.kernel.org/r/20250412004704.2297939-2-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
104 lines
2.2 KiB
Bash
Executable file
104 lines
2.2 KiB
Bash
Executable file
#!/bin/bash
|
|
# perf all metrics test
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
ParanoidAndNotRoot()
|
|
{
|
|
[ "$(id -u)" != 0 ] && [ "$(cat /proc/sys/kernel/perf_event_paranoid)" -gt $1 ]
|
|
}
|
|
|
|
test_prog="sleep 0.01"
|
|
system_wide_flag="-a"
|
|
if ParanoidAndNotRoot 0
|
|
then
|
|
system_wide_flag=""
|
|
test_prog="perf test -w noploop"
|
|
fi
|
|
|
|
err=0
|
|
for m in $(perf list --raw-dump metrics); do
|
|
echo "Testing $m"
|
|
result=$(perf stat -M "$m" $system_wide_flag -- $test_prog 2>&1)
|
|
result_err=$?
|
|
if [[ $result_err -eq 0 && "$result" =~ ${m:0:50} ]]
|
|
then
|
|
# No error result and metric shown.
|
|
continue
|
|
fi
|
|
if [[ "$result" =~ "Cannot resolve IDs for" ]]
|
|
then
|
|
echo "Metric contains missing events"
|
|
echo $result
|
|
err=1 # Fail
|
|
continue
|
|
elif [[ "$result" =~ \
|
|
"Access to performance monitoring and observability operations is limited" ]]
|
|
then
|
|
echo "Permission failure"
|
|
echo $result
|
|
if [[ $err -eq 0 ]]
|
|
then
|
|
err=2 # Skip
|
|
fi
|
|
continue
|
|
elif [[ "$result" =~ "in per-thread mode, enable system wide" ]]
|
|
then
|
|
echo "Permissions - need system wide mode"
|
|
echo $result
|
|
if [[ $err -eq 0 ]]
|
|
then
|
|
err=2 # Skip
|
|
fi
|
|
continue
|
|
elif [[ "$result" =~ "<not supported>" ]]
|
|
then
|
|
echo "Not supported events"
|
|
echo $result
|
|
if [[ $err -eq 0 ]]
|
|
then
|
|
err=2 # Skip
|
|
fi
|
|
continue
|
|
elif [[ "$result" =~ "<not counted>" ]]
|
|
then
|
|
echo "Not counted events"
|
|
echo $result
|
|
if [[ $err -eq 0 ]]
|
|
then
|
|
err=2 # Skip
|
|
fi
|
|
continue
|
|
elif [[ "$result" =~ "FP_ARITH" || "$result" =~ "AMX" ]]
|
|
then
|
|
echo "FP issues"
|
|
echo $result
|
|
if [[ $err -eq 0 ]]
|
|
then
|
|
err=2 # Skip
|
|
fi
|
|
continue
|
|
elif [[ "$result" =~ "PMM" ]]
|
|
then
|
|
echo "Optane memory issues"
|
|
echo $result
|
|
if [[ $err -eq 0 ]]
|
|
then
|
|
err=2 # Skip
|
|
fi
|
|
continue
|
|
fi
|
|
|
|
# Failed, possibly the workload was too small so retry with something longer.
|
|
result=$(perf stat -M "$m" $system_wide_flag -- perf bench internals synthesize 2>&1)
|
|
result_err=$?
|
|
if [[ $result_err -eq 0 && "$result" =~ ${m:0:50} ]]
|
|
then
|
|
# No error result and metric shown.
|
|
continue
|
|
fi
|
|
echo "Metric '$m' has non-zero error '$result_err' or not printed in:"
|
|
echo "$result"
|
|
err=1
|
|
done
|
|
|
|
exit "$err"
|