| #!/bin/bash |
| # perf trace enum augmentation tests |
| # SPDX-License-Identifier: GPL-2.0 |
| |
| err=0 |
| |
| syscall="landlock_add_rule" |
| non_syscall="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 [ ! -f /sys/kernel/btf/vmlinux ] |
| 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 |
| |
| output="$(perf trace -e $syscall $TESTPROG 2>&1)" |
| if echo "$output" | 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 |
| printf "[syscall failure] Failed to trace syscall $syscall, output:\n$output\n" |
| err=1 |
| fi |
| } |
| |
| trace_non_syscall() { |
| echo "Tracing non-syscall tracepoint ${non_syscall}" |
| output="$(perf trace -e $non_syscall --max-events=1 2>&1)" |
| if echo "$output" | grep -q -E '.*timer:hrtimer_.*\(.*mode: HRTIMER_MODE_.*\)$' |
| then |
| err=0 |
| else |
| printf "[tracepoint failure] Failed to trace tracepoint $non_syscall, output:\n$output\n" |
| err=1 |
| fi |
| } |
| |
| check_vmlinux |
| |
| if [ $err = 0 ]; then |
| trace_landlock |
| fi |
| |
| if [ $err = 0 ]; then |
| trace_non_syscall |
| fi |
| |
| exit $err |