Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

perf test: Add a shell test for 'perf stat --bpf-counters' new option

Add a test to compare the output of perf-stat with and without option
--bpf-counters. If the difference is more than 10%, the test is considered
as failed.

Committer testing:

# perf test bpf-counters
86: perf stat --bpf-counters test : Ok
# perf test -v bpf-counters
86: perf stat --bpf-counters test :
--- start ---
test child forked, pid 2433339
test child finished with 0
---- end ----
perf stat --bpf-counters test: Ok
#

Signed-off-by: Song Liu <songliubraving@fb.com>
Requested-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Acked-by: Namhyung Kim <namhyung@kernel.org>
Cc: Jiri Olsa <jolsa@redhat.com>
Link: http://lore.kernel.org/lkml/EC00E37D-8587-4662-8E30-7AD5F874FA84@fb.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>

authored by

Song Liu and committed by
Arnaldo Carvalho de Melo
2c0cb9f5 435b46ef

+31
+31
tools/perf/tests/shell/stat_bpf_counters.sh
··· 1 + #!/bin/sh 2 + # perf stat --bpf-counters test 3 + # SPDX-License-Identifier: GPL-2.0 4 + 5 + set -e 6 + 7 + # check whether $2 is within +/- 10% of $1 8 + compare_number() 9 + { 10 + first_num=$1 11 + second_num=$2 12 + 13 + # upper bound is first_num * 110% 14 + upper=$(( $first_num + $first_num / 10 )) 15 + # lower bound is first_num * 90% 16 + lower=$(( $first_num - $first_num / 10 )) 17 + 18 + if [ $second_num -gt $upper ] || [ $second_num -lt $lower ]; then 19 + echo "The difference between $first_num and $second_num are greater than 10%." 20 + exit 1 21 + fi 22 + } 23 + 24 + # skip if --bpf-counters is not supported 25 + perf stat --bpf-counters true > /dev/null 2>&1 || exit 2 26 + 27 + base_cycles=$(perf stat --no-big-num -e cycles -- perf bench sched messaging -g 1 -l 100 -t 2>&1 | awk '/cycles/ {print $1}') 28 + bpf_cycles=$(perf stat --no-big-num --bpf-counters -e cycles -- perf bench sched messaging -g 1 -l 100 -t 2>&1 | awk '/cycles/ {print $1}') 29 + 30 + compare_number $base_cycles $bpf_cycles 31 + exit 0