evlist.sh 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. #!/bin/bash
  2. # perf evlist tests
  3. # SPDX-License-Identifier: GPL-2.0
  4. set -e
  5. err=0
  6. perfdata=$(mktemp /tmp/__perf_test.perf.data.XXXXX)
  7. cleanup() {
  8. rm -f "${perfdata}"
  9. trap - EXIT TERM INT
  10. }
  11. trap_cleanup() {
  12. echo "Unexpected signal in ${FUNCNAME[1]}"
  13. cleanup
  14. exit 1
  15. }
  16. trap trap_cleanup EXIT TERM INT
  17. test_evlist_simple() {
  18. echo "Simple evlist test"
  19. if ! perf record -e cpu-clock -o "${perfdata}" true 2> /dev/null
  20. then
  21. echo "Simple evlist [Failed record]"
  22. err=1
  23. return
  24. fi
  25. if ! perf evlist -i "${perfdata}" | grep -q "cpu-clock"
  26. then
  27. echo "Simple evlist [Failed to list event]"
  28. err=1
  29. return
  30. fi
  31. echo "Simple evlist test [Success]"
  32. }
  33. test_evlist_group() {
  34. echo "Group evlist test"
  35. if ! perf record -e "{cpu-clock,task-clock}" -o "${perfdata}" \
  36. -- perf test -w noploop 2> /dev/null
  37. then
  38. echo "Group evlist [Skipped event group recording failed]"
  39. return
  40. fi
  41. if ! perf evlist -i "${perfdata}" -g | grep -q "{.*cpu-clock.*,.*task-clock.*}"
  42. then
  43. echo "Group evlist [Failed to list event group]"
  44. err=1
  45. return
  46. fi
  47. echo "Group evlist test [Success]"
  48. }
  49. test_evlist_verbose() {
  50. echo "Event configuration evlist test"
  51. if ! perf record -e cycles -o "${perfdata}" true 2> /dev/null
  52. then
  53. echo "Event configuration evlist [Failed record]"
  54. err=1
  55. return
  56. fi
  57. if ! perf evlist -i "${perfdata}" -v | grep -q "config:"
  58. then
  59. echo "Event configuration evlist [Failed to list verbose info]"
  60. err=1
  61. return
  62. fi
  63. echo "Event configuration evlist test [Success]"
  64. }
  65. test_evlist_simple
  66. test_evlist_group
  67. test_evlist_verbose
  68. cleanup
  69. exit $err