clear_trace() { # reset trace output echo > trace } disable_tracing() { # stop trace recording echo 0 > tracing_on } enable_tracing() { # start trace recording echo 1 > tracing_on } reset_tracer() { # reset the current tracer echo nop > current_tracer } reset_trigger_file() { # remove action triggers first grep -H ':on[^:]*(' $@ | while read line; do cmd=`echo $line | cut -f2- -d: | cut -f1 -d"["` file=`echo $line | cut -f1 -d:` echo "!$cmd" >> $file done grep -Hv ^# $@ | while read line; do cmd=`echo $line | cut -f2- -d: | cut -f1 -d"["` file=`echo $line | cut -f1 -d:` echo "!$cmd" > $file done } reset_trigger() { # reset all current setting triggers if [ -d events/synthetic ]; then reset_trigger_file events/synthetic/*/trigger fi reset_trigger_file events/*/*/trigger } reset_events_filter() { # reset all current setting filters grep -v ^none events/*/*/filter | while read line; do echo 0 > `echo $line | cut -f1 -d:` done } reset_ftrace_filter() { # reset all triggers in set_ftrace_filter if [ ! -f set_ftrace_filter ]; then return 0 fi echo > set_ftrace_filter grep -v '^#' set_ftrace_filter | while read t; do tr=`echo $t | cut -d: -f2` if [ "$tr" = "" ]; then continue fi if ! grep -q "$t" set_ftrace_filter; then continue; fi name=`echo $t | cut -d: -f1 | cut -d' ' -f1` if [ $tr = "enable_event" -o $tr = "disable_event" ]; then tr=`echo $t | cut -d: -f2-4` limit=`echo $t | cut -d: -f5` else tr=`echo $t | cut -d: -f2` limit=`echo $t | cut -d: -f3` fi if [ "$limit" != "unlimited" ]; then tr="$tr:$limit" fi echo "!$name:$tr" > set_ftrace_filter done } disable_events() { echo 0 > events/enable } clear_synthetic_events() { # reset all current synthetic events grep -v ^# synthetic_events | while read line; do echo "!$line" >> synthetic_events done } clear_dynamic_events() { # reset all current dynamic events again=1 stop=1 # loop mulitple times as some events require other to be removed first while [ $again -eq 1 ]; do stop=$((stop+1)) # Prevent infinite loops if [ $stop -gt 10 ]; then break; fi again=2 grep -v '^#' dynamic_events| while read line; do del=`echo $line | sed -e 's/^.\([^ ]*\).*/-\1/'` if ! echo "$del" >> dynamic_events; then again=1 fi done done } initialize_ftrace() { # Reset ftrace to initial-state # As the initial state, ftrace will be set to nop tracer, # no events, no triggers, no filters, no function filters, # no probes, and tracing on. disable_tracing reset_tracer reset_trigger reset_events_filter reset_ftrace_filter disable_events clear_dynamic_events [ -f set_event_pid ] && echo > set_event_pid [ -f set_ftrace_pid ] && echo > set_ftrace_pid [ -f set_ftrace_notrace ] && echo > set_ftrace_notrace [ -f set_graph_function ] && echo | tee set_graph_* [ -f stack_trace_filter ] && echo > stack_trace_filter [ -f kprobe_events ] && echo > kprobe_events [ -f uprobe_events ] && echo > uprobe_events [ -f synthetic_events ] && echo > synthetic_events [ -f snapshot ] && echo 0 > snapshot # Stop tracing while reading the trace file by default, to prevent # the test results while checking it and to avoid taking a long time # to check the result. [ -f options/pause-on-trace ] && echo 1 > options/pause-on-trace clear_trace enable_tracing } finish_ftrace() { initialize_ftrace # And recover it to default. [ -f options/pause-on-trace ] && echo 0 > options/pause-on-trace } check_requires() { # Check required files and tracers for i in "$@" ; do p=${i%:program} r=${i%:README} t=${i%:tracer} if [ $p != $i ]; then if ! which $p ; then echo "Required program $p is not found." exit_unresolved fi elif [ $t != $i ]; then if ! grep -wq $t available_tracers ; then echo "Required tracer $t is not configured." exit_unsupported fi elif [ "$r" != "$i" ]; then if ! grep -Fq "$r" README ; then echo "Required feature pattern \"$r\" is not in README." exit_unsupported fi elif [ ! -e $i ]; then echo "Required feature interface $i doesn't exist." exit_unsupported fi done } LOCALHOST=127.0.0.1 yield() { ping $LOCALHOST -c 1 || sleep .001 || usleep 1 || sleep 1 } # The fork function in the kernel was renamed from "_do_fork" to # "kernel_fork". As older tests should still work with older kernels # as well as newer kernels, check which version of fork is used on this # kernel so that the tests can use the fork function for the running kernel. FUNCTION_FORK=`(if grep '\bkernel_clone\b' /proc/kallsyms > /dev/null; then echo kernel_clone; else echo '_do_fork'; fi)` # Since probe event command may include backslash, explicitly use printf "%s" # to NOT interpret it. ftrace_errlog_check() { # err-prefix command-with-error-pos-by-^ command-file pos=$(printf "%s" "${2%^*}" | wc -c) # error position command=$(printf "%s" "$2" | tr -d ^) echo "Test command: $command" echo > error_log (! printf "%s" "$command" >> "$3" ) 2> /dev/null grep "$1: error:" -A 3 error_log N=$(tail -n 1 error_log | wc -c) # " Command: " and "^\n" => 13 test $(expr 13 + $pos) -eq $N } # Helper to get the tracefs mount point get_mount_point() { local mount_point=`stat -c '%m' .` # If stat -c '%m' does not work (e.g. busybox) or failed, try to use the # current working directory (which should be a tracefs) as the mount point. if [ ! -d "$mount_point" ]; then if mount | grep -qw "$PWD"; then mount_point=$PWD else # If PWD doesn't work, that is an environmental problem. exit_unresolved fi fi echo "$mount_point" } # Helper function to retrieve mount options for a given mount point get_mnt_options() { local mnt_point="$1" local opts=$(mount | grep -m1 "$mnt_point" | sed -e 's/.*(\(.*\)).*/\1/') echo "$opts" }