[LTP] [PATCH V2 1/9] tracing: reorganize ftrace-stress tests to general tests

Chunyu Hu chuhu@redhat.com
Thu May 5 12:11:04 CEST 2016


Thanks. Some issue has been done in patch 2/9, will fix
other issues you mentioned in next step.

----- Original Message -----
> From: "Cyril Hrubis" <chrubis@suse.cz>
> To: "Chunyu Hu" <chuhu@redhat.com>
> Cc: ltp@lists.linux.it, liwan@redhat.com
> Sent: Thursday, May 5, 2016 12:26:56 AM
> Subject: Re: [LTP] [PATCH V2 1/9] tracing: reorganize ftrace-stress tests to general tests
> 
> Hi!
> > diff --git a/testcases/kernel/tracing/ftrace_test/ftrace_lib.sh
> > b/testcases/kernel/tracing/ftrace_test/ftrace_lib.sh
> > new file mode 100755
> > index 0000000..ea082dc
> > --- /dev/null
> > +++ b/testcases/kernel/tracing/ftrace_test/ftrace_lib.sh
> > @@ -0,0 +1,156 @@
> > +#! /bin/sh
>      ^
>      The space should be removed

will fix this in patch 2/9 "skip unsupported tests and early cleanup". 

> > +###########################################################################
> > +##
> > ##
> > +## 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>
> > ##
> > +##
> > ##
> > +###########################################################################
> > +
> > +cd $LTPROOT/testcases/bin
> > +
> > +export TPATH="$PWD"
> > +export DEBUGFS_PATH="$PWD/debugfs"
> > +export TRACING_PATH="$PWD/debugfs/tracing"
> 
> The test must not create files and mount things outside of the test
> temporary directory. Expecially not in $LTPROOT. You should call
> tst_tmpdir to create temporary directory instead, then create directory
> there.

Thanks for the suggestion, will take this way in next version, also
add it into patch 2/9.

> Also the ftrace filesystem seems to be mounted on
> /sys/kernel/debug/tracing/ on recent distributions, why don't we just
> set TRACING_PATH accodingly if it's already mounted and fallback to
> mounting it only when debugfs couldn't be found in /proc/mounts?

Thanks. Will take this way in next version, we check whether the mounting is
needed, through /proc/mounts , and then only mount/umount 
if it's not mounted by default.

> > +export FPATH="$TPATH/ftrace_function"
> > +export RPATH="$TPATH/ftrace_regression"
> > +export SPATH="$TPATH/ftrace_stress"
> > +
> > +. test.sh
> > +
> > +test_interval=$1
> > +
> > +save_old_setting()
> > +{
> > +	cd $TRACING_PATH
> > +
> > +	old_trace_options=( `cat trace_options` )
> > +	old_tracing_on=`cat tracing_on`
> > +	old_tracing_enabled=`cat tracing_enabled`
> > +	old_buffer_size=`cat buffer_size_kb`
> > +
> > +	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
> > +
> > +	cd - > /dev/null
> > +}
> > +
> > +
> > +restore_old_setting()
> > +{
> > +	cd $TRACING_PATH
> > +
> > +	echo nop > current_tracer
> > +	echo 0 > events/enable
> > +	echo 0 > tracing_max_latency 2> /dev/null
> > +
> > +	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
> > +	echo $old_tracing_enabled > tracing_enabled
> > +
> > +	for option in $old_trace_options
> > +	do
> > +		echo $option > trace_options 2> /dev/null
> > +	done
> > +
> > +	echo > trace
> > +
> > +	cd - > /dev/null
> > +}
> > +
> > +clean_up()
> > +{
> > +	restore_old_setting
> > +
> > +	umount $DEBUGFS_PATH
> > +	rmdir $DEBUGFS_PATH
> > +}
> > +
> > +clean_up_exit()
> > +{
> > +	clean_up
> > +	exit 1
> > +}
> > +
> > +test_begin()
> > +{
> > +	start_time=`date +%s`
> > +}
> > +
> > +test_wait()
> > +{
> > +	for ((; ;))
> > +	{
> > +		sleep 2
> > +
> > +		cur_time=`date +%s`
> > +		elapsed=$(( $cur_time - $start_time ))
> > +
> > +		# run the test for $test_interval secs
> > +		if [ $elapsed -ge $test_interval ]; then
> > +			break
> > +		fi
> > +	}
> > +}
> 
> Why don't we just do sleep $test_interval instead?

Good idea, will leave only a tst_sleep in the func in 
next step.

> > +trap clean_up_exit INT
> > +
> > +tst_require_root
> > +
> > +# Don't run the test on kernels older than 2.6.34, otherwise
> > +# it can crash the system if the kernel is not latest-stable
> > +tst_kvercmp 2 6 34
> > +if [ $? -eq 0 ]; then
> > +	tst_brkm TCONF ignored "The test should be run in kernels >= 2.6.34. Skip
> > the test..."
> > +	exit 0
> > +fi
> 
> Don't do this. Really the whole point of LTP is to validate kernel, if
> we skip known bugs by default we would give users false impression that
> the kernel was thoroughly tested.

OK, will remove the ignore, and remove this skip step, I agree that
this skip is not needed. If user found panic,  should fix the 
issue asap. and skip steps should be done in local repo if needed.

> Also since you include the test.sh here the tst_brkm format is different
> and it exits the test, so the exit 0 is never reached.

OK. Will remove this. 

> > +mkdir $DEBUGFS_PATH
> > +mount -t debugfs xxx $DEBUGFS_PATH
> > +
> > +# Check to see tracing feature is supported or not
> > +if [ ! -d $TRACING_PATH ]; then
> > +	tst_brkm TCONF ignored "Tracing is not supported. Skip the test..."
> > +	umount $DEBUGFS_PATH
> > +	rmdir $DEBUGFS_PATH
> > +	exit 0
> > +fi
> 
> Here as well, the tst_brkm from test.sh exit the test. Ideally you
> should setup TST_CLEANUP to point to a cleanup function once you do the
> test initalization which would be then executed before the test exits
> automatically.

OK. I think we can add a function for test initiating. including check/mount
debugfs, exporting the env like TRACING_PATH,  and setting up the cleanup
callback TST_CLEANUP=cleanup

> ...
> 
> 
> > diff --git a/testcases/kernel/tracing/ftrace_test/ftrace_stress_test.sh
> > b/testcases/kernel/tracing/ftrace_test/ftrace_stress_test.sh
> > new file mode 100755
> > index 0000000..d9f7f8b
> > --- /dev/null
> > +++ b/testcases/kernel/tracing/ftrace_test/ftrace_stress_test.sh
> > @@ -0,0 +1,123 @@
> > +#! /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>
> > ##
> > +##
> > ##
> > +###########################################################################
> > +
> > +
> > +export TCID="ftrace-stress-test"
> > +export TST_TOTAL=1
> > +export TST_COUNT=1
> > +
> > +. ftrace_lib.sh
> > +
> > +test_success=true
> > +
> > +export_pids()
> > +{
> > +	export pid1 pid2 pid3 pid4 pid5 pid6 pid7 pid8 pid9 pid10 pid11 pid12 \
> > +		pid13 pid14 pid15 pid16
> > +
> > +	export NR_PIDS=16
> > +}
> > +
> > +test_stress()
> > +{
> > +	export_pids
> > +
> > +	$SPATH/ftrace_trace_clock.sh &
> > +	pid1=$!
> > +	$SPATH/ftrace_current_tracer.sh &
> > +	pid2=$!
> > +	$SPATH/ftrace_trace_options.sh &
> > +	pid3=$!
> > +	$SPATH/ftrace_tracing_max_latency.sh &
> > +	pid4=$!
> > +	$SPATH/ftrace_stack_trace.sh &
> > +	pid5=$!
> > +	$SPATH/ftrace_stack_max_size.sh &
> > +	pid6=$!
> > +	$SPATH/ftrace_tracing_on.sh &
> > +	pid7=$!
> > +	$SPATH/ftrace_tracing_enabled.sh &
> > +	pid8=$!
> > +	$SPATH/ftrace_set_event.sh &
> > +	pid9=$!
> > +	$SPATH/ftrace_buffer_size.sh &
> > +	pid10=$!
> > +	$SPATH/ftrace_trace.sh &
> > +	pid11=$!
> > +	$SPATH/ftrace_trace_pipe.sh &
> > +	pid12=$!
> > +	$SPATH/ftrace_ftrace_enabled.sh &
> > +	pid13=$!
> > +	$SPATH/ftrace_set_ftrace_pid.sh &
> > +	pid14=$!
> > +	$SPATH/ftrace_profile_enabled.sh &
> > +	pid15=$!
> > +	$SPATH/ftrace_trace_stat.sh &
> > +	pid16=$!
> > +}
> > +
> > +test_kill()
> > +{
> > +	kill -KILL $pid1 || test_success=false
> > +	kill -KILL $pid2 || test_success=false
> > +	kill -KILL $pid3 || test_success=false
> > +	kill -KILL $pid4 || test_success=false
> > +	kill -KILL $pid5 || test_success=false
> > +	kill -KILL $pid6 || test_success=false
> > +	kill -KILL $pid7 || test_success=false
> > +	kill -KILL $pid8 || test_success=false
> > +	kill -KILL $pid9 || test_success=false
> > +	kill -KILL $pid10 || test_success=false
> > +	kill -KILL $pid11 || test_success=false
> > +	kill -USR1 $pid12 || test_success=false
> > +	kill -KILL $pid13 || test_success=false
> > +	kill -KILL $pid14 || test_success=false
> > +	kill -KILL $pid15 || test_success=false
> > +	kill -KILL $pid16 || test_success=false
> > +
> > +	sleep 2
> 
> I remember telling you to call wait on each pid instead of the sleep 2
> here.

The sleep 2 wil be removed in next step into patch 2/9.

> > +	clean_up
> > +}
> > +
> > +
> > +# ----------------------------
> > +echo "Ftrace Stress Test Begin"
> 
> That should be tst_resm TINFO "..." but that is very minor.

This has been fixed in patch 2/9

> > +save_old_setting
> > +
> > +test_begin
> > +
> > +test_stress
> > +
> > +test_wait
> > +
> > +test_kill
> 
> Hmm, shouldn't you restore old settings here?
> 
> > +echo "Ftrace Stress Test End"
> 
> Here as well.

Fixed in patch 2/9.

> > +if $test_success; then
> > +	tst_resm TPASS "finished running the test. Run dmesg to double-check for
> > bugs"
> > +else
> > +	tst_resm TFAIL "please check log message."
> > +	exit 1
> > +fi
> 
> You should call tst_exit at the end of the test instead of doing exit 1
> after the tst_resm. This is another leftover caused by the
> broken-by-desing tst_resm and tst_brkm binaries.

This has been done in 2/9. thank you for the detailed info.

> --
> Cyril Hrubis
> chrubis@suse.cz
> 

-- 
Regards,
Chunyu Hu



More information about the ltp mailing list