1ee3988c7SSteven Rostedt (Red Hat)clear_trace() { # reset trace output 2ee3988c7SSteven Rostedt (Red Hat) echo > trace 3ee3988c7SSteven Rostedt (Red Hat)} 4ee3988c7SSteven Rostedt (Red Hat) 5ee3988c7SSteven Rostedt (Red Hat)disable_tracing() { # stop trace recording 6ee3988c7SSteven Rostedt (Red Hat) echo 0 > tracing_on 7ee3988c7SSteven Rostedt (Red Hat)} 8ee3988c7SSteven Rostedt (Red Hat) 9ee3988c7SSteven Rostedt (Red Hat)enable_tracing() { # start trace recording 10ee3988c7SSteven Rostedt (Red Hat) echo 1 > tracing_on 11ee3988c7SSteven Rostedt (Red Hat)} 12ee3988c7SSteven Rostedt (Red Hat) 13ee3988c7SSteven Rostedt (Red Hat)reset_tracer() { # reset the current tracer 14ee3988c7SSteven Rostedt (Red Hat) echo nop > current_tracer 15ee3988c7SSteven Rostedt (Red Hat)} 16cfa0963dSMasami Hiramatsu 17756b56a9SSteven Rostedt (VMware)reset_trigger_file() { 18756b56a9SSteven Rostedt (VMware) # remove action triggers first 19756b56a9SSteven Rostedt (VMware) grep -H ':on[^:]*(' $@ | 20cfa0963dSMasami Hiramatsu while read line; do 21922a418dSSteven Rostedt (VMware) cmd=`echo $line | cut -f2- -d: | cut -f1 -d"["` 22756b56a9SSteven Rostedt (VMware) file=`echo $line | cut -f1 -d:` 23756b56a9SSteven Rostedt (VMware) echo "!$cmd" >> $file 24cfa0963dSMasami Hiramatsu done 25756b56a9SSteven Rostedt (VMware) grep -Hv ^# $@ | 26756b56a9SSteven Rostedt (VMware) while read line; do 27922a418dSSteven Rostedt (VMware) cmd=`echo $line | cut -f2- -d: | cut -f1 -d"["` 28756b56a9SSteven Rostedt (VMware) file=`echo $line | cut -f1 -d:` 29756b56a9SSteven Rostedt (VMware) echo "!$cmd" > $file 30756b56a9SSteven Rostedt (VMware) done 31756b56a9SSteven Rostedt (VMware)} 32756b56a9SSteven Rostedt (VMware) 33756b56a9SSteven Rostedt (VMware)reset_trigger() { # reset all current setting triggers 34756b56a9SSteven Rostedt (VMware) if [ -d events/synthetic ]; then 35756b56a9SSteven Rostedt (VMware) reset_trigger_file events/synthetic/*/trigger 36756b56a9SSteven Rostedt (VMware) fi 37756b56a9SSteven Rostedt (VMware) reset_trigger_file events/*/*/trigger 38cfa0963dSMasami Hiramatsu} 39cfa0963dSMasami Hiramatsu 40131f840dSMasami Hiramatsureset_events_filter() { # reset all current setting filters 41131f840dSMasami Hiramatsu grep -v ^none events/*/*/filter | 42131f840dSMasami Hiramatsu while read line; do 43131f840dSMasami Hiramatsu echo 0 > `echo $line | cut -f1 -d:` 44131f840dSMasami Hiramatsu done 45131f840dSMasami Hiramatsu} 46131f840dSMasami Hiramatsu 478e5e19c1SSteven Rostedt (VMware)reset_ftrace_filter() { # reset all triggers in set_ftrace_filter 48fd1baf6cSMasami Hiramatsu if [ ! -f set_ftrace_filter ]; then 49fd1baf6cSMasami Hiramatsu return 0 50fd1baf6cSMasami Hiramatsu fi 518e5e19c1SSteven Rostedt (VMware) echo > set_ftrace_filter 528e5e19c1SSteven Rostedt (VMware) grep -v '^#' set_ftrace_filter | while read t; do 538e5e19c1SSteven Rostedt (VMware) tr=`echo $t | cut -d: -f2` 54d2ffb8d3SNaveen N. Rao if [ "$tr" = "" ]; then 558e5e19c1SSteven Rostedt (VMware) continue 568e5e19c1SSteven Rostedt (VMware) fi 570787ce33SSteven Rostedt (VMware) if ! grep -q "$t" set_ftrace_filter; then 580787ce33SSteven Rostedt (VMware) continue; 590787ce33SSteven Rostedt (VMware) fi 60df9d36d9SSteven Rostedt (VMware) name=`echo $t | cut -d: -f1 | cut -d' ' -f1` 61d2ffb8d3SNaveen N. Rao if [ $tr = "enable_event" -o $tr = "disable_event" ]; then 62df9d36d9SSteven Rostedt (VMware) tr=`echo $t | cut -d: -f2-4` 638e5e19c1SSteven Rostedt (VMware) limit=`echo $t | cut -d: -f5` 648e5e19c1SSteven Rostedt (VMware) else 65df9d36d9SSteven Rostedt (VMware) tr=`echo $t | cut -d: -f2` 668e5e19c1SSteven Rostedt (VMware) limit=`echo $t | cut -d: -f3` 678e5e19c1SSteven Rostedt (VMware) fi 688e5e19c1SSteven Rostedt (VMware) if [ "$limit" != "unlimited" ]; then 698e5e19c1SSteven Rostedt (VMware) tr="$tr:$limit" 708e5e19c1SSteven Rostedt (VMware) fi 71df9d36d9SSteven Rostedt (VMware) echo "!$name:$tr" > set_ftrace_filter 728e5e19c1SSteven Rostedt (VMware) done 738e5e19c1SSteven Rostedt (VMware)} 748e5e19c1SSteven Rostedt (VMware) 75131f840dSMasami Hiramatsudisable_events() { 76131f840dSMasami Hiramatsu echo 0 > events/enable 77131f840dSMasami Hiramatsu} 78131f840dSMasami Hiramatsu 79f06eec4dSRajvi Jingarclear_synthetic_events() { # reset all current synthetic events 80f06eec4dSRajvi Jingar grep -v ^# synthetic_events | 81f06eec4dSRajvi Jingar while read line; do 82f06eec4dSRajvi Jingar echo "!$line" >> synthetic_events 83f06eec4dSRajvi Jingar done 84f06eec4dSRajvi Jingar} 85f06eec4dSRajvi Jingar 86131f840dSMasami Hiramatsuinitialize_ftrace() { # Reset ftrace to initial-state 87131f840dSMasami Hiramatsu# As the initial state, ftrace will be set to nop tracer, 88131f840dSMasami Hiramatsu# no events, no triggers, no filters, no function filters, 89131f840dSMasami Hiramatsu# no probes, and tracing on. 90131f840dSMasami Hiramatsu disable_tracing 91131f840dSMasami Hiramatsu reset_tracer 92131f840dSMasami Hiramatsu reset_trigger 93131f840dSMasami Hiramatsu reset_events_filter 947590472eSMasami Hiramatsu reset_ftrace_filter 95131f840dSMasami Hiramatsu disable_events 966e55f320SSteven Rostedt (VMware) [ -f set_event_pid ] && echo > set_event_pid 976e55f320SSteven Rostedt (VMware) [ -f set_ftrace_pid ] && echo > set_ftrace_pid 98fd1baf6cSMasami Hiramatsu [ -f set_ftrace_notrace ] && echo > set_ftrace_notrace 99131f840dSMasami Hiramatsu [ -f set_graph_function ] && echo | tee set_graph_* 100131f840dSMasami Hiramatsu [ -f stack_trace_filter ] && echo > stack_trace_filter 101131f840dSMasami Hiramatsu [ -f kprobe_events ] && echo > kprobe_events 102131f840dSMasami Hiramatsu [ -f uprobe_events ] && echo > uprobe_events 1037590472eSMasami Hiramatsu [ -f synthetic_events ] && echo > synthetic_events 1047590472eSMasami Hiramatsu [ -f snapshot ] && echo 0 > snapshot 1057590472eSMasami Hiramatsu clear_trace 106131f840dSMasami Hiramatsu enable_tracing 107131f840dSMasami Hiramatsu} 108cec3adf5SMasami Hiramatsu 109305c8388SMasami Hiramatsucheck_requires() { # Check required files and tracers 1101b8eec51SMasami Hiramatsu for i in "$@" ; do 1111b8eec51SMasami Hiramatsu r=${i%:README} 112305c8388SMasami Hiramatsu t=${i%:tracer} 113305c8388SMasami Hiramatsu if [ $t != $i ]; then 114305c8388SMasami Hiramatsu if ! grep -wq $t available_tracers ; then 115305c8388SMasami Hiramatsu echo "Required tracer $t is not configured." 116305c8388SMasami Hiramatsu exit_unsupported 117305c8388SMasami Hiramatsu fi 1181b8eec51SMasami Hiramatsu elif [ $r != $i ]; then 1191b8eec51SMasami Hiramatsu if ! grep -Fq "$r" README ; then 1201b8eec51SMasami Hiramatsu echo "Required feature pattern \"$r\" is not in README." 1211b8eec51SMasami Hiramatsu exit_unsupported 1221b8eec51SMasami Hiramatsu fi 123305c8388SMasami Hiramatsu elif [ ! -e $i ]; then 124fa33e623SMasami Hiramatsu echo "Required feature interface $i doesn't exist." 125fa33e623SMasami Hiramatsu exit_unsupported 126fa33e623SMasami Hiramatsu fi 127fa33e623SMasami Hiramatsu done 128fa33e623SMasami Hiramatsu} 129fa33e623SMasami Hiramatsu 130cec3adf5SMasami HiramatsuLOCALHOST=127.0.0.1 131cec3adf5SMasami Hiramatsu 132cec3adf5SMasami Hiramatsuyield() { 133cec3adf5SMasami Hiramatsu ping $LOCALHOST -c 1 || sleep .001 || usleep 1 || sleep 1 134cec3adf5SMasami Hiramatsu} 135c5e4114fSTom Zanussi 136*dc6bf4daSSteven Rostedt (VMware)# The fork function in the kernel was renamed from "_do_fork" to 137*dc6bf4daSSteven Rostedt (VMware)# "kernel_fork". As older tests should still work with older kernels 138*dc6bf4daSSteven Rostedt (VMware)# as well as newer kernels, check which version of fork is used on this 139*dc6bf4daSSteven Rostedt (VMware)# kernel so that the tests can use the fork function for the running kernel. 140*dc6bf4daSSteven Rostedt (VMware)FUNCTION_FORK=`(if grep '\bkernel_clone\b' /proc/kallsyms > /dev/null; then 141*dc6bf4daSSteven Rostedt (VMware) echo kernel_clone; else echo '_do_fork'; fi)` 142*dc6bf4daSSteven Rostedt (VMware) 1438e923a21SMasami Hiramatsu# Since probe event command may include backslash, explicitly use printf "%s" 1448e923a21SMasami Hiramatsu# to NOT interpret it. 145c5e4114fSTom Zanussiftrace_errlog_check() { # err-prefix command-with-error-pos-by-^ command-file 1468e923a21SMasami Hiramatsu pos=$(printf "%s" "${2%^*}" | wc -c) # error position 1478e923a21SMasami Hiramatsu command=$(printf "%s" "$2" | tr -d ^) 148c5e4114fSTom Zanussi echo "Test command: $command" 149c5e4114fSTom Zanussi echo > error_log 1508e923a21SMasami Hiramatsu (! printf "%s" "$command" >> "$3" ) 2> /dev/null 151c5e4114fSTom Zanussi grep "$1: error:" -A 3 error_log 152c5e4114fSTom Zanussi N=$(tail -n 1 error_log | wc -c) 153c5e4114fSTom Zanussi # " Command: " and "^\n" => 13 154c5e4114fSTom Zanussi test $(expr 13 + $pos) -eq $N 155c5e4114fSTom Zanussi} 156