test_arm_callgraph_fp.sh 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. #!/bin/bash
  2. # Check Arm64 callgraphs are complete in fp mode
  3. # SPDX-License-Identifier: GPL-2.0
  4. shelldir=$(dirname "$0")
  5. # shellcheck source=lib/perf_has_symbol.sh
  6. . "${shelldir}"/lib/perf_has_symbol.sh
  7. if [ "$(uname -m)" != "aarch64" ]; then
  8. exit 2
  9. fi
  10. if perf version --build-options | grep HAVE_DWARF_UNWIND_SUPPORT | grep -q OFF
  11. then
  12. echo "Skipping, no dwarf unwind support"
  13. exit 2
  14. fi
  15. skip_test_missing_symbol leafloop
  16. PERF_DATA=$(mktemp /tmp/__perf_test.perf.data.XXXXX)
  17. TEST_PROGRAM="perf test -w leafloop"
  18. cleanup_files()
  19. {
  20. rm -f "$PERF_DATA"
  21. }
  22. trap cleanup_files EXIT TERM INT
  23. # shellcheck disable=SC2086
  24. perf record -o "$PERF_DATA" --call-graph fp -e cycles//u --user-callchains -- $TEST_PROGRAM
  25. # Try opening the file so any immediate errors are visible in the log
  26. perf script -i "$PERF_DATA" -F comm,ip,sym | head -n4
  27. # expected perf-script output if 'leaf' has been inserted correctly:
  28. #
  29. # perf
  30. # 728 leaf
  31. # 753 parent
  32. # 76c leafloop
  33. # ... remaining stack to main() ...
  34. # Each frame is separated by a tab, some spaces and an address
  35. SEP="[[:space:]]+ [[:xdigit:]]+"
  36. perf script -i "$PERF_DATA" -F comm,ip,sym | tr '\n' ' ' | \
  37. grep -E -q "perf $SEP leaf $SEP parent $SEP leafloop"