linux/tools/perf/tests/shell/trace_btf_enum.sh
Nam Cao 244132c4e5 tracing/timers: Rename the hrtimer_init event to hrtimer_setup
The function hrtimer_init() doesn't exist anymore. It was replaced by
hrtimer_setup().

Thus, rename the hrtimer_init trace event to hrtimer_setup to keep it
consistent.

Signed-off-by: Nam Cao <namcao@linutronix.de>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Link: https://lore.kernel.org/all/cba84c3d853c5258aa3a262363a6eac08e2c7afc.1738746927.git.namcao@linutronix.de
2025-04-05 10:30:17 +02:00

67 lines
1.4 KiB
Bash
Executable file

#!/bin/sh
# perf trace enum augmentation tests
# SPDX-License-Identifier: GPL-2.0
err=0
set -e
syscall="landlock_add_rule"
non_syscall="timer:hrtimer_setup,timer:hrtimer_start"
TESTPROG="perf test -w landlock"
# shellcheck source=lib/probe.sh
. "$(dirname $0)"/lib/probe.sh
skip_if_no_perf_trace || exit 2
[ "$(id -u)" = 0 ] || exit 2
check_vmlinux() {
echo "Checking if vmlinux exists"
if ! ls /sys/kernel/btf/vmlinux 1>/dev/null 2>&1
then
echo "trace+enum test [Skipped missing vmlinux BTF support]"
err=2
fi
}
trace_landlock() {
echo "Tracing syscall ${syscall}"
# test flight just to see if landlock_add_rule is available
if ! perf trace $TESTPROG 2>&1 | grep -q landlock
then
echo "No landlock system call found, skipping to non-syscall tracing."
return
fi
if perf trace -e $syscall $TESTPROG 2>&1 | \
grep -q -E ".*landlock_add_rule\(ruleset_fd: 11, rule_type: (LANDLOCK_RULE_PATH_BENEATH|LANDLOCK_RULE_NET_PORT), rule_attr: 0x[a-f0-9]+, flags: 45\) = -1.*"
then
err=0
else
err=1
fi
}
trace_non_syscall() {
echo "Tracing non-syscall tracepoint ${non-syscall}"
if perf trace -e $non_syscall --max-events=1 2>&1 | \
grep -q -E '.*timer:hrtimer_.*\(.*mode: HRTIMER_MODE_.*\)$'
then
err=0
else
err=1
fi
}
check_vmlinux
if [ $err = 0 ]; then
trace_landlock
fi
if [ $err = 0 ]; then
trace_non_syscall
fi
exit $err