2022-07-07 08:34:49 -07:00
|
|
|
#!/bin/bash
|
2021-09-17 11:42:39 -07:00
|
|
|
# perf all metrics test
|
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
|
2024-10-18 13:43:06 -07:00
|
|
|
ParanoidAndNotRoot()
|
|
|
|
{
|
|
|
|
[ "$(id -u)" != 0 ] && [ "$(cat /proc/sys/kernel/perf_event_paranoid)" -gt $1 ]
|
|
|
|
}
|
|
|
|
|
2025-04-11 17:47:04 -07:00
|
|
|
test_prog="sleep 0.01"
|
2024-10-18 13:43:06 -07:00
|
|
|
system_wide_flag="-a"
|
|
|
|
if ParanoidAndNotRoot 0
|
|
|
|
then
|
|
|
|
system_wide_flag=""
|
2025-04-11 17:47:04 -07:00
|
|
|
test_prog="perf test -w noploop"
|
2024-10-18 13:43:06 -07:00
|
|
|
fi
|
|
|
|
|
2022-01-31 17:58:33 -08:00
|
|
|
err=0
|
2021-09-17 11:42:39 -07:00
|
|
|
for m in $(perf list --raw-dump metrics); do
|
|
|
|
echo "Testing $m"
|
2025-04-11 17:47:04 -07:00
|
|
|
result=$(perf stat -M "$m" $system_wide_flag -- $test_prog 2>&1)
|
2024-10-18 13:43:06 -07:00
|
|
|
result_err=$?
|
2025-04-11 17:47:04 -07:00
|
|
|
if [[ $result_err -eq 0 && "$result" =~ ${m:0:50} ]]
|
2022-07-07 08:34:49 -07:00
|
|
|
then
|
2025-04-11 17:47:04 -07:00
|
|
|
# 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 ]]
|
2024-10-18 13:43:06 -07:00
|
|
|
then
|
2025-04-11 17:47:04 -07:00
|
|
|
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 ]]
|
2024-10-18 13:43:06 -07:00
|
|
|
then
|
2025-04-11 17:47:04 -07:00
|
|
|
err=2 # Skip
|
|
|
|
fi
|
|
|
|
continue
|
|
|
|
elif [[ "$result" =~ "<not supported>" ]]
|
|
|
|
then
|
|
|
|
echo "Not supported events"
|
|
|
|
echo $result
|
|
|
|
if [[ $err -eq 0 ]]
|
2024-10-18 13:43:06 -07:00
|
|
|
then
|
2025-04-11 17:47:04 -07:00
|
|
|
err=2 # Skip
|
|
|
|
fi
|
|
|
|
continue
|
|
|
|
elif [[ "$result" =~ "<not counted>" ]]
|
|
|
|
then
|
|
|
|
echo "Not counted events"
|
|
|
|
echo $result
|
|
|
|
if [[ $err -eq 0 ]]
|
2024-10-18 13:43:06 -07:00
|
|
|
then
|
2025-04-11 17:47:04 -07:00
|
|
|
err=2 # Skip
|
|
|
|
fi
|
|
|
|
continue
|
|
|
|
elif [[ "$result" =~ "FP_ARITH" || "$result" =~ "AMX" ]]
|
|
|
|
then
|
|
|
|
echo "FP issues"
|
|
|
|
echo $result
|
|
|
|
if [[ $err -eq 0 ]]
|
2024-10-18 13:43:06 -07:00
|
|
|
then
|
2025-04-11 17:47:04 -07:00
|
|
|
err=2 # Skip
|
2024-10-18 13:43:06 -07:00
|
|
|
fi
|
2025-04-11 17:47:04 -07:00
|
|
|
continue
|
|
|
|
elif [[ "$result" =~ "PMM" ]]
|
2022-07-07 08:34:49 -07:00
|
|
|
then
|
2025-04-11 17:47:04 -07:00
|
|
|
echo "Optane memory issues"
|
|
|
|
echo $result
|
|
|
|
if [[ $err -eq 0 ]]
|
|
|
|
then
|
|
|
|
err=2 # Skip
|
|
|
|
fi
|
2022-07-07 08:34:49 -07:00
|
|
|
continue
|
|
|
|
fi
|
2024-10-18 13:43:06 -07:00
|
|
|
|
|
|
|
# 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)
|
2025-04-11 17:47:04 -07:00
|
|
|
result_err=$?
|
|
|
|
if [[ $result_err -eq 0 && "$result" =~ ${m:0:50} ]]
|
2022-07-07 08:34:49 -07:00
|
|
|
then
|
2025-04-11 17:47:04 -07:00
|
|
|
# No error result and metric shown.
|
2022-07-07 08:34:49 -07:00
|
|
|
continue
|
|
|
|
fi
|
2025-04-11 17:47:04 -07:00
|
|
|
echo "Metric '$m' has non-zero error '$result_err' or not printed in:"
|
2022-07-07 08:34:49 -07:00
|
|
|
echo "$result"
|
2024-10-18 13:43:06 -07:00
|
|
|
err=1
|
2021-09-17 11:42:39 -07:00
|
|
|
done
|
|
|
|
|
2022-01-31 17:58:33 -08:00
|
|
|
exit "$err"
|