stat_all_metrics.sh 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. #!/bin/bash
  2. # perf all metrics test
  3. # SPDX-License-Identifier: GPL-2.0
  4. ParanoidAndNotRoot()
  5. {
  6. [ "$(id -u)" != 0 ] && [ "$(cat /proc/sys/kernel/perf_event_paranoid)" -gt $1 ]
  7. }
  8. test_prog="sleep 0.01"
  9. system_wide_flag="-a"
  10. if ParanoidAndNotRoot 0
  11. then
  12. system_wide_flag=""
  13. test_prog="perf test -w noploop"
  14. fi
  15. skip=0
  16. err=3
  17. for m in $(perf list --raw-dump metrics); do
  18. echo "Testing $m"
  19. result=$(perf stat -M "$m" $system_wide_flag -- $test_prog 2>&1)
  20. result_err=$?
  21. if [[ $result_err -eq 0 && "$result" =~ ${m:0:50} ]]
  22. then
  23. # No error result and metric shown.
  24. if [[ "$err" -ne 1 ]]
  25. then
  26. err=0
  27. fi
  28. continue
  29. fi
  30. if [[ "$result" =~ "Cannot resolve IDs for" || "$result" =~ "No supported events found" ]]
  31. then
  32. if [[ $(perf list --raw-dump $m) == "Default"* ]]
  33. then
  34. echo "[Ignored $m] failed but as a Default metric this can be expected"
  35. echo $result
  36. continue
  37. fi
  38. echo "[Failed $m] Metric contains missing events"
  39. echo $result
  40. err=1 # Fail
  41. continue
  42. elif [[ "$result" =~ \
  43. "Access to performance monitoring and observability operations is limited" ]]
  44. then
  45. echo "[Skipped $m] Permission failure"
  46. echo $result
  47. if [[ $err -eq 0 ]]
  48. then
  49. skip=1
  50. fi
  51. continue
  52. elif [[ "$result" =~ "in per-thread mode, enable system wide" ]]
  53. then
  54. echo "[Skipped $m] Permissions - need system wide mode"
  55. echo $result
  56. if [[ $err -eq 0 ]]
  57. then
  58. skip=1
  59. fi
  60. continue
  61. elif [[ "$result" =~ "<not supported>" ]]
  62. then
  63. if [[ $(perf list --raw-dump $m) == "Default"* ]]
  64. then
  65. echo "[Ignored $m] failed but as a Default metric this can be expected"
  66. echo $result
  67. continue
  68. fi
  69. echo "[Skipped $m] Not supported events"
  70. echo $result
  71. if [[ $err -eq 0 ]]
  72. then
  73. skip=1
  74. fi
  75. continue
  76. elif [[ "$result" =~ "<not counted>" ]]
  77. then
  78. echo "[Skipped $m] Not counted events"
  79. echo $result
  80. if [[ $err -eq 0 ]]
  81. then
  82. skip=1
  83. fi
  84. continue
  85. elif [[ "$result" =~ "FP_ARITH" || "$result" =~ "AMX" ]]
  86. then
  87. echo "[Skipped $m] FP issues"
  88. echo $result
  89. if [[ $err -eq 0 ]]
  90. then
  91. skip=1
  92. fi
  93. continue
  94. elif [[ "$result" =~ "PMM" ]]
  95. then
  96. echo "[Skipped $m] Optane memory issues"
  97. echo $result
  98. if [[ $err -eq 0 ]]
  99. then
  100. skip=1
  101. fi
  102. continue
  103. fi
  104. # Failed, possibly the workload was too small so retry with something longer.
  105. result=$(perf stat -M "$m" $system_wide_flag -- perf bench internals synthesize 2>&1)
  106. result_err=$?
  107. if [[ $result_err -eq 0 && "$result" =~ ${m:0:50} ]]
  108. then
  109. # No error result and metric shown.
  110. if [[ "$err" -ne 1 ]]
  111. then
  112. err=0
  113. fi
  114. continue
  115. fi
  116. echo "[Failed $m] has non-zero error '$result_err' or not printed in:"
  117. echo "$result"
  118. err=1
  119. done
  120. # return SKIP only if no success returned
  121. if [[ "$err" -eq 3 && "$skip" -eq 1 ]]
  122. then
  123. err=2
  124. fi
  125. exit "$err"