mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-05-11 09:45:52 +00:00
This adds simple event trigger testcases for ftracetest, which covers following triggers. - traceon-traceoff trigger - enable/disable_event trigger - snapshot trigger - stacktrace trigger - trigger filters Here is the test result. ---- # ./ftracetest test.d/trigger/ === Ftrace unit tests === [1] event trigger - test event enable/disable trigger [PASS] [2] event trigger - test trigger filter [PASS] [3] event trigger - test snapshot-trigger [PASS] [4] event trigger - test stacktrace-trigger [PASS] [5] event trigger - test traceon/off trigger [PASS] # of passed: 5 # of failed: 0 # of unresolved: 0 # of untested: 0 # of unsupported: 0 # of xfailed: 0 # of undefined(test bug): 0 ---- Link: http://lkml.kernel.org/r/12b9c2b289a0dc1e4386e7b77674611a83abca85.1457029949.git.tom.zanussi@linux.intel.com Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Shuah Khan <shuahkh@osg.samsung.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Tom Zanussi <tom.zanussi@linux.intel.com> Reviewed-by: Namhyung Kim <namhyung@kernel.org> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
64 lines
1.7 KiB
Bash
64 lines
1.7 KiB
Bash
#!/bin/sh
|
|
# description: event trigger - test event enable/disable trigger
|
|
|
|
do_reset() {
|
|
reset_trigger
|
|
echo > set_event
|
|
clear_trace
|
|
}
|
|
|
|
fail() { #msg
|
|
do_reset
|
|
echo $1
|
|
exit $FAIL
|
|
}
|
|
|
|
if [ ! -f set_event -o ! -d events/sched ]; then
|
|
echo "event tracing is not supported"
|
|
exit_unsupported
|
|
fi
|
|
|
|
if [ ! -f events/sched/sched_process_fork/trigger ]; then
|
|
echo "event trigger is not supported"
|
|
exit_unsupported
|
|
fi
|
|
|
|
reset_tracer
|
|
do_reset
|
|
|
|
FEATURE=`grep enable_event events/sched/sched_process_fork/trigger`
|
|
if [ -z "$FEATURE" ]; then
|
|
echo "event enable/disable trigger is not supported"
|
|
exit_unsupported
|
|
fi
|
|
|
|
echo "Test enable_event trigger"
|
|
echo 0 > events/sched/sched_switch/enable
|
|
echo 'enable_event:sched:sched_switch' > events/sched/sched_process_fork/trigger
|
|
( echo "forked")
|
|
if [ `cat events/sched/sched_switch/enable` != '1*' ]; then
|
|
fail "enable_event trigger on sched_process_fork did not work"
|
|
fi
|
|
|
|
reset_trigger
|
|
|
|
echo "Test disable_event trigger"
|
|
echo 1 > events/sched/sched_switch/enable
|
|
echo 'disable_event:sched:sched_switch' > events/sched/sched_process_fork/trigger
|
|
( echo "forked")
|
|
if [ `cat events/sched/sched_switch/enable` != '0*' ]; then
|
|
fail "disable_event trigger on sched_process_fork did not work"
|
|
fi
|
|
|
|
reset_trigger
|
|
|
|
echo "Test semantic error for event enable/disable trigger"
|
|
! echo 'enable_event:nogroup:noevent' > events/sched/sched_process_fork/trigger
|
|
! echo 'disable_event+1' > events/sched/sched_process_fork/trigger
|
|
echo 'enable_event:sched:sched_switch' > events/sched/sched_process_fork/trigger
|
|
! echo 'enable_event:sched:sched_switch' > events/sched/sched_process_fork/trigger
|
|
! echo 'disable_event:sched:sched_switch' > events/sched/sched_process_fork/trigger
|
|
|
|
do_reset
|
|
|
|
exit 0
|