| #!/bin/bash |
| # perf script perl tests |
| # SPDX-License-Identifier: GPL-2.0 |
| |
| set -e |
| |
| # set PERF_EXEC_PATH to find scripts in the source directory |
| perfdir=$(dirname "$0")/../.. |
| if [ -e "$perfdir/scripts/perl/Perf-Trace-Util" ]; then |
| export PERF_EXEC_PATH=$perfdir |
| fi |
| |
| |
| perfdata=$(mktemp /tmp/__perf_test_script_perl.perf.data.XXXXX) |
| generated_script=$(mktemp /tmp/__perf_test_script.XXXXX.pl) |
| |
| cleanup() { |
| rm -f "${perfdata}" |
| rm -f "${generated_script}" |
| trap - EXIT TERM INT |
| } |
| |
| trap_cleanup() { |
| echo "Unexpected signal in ${FUNCNAME[1]}" |
| cleanup |
| exit 1 |
| } |
| trap trap_cleanup TERM INT |
| trap cleanup EXIT |
| |
| check_perl_support() { |
| if perf check feature -q libperl; then |
| return 0 |
| fi |
| echo "perf script perl test [Skipped: no libperl support]" |
| return 2 |
| } |
| |
| test_script() { |
| local event_name=$1 |
| local expected_output=$2 |
| local record_opts=$3 |
| |
| echo "Testing event: $event_name" |
| |
| # Try to record. If this fails, it might be permissions or lack of support. |
| # We return 2 to indicate "skip this event" rather than "fail test". |
| if ! perf record -o "${perfdata}" -e "$event_name" $record_opts -- perf test -w thloop > /dev/null 2>&1; then |
| echo "perf script perl test [Skipped: failed to record $event_name]" |
| return 2 |
| fi |
| |
| echo "Generating perl script..." |
| if ! perf script -i "${perfdata}" -g "${generated_script}"; then |
| echo "perf script perl test [Failed: script generation for $event_name]" |
| return 1 |
| fi |
| |
| if [ ! -f "${generated_script}" ]; then |
| echo "perf script perl test [Failed: script not generated for $event_name]" |
| return 1 |
| fi |
| |
| echo "Executing perl script..." |
| output=$(perf script -i "${perfdata}" -s "${generated_script}" 2>&1) |
| |
| if echo "$output" | grep -q "$expected_output"; then |
| echo "perf script perl test [Success: $event_name triggered $expected_output]" |
| return 0 |
| else |
| echo "perf script perl test [Failed: $event_name did not trigger $expected_output]" |
| echo "Output was:" |
| echo "$output" | head -n 20 |
| return 1 |
| fi |
| } |
| |
| check_perl_support || exit 2 |
| |
| # Try tracepoint first |
| test_script "sched:sched_switch" "sched::sched_switch" "-c 1" && res=0 || res=$? |
| |
| if [ $res -eq 0 ]; then |
| exit 0 |
| elif [ $res -eq 1 ]; then |
| exit 1 |
| fi |
| |
| # If tracepoint skipped (res=2), try task-clock |
| # For generic events like task-clock, the generated script uses process_event() |
| # which dumps data using Data::Dumper. We check for "$VAR1" which is standard Dumper output. |
| test_script "task-clock" "\$VAR1" "-c 100" && res=0 || res=$? |
| |
| if [ $res -eq 0 ]; then |
| exit 0 |
| elif [ $res -eq 1 ]; then |
| exit 1 |
| fi |
| |
| # If both skipped |
| echo "perf script perl test [Skipped: Could not record tracepoint or task-clock]" |
| exit 2 |