blob: 572001d75d781562d69e08ed492924629050e4b0 (
plain)
| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
 | #!/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
 |