Files
linux/tools/perf/tests/shell/stat_all_metrics.sh
Ian Rogers 08d9e88348 perf test stat_all_metrics: Ensure missing events fail test
Issue reported by Thomas Falcon and diagnosed by Kan Liang here:
https://lore.kernel.org/lkml/d44036481022c27d83ce0faf8c7f77042baedb34.camel@intel.com/
Metrics with missing events can be erroneously skipped if they contain
FP, AMX or PMM events.

Signed-off-by: Ian Rogers <irogers@google.com>
Acked-by: Kan Liang <kan.liang@linux.intel.com>
Tested-by: Thomas Falcon <thomas.falcon@intel.com>
Link: https://lore.kernel.org/r/20250211213031.114209-25-irogers@google.com
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
2025-02-12 19:54:40 -08:00

95 lines
2.0 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 ]
}
system_wide_flag="-a"
if ParanoidAndNotRoot 0
then
system_wide_flag=""
fi
err=0
for m in $(perf list --raw-dump metrics); do
echo "Testing $m"
result=$(perf stat -M "$m" $system_wide_flag -- sleep 0.01 2>&1)
result_err=$?
if [[ $result_err -gt 0 ]]
then
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" =~ "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
fi
if [[ "$result" =~ ${m:0:50} ]]
then
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)
if [[ "$result" =~ ${m:0:50} ]]
then
continue
fi
echo "Metric '$m' not printed in:"
echo "$result"
err=1
done
exit "$err"