test_data_symbol.sh 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. #!/bin/bash
  2. # Test data symbol (exclusive)
  3. # SPDX-License-Identifier: GPL-2.0
  4. # Leo Yan <leo.yan@linaro.org>, 2022
  5. shelldir=$(dirname "$0")
  6. # shellcheck source=lib/perf_has_symbol.sh
  7. . "${shelldir}"/lib/perf_has_symbol.sh
  8. skip_if_no_mem_event() {
  9. perf mem record -e list 2>&1 | grep -E -q 'available' && return 0
  10. return 2
  11. }
  12. skip_if_no_mem_event || exit 2
  13. skip_test_missing_symbol workload_datasym_buf1
  14. TEST_PROGRAM="perf test -w datasym"
  15. PERF_DATA=$(mktemp /tmp/__perf_test.perf.data.XXXXX)
  16. ERR_FILE=$(mktemp /tmp/__perf_test.stderr.XXXXX)
  17. check_result() {
  18. # The memory report format is as below:
  19. # 99.92% ... [.] workload_datasym_buf1+0x38
  20. result=$(perf mem report -i ${PERF_DATA} -s symbol_daddr -q 2>&1 |
  21. awk '/workload_datasym_buf1/ { print $4 }')
  22. # Testing is failed if has no any sample for "workload_datasym_buf1"
  23. [ -z "$result" ] && return 1
  24. while IFS= read -r line; do
  25. # The "data1" and "data2" fields in structure
  26. # "workload_datasym_buf1" have offset "0x0" and "0x38", returns
  27. # failure if detect any other offset value.
  28. if [ "$line" != "workload_datasym_buf1+0x0" ] && \
  29. [ "$line" != "workload_datasym_buf1+0x38" ]; then
  30. return 1
  31. fi
  32. done <<< "$result"
  33. return 0
  34. }
  35. cleanup_files()
  36. {
  37. echo "Cleaning up files..."
  38. rm -f ${PERF_DATA}
  39. }
  40. trap cleanup_files exit term int
  41. echo "Recording workload..."
  42. is_amd=$(grep -E -c 'vendor_id.*AuthenticAMD' /proc/cpuinfo)
  43. if (($is_amd >= 1)); then
  44. mem_events="$(perf mem record -v -e list 2>&1)"
  45. if ! [[ "$mem_events" =~ ^mem\-ldst.*ibs_op/(.*)/.*available ]]; then
  46. echo "ERROR: mem-ldst event is not matching"
  47. exit 1
  48. fi
  49. # --ldlat on AMD:
  50. # o Zen4 and earlier uarch does not support ldlat
  51. # o Even on supported platforms, it's disabled (--ldlat=0) by default.
  52. ldlat=${BASH_REMATCH[1]}
  53. if [[ -n $ldlat ]]; then
  54. if ! [[ "$ldlat" =~ ldlat=0 ]]; then
  55. echo "ERROR: ldlat not initialized to 0?"
  56. exit 1
  57. fi
  58. mem_events="$(perf mem record -v --ldlat=150 -e list 2>&1)"
  59. if ! [[ "$mem_events" =~ ^mem-ldst.*ibs_op/ldlat=150/.*available ]]; then
  60. echo "ERROR: --ldlat not honored?"
  61. exit 1
  62. fi
  63. fi
  64. # perf mem/c2c internally uses IBS PMU on AMD CPU which doesn't
  65. # support user/kernel filtering and per-process monitoring on older
  66. # kernels, spin program on specific CPU and test in per-CPU mode.
  67. perf mem record -vvv -o ${PERF_DATA} -C 0 -- taskset -c 0 $TEST_PROGRAM 2>"${ERR_FILE}"
  68. else
  69. perf mem record -vvv --all-user -o ${PERF_DATA} -- $TEST_PROGRAM 2>"${ERR_FILE}"
  70. fi
  71. check_result
  72. exit $?