#!/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