mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-20 08:42:06 +00:00
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>
95 lines
2.0 KiB
Bash
Executable File
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"
|