1ee3988c7SSteven Rostedt (Red Hat) 2ee3988c7SSteven Rostedt (Red Hat)clear_trace() { # reset trace output 3ee3988c7SSteven Rostedt (Red Hat) echo > trace 4ee3988c7SSteven Rostedt (Red Hat)} 5ee3988c7SSteven Rostedt (Red Hat) 6ee3988c7SSteven Rostedt (Red Hat)disable_tracing() { # stop trace recording 7ee3988c7SSteven Rostedt (Red Hat) echo 0 > tracing_on 8ee3988c7SSteven Rostedt (Red Hat)} 9ee3988c7SSteven Rostedt (Red Hat) 10ee3988c7SSteven Rostedt (Red Hat)enable_tracing() { # start trace recording 11ee3988c7SSteven Rostedt (Red Hat) echo 1 > tracing_on 12ee3988c7SSteven Rostedt (Red Hat)} 13ee3988c7SSteven Rostedt (Red Hat) 14ee3988c7SSteven Rostedt (Red Hat)reset_tracer() { # reset the current tracer 15ee3988c7SSteven Rostedt (Red Hat) echo nop > current_tracer 16ee3988c7SSteven Rostedt (Red Hat)} 17cfa0963dSMasami Hiramatsu 18756b56a9SSteven Rostedt (VMware)reset_trigger_file() { 19756b56a9SSteven Rostedt (VMware) # remove action triggers first 20756b56a9SSteven Rostedt (VMware) grep -H ':on[^:]*(' $@ | 21cfa0963dSMasami Hiramatsu while read line; do 22922a418dSSteven Rostedt (VMware) cmd=`echo $line | cut -f2- -d: | cut -f1 -d"["` 23756b56a9SSteven Rostedt (VMware) file=`echo $line | cut -f1 -d:` 24756b56a9SSteven Rostedt (VMware) echo "!$cmd" >> $file 25cfa0963dSMasami Hiramatsu done 26756b56a9SSteven Rostedt (VMware) grep -Hv ^# $@ | 27756b56a9SSteven Rostedt (VMware) while read line; do 28922a418dSSteven Rostedt (VMware) cmd=`echo $line | cut -f2- -d: | cut -f1 -d"["` 29756b56a9SSteven Rostedt (VMware) file=`echo $line | cut -f1 -d:` 30756b56a9SSteven Rostedt (VMware) echo "!$cmd" > $file 31756b56a9SSteven Rostedt (VMware) done 32756b56a9SSteven Rostedt (VMware)} 33756b56a9SSteven Rostedt (VMware) 34756b56a9SSteven Rostedt (VMware)reset_trigger() { # reset all current setting triggers 35756b56a9SSteven Rostedt (VMware) if [ -d events/synthetic ]; then 36756b56a9SSteven Rostedt (VMware) reset_trigger_file events/synthetic/*/trigger 37756b56a9SSteven Rostedt (VMware) fi 38756b56a9SSteven Rostedt (VMware) reset_trigger_file events/*/*/trigger 39cfa0963dSMasami Hiramatsu} 40cfa0963dSMasami Hiramatsu 41131f840dSMasami Hiramatsureset_events_filter() { # reset all current setting filters 42131f840dSMasami Hiramatsu grep -v ^none events/*/*/filter | 43131f840dSMasami Hiramatsu while read line; do 44131f840dSMasami Hiramatsu echo 0 > `echo $line | cut -f1 -d:` 45131f840dSMasami Hiramatsu done 46131f840dSMasami Hiramatsu} 47131f840dSMasami Hiramatsu 488e5e19c1SSteven Rostedt (VMware)reset_ftrace_filter() { # reset all triggers in set_ftrace_filter 498e5e19c1SSteven Rostedt (VMware) echo > set_ftrace_filter 508e5e19c1SSteven Rostedt (VMware) grep -v '^#' set_ftrace_filter | while read t; do 518e5e19c1SSteven Rostedt (VMware) tr=`echo $t | cut -d: -f2` 52d2ffb8d3SNaveen N. Rao if [ "$tr" = "" ]; then 538e5e19c1SSteven Rostedt (VMware) continue 548e5e19c1SSteven Rostedt (VMware) fi 550787ce33SSteven Rostedt (VMware) if ! grep -q "$t" set_ftrace_filter; then 560787ce33SSteven Rostedt (VMware) continue; 570787ce33SSteven Rostedt (VMware) fi 58df9d36d9SSteven Rostedt (VMware) name=`echo $t | cut -d: -f1 | cut -d' ' -f1` 59d2ffb8d3SNaveen N. Rao if [ $tr = "enable_event" -o $tr = "disable_event" ]; then 60df9d36d9SSteven Rostedt (VMware) tr=`echo $t | cut -d: -f2-4` 618e5e19c1SSteven Rostedt (VMware) limit=`echo $t | cut -d: -f5` 628e5e19c1SSteven Rostedt (VMware) else 63df9d36d9SSteven Rostedt (VMware) tr=`echo $t | cut -d: -f2` 648e5e19c1SSteven Rostedt (VMware) limit=`echo $t | cut -d: -f3` 658e5e19c1SSteven Rostedt (VMware) fi 668e5e19c1SSteven Rostedt (VMware) if [ "$limit" != "unlimited" ]; then 678e5e19c1SSteven Rostedt (VMware) tr="$tr:$limit" 688e5e19c1SSteven Rostedt (VMware) fi 69df9d36d9SSteven Rostedt (VMware) echo "!$name:$tr" > set_ftrace_filter 708e5e19c1SSteven Rostedt (VMware) done 718e5e19c1SSteven Rostedt (VMware)} 728e5e19c1SSteven Rostedt (VMware) 73131f840dSMasami Hiramatsudisable_events() { 74131f840dSMasami Hiramatsu echo 0 > events/enable 75131f840dSMasami Hiramatsu} 76131f840dSMasami Hiramatsu 77f06eec4dSRajvi Jingarclear_synthetic_events() { # reset all current synthetic events 78f06eec4dSRajvi Jingar grep -v ^# synthetic_events | 79f06eec4dSRajvi Jingar while read line; do 80f06eec4dSRajvi Jingar echo "!$line" >> synthetic_events 81f06eec4dSRajvi Jingar done 82f06eec4dSRajvi Jingar} 83f06eec4dSRajvi Jingar 84131f840dSMasami Hiramatsuinitialize_ftrace() { # Reset ftrace to initial-state 85131f840dSMasami Hiramatsu# As the initial state, ftrace will be set to nop tracer, 86131f840dSMasami Hiramatsu# no events, no triggers, no filters, no function filters, 87131f840dSMasami Hiramatsu# no probes, and tracing on. 88131f840dSMasami Hiramatsu disable_tracing 89131f840dSMasami Hiramatsu reset_tracer 90131f840dSMasami Hiramatsu reset_trigger 91131f840dSMasami Hiramatsu reset_events_filter 927590472eSMasami Hiramatsu reset_ftrace_filter 93131f840dSMasami Hiramatsu disable_events 94*6e55f320SSteven Rostedt (VMware) [ -f set_event_pid ] && echo > set_event_pid 95*6e55f320SSteven Rostedt (VMware) [ -f set_ftrace_pid ] && echo > set_ftrace_pid 96131f840dSMasami Hiramatsu [ -f set_ftrace_filter ] && echo | tee set_ftrace_* 97131f840dSMasami Hiramatsu [ -f set_graph_function ] && echo | tee set_graph_* 98131f840dSMasami Hiramatsu [ -f stack_trace_filter ] && echo > stack_trace_filter 99131f840dSMasami Hiramatsu [ -f kprobe_events ] && echo > kprobe_events 100131f840dSMasami Hiramatsu [ -f uprobe_events ] && echo > uprobe_events 1017590472eSMasami Hiramatsu [ -f synthetic_events ] && echo > synthetic_events 1027590472eSMasami Hiramatsu [ -f snapshot ] && echo 0 > snapshot 1037590472eSMasami Hiramatsu clear_trace 104131f840dSMasami Hiramatsu enable_tracing 105131f840dSMasami Hiramatsu} 106cec3adf5SMasami Hiramatsu 107cec3adf5SMasami HiramatsuLOCALHOST=127.0.0.1 108cec3adf5SMasami Hiramatsu 109cec3adf5SMasami Hiramatsuyield() { 110cec3adf5SMasami Hiramatsu ping $LOCALHOST -c 1 || sleep .001 || usleep 1 || sleep 1 111cec3adf5SMasami Hiramatsu} 112c5e4114fSTom Zanussi 113c5e4114fSTom Zanussiftrace_errlog_check() { # err-prefix command-with-error-pos-by-^ command-file 114c5e4114fSTom Zanussi pos=$(echo -n "${2%^*}" | wc -c) # error position 115c5e4114fSTom Zanussi command=$(echo "$2" | tr -d ^) 116c5e4114fSTom Zanussi echo "Test command: $command" 117c5e4114fSTom Zanussi echo > error_log 118c5e4114fSTom Zanussi (! echo "$command" > "$3" ) 2> /dev/null 119c5e4114fSTom Zanussi grep "$1: error:" -A 3 error_log 120c5e4114fSTom Zanussi N=$(tail -n 1 error_log | wc -c) 121c5e4114fSTom Zanussi # " Command: " and "^\n" => 13 122c5e4114fSTom Zanussi test $(expr 13 + $pos) -eq $N 123c5e4114fSTom Zanussi} 124