mirror of
https://github.com/brain-hackers/linux-brain.git
synced 2024-06-09 23:36:23 +09:00
d12d7bf92b
[ Upstream commit f0c0d0cf590f71b2213b29a7ded2cde3d0a1a0ba ] It is possible to get multiple records from trace during test and then more than 4 arguments are assigned to ARGS. This situation results in the failure of kprobe_args_type.tc. For example: ----------------------------------------------------------- grep testprobe trace ftracetest-5902 [001] d... 111195.682227: testprobe: (_do_fork+0x0/0x460) arg1=334823024 arg2=334823024 arg3=0x13f4fe70 arg4=7 pmlogger-5949 [000] d... 111195.709898: testprobe: (_do_fork+0x0/0x460) arg1=345308784 arg2=345308784 arg3=0x1494fe70 arg4=7 grep testprobe trace sed -e 's/.* arg1=\(.*\) arg2=\(.*\) arg3=\(.*\) arg4=\(.*\)/\1 \2 \3 \4/' ARGS='334823024 334823024 0x13f4fe70 7 345308784 345308784 0x1494fe70 7' ----------------------------------------------------------- We don't care which process calls do_fork so just check the first record to fix the issue. Signed-off-by: Xiao Yang <yangx.jy@cn.fujitsu.com> Acked-by: Masami Hiramatsu <mhiramat@kernel.org> Signed-off-by: Shuah Khan <skhan@linuxfoundation.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
51 lines
1.3 KiB
Bash
51 lines
1.3 KiB
Bash
#!/bin/sh
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
# description: Kprobes event arguments with types
|
|
|
|
[ -f kprobe_events ] || exit_unsupported # this is configurable
|
|
|
|
grep "x8/16/32/64" README > /dev/null || exit_unsupported # version issue
|
|
|
|
gen_event() { # Bitsize
|
|
echo "p:testprobe _do_fork \$stack0:s$1 \$stack0:u$1 \$stack0:x$1 \$stack0:b4@4/$1"
|
|
}
|
|
|
|
check_types() { # s-type u-type x-type bf-type width
|
|
test $# -eq 5
|
|
CW=$5
|
|
CW=$((CW / 4))
|
|
X1=`printf "%x" $1 | tail -c ${CW}`
|
|
X2=`printf "%x" $2`
|
|
X3=`printf "%x" $3`
|
|
test $X1 = $X2
|
|
test $X2 = $X3
|
|
test 0x$X3 = $3
|
|
|
|
B4=`printf "%1x" $4`
|
|
B3=`printf "%03x" 0x$X3 | tail -c 2 | head -c 1`
|
|
test $B3 = $B4
|
|
}
|
|
|
|
for width in 64 32 16 8; do
|
|
: "Add new event with basic types"
|
|
gen_event $width > kprobe_events
|
|
grep testprobe kprobe_events
|
|
test -d events/kprobes/testprobe
|
|
|
|
: "Trace the event"
|
|
echo 1 > events/kprobes/testprobe/enable
|
|
( echo "forked")
|
|
echo 0 > events/kprobes/testprobe/enable
|
|
|
|
: "Confirm the arguments is recorded in given types correctly"
|
|
ARGS=`grep "testprobe" trace | head -n 1 | sed -e 's/.* arg1=\(.*\) arg2=\(.*\) arg3=\(.*\) arg4=\(.*\)/\1 \2 \3 \4/'`
|
|
check_types $ARGS $width
|
|
|
|
: "Clear event for next loop"
|
|
echo "-:testprobe" >> kprobe_events
|
|
clear_trace
|
|
|
|
done
|
|
|
|
exit_pass
|