#!/bin/sh
###########################################################################
## ##
## Copyright (c) 2010 FUJITSU LIMITED ##
## ##
## This program is free software: you can redistribute it and/or modify ##
## it under the terms of the GNU General Public License as published by ##
## the Free Software Foundation, either version 3 of the License, or ##
## (at your option) any later version. ##
## ##
## This program is distributed in the hope that it will be useful, ##
## but WITHOUT ANY WARRANTY; without even the implied warranty of ##
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ##
## GNU General Public License for more details. ##
## ##
## You should have received a copy of the GNU General Public License ##
## along with this program. If not, see <http://www.gnu.org/licenses/>. ##
## ##
## Author: Li Zefan <lizf@cn.fujitsu.com> ##
## ##
###########################################################################
. test.sh
ftrace_test_init()
{
export TPATH="$PWD"
export SPATH="$TPATH/ftrace_stress"
if grep -q debugfs /proc/mounts; then
export DEBUGFS_PATH=/sys/kernel/debug/
export TRACING_PATH="$DEBUGFS_PATH/tracing"
debugfs_def_mounted=1
else
tst_tmpdir
export DEBUGFS_PATH="$PWD/debugfs"
export TRACING_PATH="$PWD/debugfs/tracing"
mkdir $DEBUGFS_PATH
mount -t debugfs xxx $DEBUGFS_PATH
fi
TST_CLEANUP=clean_up
trap clean_up_exit INT
tst_require_root
# Check to see tracing feature is supported or not
if [ ! -d $TRACING_PATH ]; then
tst_brkm TCONF "Tracing is not supported. Skip the test..."
fi
save_old_setting
}
test_interval=$1
save_old_setting()
{
cd $TRACING_PATH
old_trace_options=( `cat trace_options` )
old_tracing_on=`cat tracing_on`
old_buffer_size=`cat buffer_size_kb`
old_tracing_cpumask=`cat tracing_cpumask`
if [ -e tracing_cpumask ]; then
old_tracing_cpumask=`cat tracing_cpumask`
fi
if [ -e tracing_enabled ]; then
old_tracing_enabled=`cat tracing_enabled`
fi
if [ -e stack_max_size ]; then
old_stack_tracer_enabled=`cat /proc/sys/kernel/stack_tracer_enabled`
fi
if [ -e "/proc/sys/kernel/ftrace_enabled" ]; then
old_ftrace_enabled=`cat /proc/sys/kernel/ftrace_enabled`
fi
if [ -e "function_profile_enabled" ]; then
old_profile_enabled=`cat function_profile_enabled`
fi
setting_saved=1
cd - > /dev/null
}
restore_old_setting()
{
if [ ! "$setting_saved" = 1 ]; then
return
fi
cd $TRACING_PATH
echo nop > current_tracer
echo 0 > events/enable
echo 0 > tracing_max_latency 2> /dev/null
if [ -e tracing_cpumask ]; then
echo $old_tracing_cpumask > tracing_cpumask
fi
if [ -e trace_clock ]; then
echo local > trace_clock
fi
if [ -e "function_pofile_enabled" ]; then
echo $old_profile_enabled > function_profile_enabled
fi
if [ -e "/proc/sys/kernel/ftrace_enabled" ]; then
echo $old_ftrace_enabled > /proc/sys/kernel/ftrace_enabled
fi
if [ -e stack_max_size ]; then
echo $old_stack_tracer_enabled > /proc/sys/kernel/stack_tracer_enabled
echo 0 > stack_max_size
fi
echo $old_buffer_size > buffer_size_kb
echo $old_tracing_on > tracing_on
if [ -e tracing_enabled ];then
echo $old_tracing_enabled > tracing_enabled
fi
for option in $old_trace_options
do
echo $option > trace_options 2> /dev/null
done
echo > trace
if [ -f set_ftrace_filter ]; then
echo > set_ftrace_filter
fi
cd - > /dev/null
}
clean_up_mount()
{
if [ ! "$debugfs_def_mounted" = "1" ]; then
umount $DEBUGFS_PATH
rmdir $DEBUGFS_PATH
fi
}
clean_up()
{
restore_old_setting
clean_up_mount
}
clean_up_exit()
{
restore_old_setting
clean_up_mount
exit 1
}
test_begin()
{
start_time=`date +%s`
}
test_wait()
{
# run the test for $test_interval secs
tst_sleep ${test_interval}s
}
ftrace_test_init