Skip to content

Commit

Permalink
selftests: ftrace: Add a testcase for string type with kprobe_event
Browse files Browse the repository at this point in the history
Add a testcase for string type with kprobe event.
This tests good/bad syntax combinations and also
the traced data is correct in several way.

Link: http://lkml.kernel.org/r/152129038381.31874.9201387794548737554.stgit@devbox

Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
  • Loading branch information
Masami Hiramatsu authored and Steven Rostedt (VMware) committed Mar 23, 2018
1 parent 871bef2 commit 5fbdbed
Showing 1 changed file with 46 additions and 0 deletions.
46 changes: 46 additions & 0 deletions tools/testing/selftests/ftrace/test.d/kprobe/kprobe_args_string.tc
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
#!/bin/sh
# SPDX-License-Identifier: GPL-2.0
# description: Kprobe event string type argument

[ -f kprobe_events ] || exit_unsupported # this is configurable

echo 0 > events/enable
echo > kprobe_events

case `uname -m` in
x86_64)
ARG2=%si
OFFS=8
;;
i[3456]86)
ARG2=%cx
OFFS=4
;;
aarch64)
ARG2=%x1
OFFS=8
;;
arm*)
ARG2=%r1
OFFS=4
;;
*)
echo "Please implement other architecture here"
exit_untested
esac

: "Test get argument (1)"
echo "p:testprobe create_trace_kprobe arg1=+0(+0(${ARG2})):string" > kprobe_events
echo 1 > events/kprobes/testprobe/enable
! echo test >> kprobe_events
tail -n 1 trace | grep -qe "testprobe.* arg1=\"test\""

echo 0 > events/kprobes/testprobe/enable
: "Test get argument (2)"
echo "p:testprobe create_trace_kprobe arg1=+0(+0(${ARG2})):string arg2=+0(+${OFFS}(${ARG2})):string" > kprobe_events
echo 1 > events/kprobes/testprobe/enable
! echo test1 test2 >> kprobe_events
tail -n 1 trace | grep -qe "testprobe.* arg1=\"test1\" arg2=\"test2\""

echo 0 > events/enable
echo > kprobe_events

0 comments on commit 5fbdbed

Please sign in to comment.