Bash程序  |  215行  |  6.61 KB

#!/bin/bash
# usage ./runcpuctl_latency_test.sh

###############################################################################
#  Copyright (c) International Business Machines  Corp., 2008                 #
#                                                                             #
#  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 2 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, write to the Free Software               #
#  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA    #
#                                                                             #
###############################################################################
# Name Of File: run_cpuctl_test.sh                                            #
#                                                                             #
# Description: This file runs the setup for testing latency under heavy load  #
#              when group scheduling is enabled                               #
#              After setup it runs diff test cases in diff setup.             #
#                                                                             #
# Test 01:     Tests latency when no cgroup is mounted                        #
# Test 02:     Tests latency when cgroup is mounted                           #
#                                                                             #
#                                                                             #
# Author:       Sudhir Kumar   <skumar@linux.vnet.ibm.com>                    #
#                                                                             #
# History:                                                                    #
#                                                                             #
#  DATE         NAME           EMAIL                         DESC             #
#                                                                             #
#  26/11/08  Sudhir Kumar <skumar@linux.vnet.ibm.com>   Created this test     #
#                                                                             #
###############################################################################


NUM_TASKS=100;
NUM_GROUPS=2;	#for default
check_task="";
declare -a pid;
allowed_latency=10;

export TCID="cpuctl_latency_test";
export TST_COUNT=1;
export TST_TOTAL=2;

. parameters.sh

latency_cleanup()
{
	local i;

	if [ -n "${pid[1]}" ]; then
		for i in $(seq 1 $NUM_TASKS)
		do
			kill -s SIGUSR1 ${pid[$i]} 2>/dev/null;
		done
	fi

	sleep 2;
	if [ $TEST_NUM -eq 2 ]; then
		# move any remaining task
		sleep 2;
		for task in `cat /dev/cpuctl/group*/tasks`; do
	                echo $task > /dev/cpuctl/tasks #2>/dev/null 1>&2;
	        done
	        rmdir /dev/cpuctl/group* #2> /dev/null
        	umount /dev/cpuctl #2> /dev/null
	        rmdir /dev/cpuctl #2> /dev/null
		rm -f myfifo;
	fi;
	echo "Cleanup done for latency test $TEST_NUM"
	echo
}

log2()
{
        local x=$1 n=2 l=-1;
        while((x));do
                let l+=1
                let x/=n;
        done;
        return $l;
}

# There is no single criterion for max latency, so pass or fail is only
# intuitive. Here we use the same logic as by the kernel
calc_allowed_latency()
{
	# default sched granularity=5ms if not exported by kernel
	def_gran=5000 #in microseconds
	if [ -f /proc/sys/kernel/sched_wakeup_granularity_ns ]; then
		sys_latency=`cat /proc/sys/kernel/sched_wakeup_granularity_ns`
		allowed_latency=`expr $sys_latency / 1000` # in microseconds
	else
		num_cpus=`tst_ncpus`
		log2 $num_cpus;
		ln_num_cpus=$?
		ln_num_cpus=`expr $ln_num_cpus + 1`
		allowed_latency=`expr $ln_num_cpus \* $def_gran`
	fi

	# To be more practical we will take our criterio as double of this value
	allowed_latency=`expr $allowed_latency \* 2`
}

PWD=`pwd`

################################
# Start
################################

	TEST_NUM=$1;
	if [ -z $TEST_NUM  ]; then
		echo "Invalid test no passed to test script"
		echo "Exiting the test..."
		exit 1;
	fi;

	cd $LTPROOT/testcases/bin/ #Bad idea????????

	# Check if sources are compiled
	if [ ! -f $cpuctl_latency_test ] || [ ! -f $cpuctl_latency_check_task ]
	then
		echo "TBROK The sources are not compiled...."
		cd $PWD;
		exit 1;
	fi

	# Keep the signal handler ready
	trap 'echo "Doing cleanup"; latency_cleanup;' 0;

	# Calculate the alowed latency value
	calc_allowed_latency;

	case $TEST_NUM in
	"1")	#without creating any groups
		# Run the load creating tasks
		echo TINFO "Running cpuctl Latency Test 1"
		for i in $(seq 1 $NUM_TASKS)
		do
			# Execute the load tasks
			./cpuctl_latency_test $TEST_NUM &
			if [ $? -ne 0 ]
			then
				echo "TBROK Failed to execute binary"
				exit;
			else
				pid[$i]=$!;
			fi
		done

		# Run the latency checking task
		./cpuctl_latency_check_task $TEST_NUM $$ $allowed_latency &
		if [ $? -ne 0 ]
		then
			echo "TBROK Failed to execute main binary"
			exit;
		else
			check_task=$!;
		fi;
		;;

	"2")	# With group scheduling
		echo TINFO "Running cpuctl Latency Test 2"

		NUM_CPUS=`tst_ncpus`
		get_num_groups;	# NUM_GROUPS is set now
		do_setup;

		for num in $(seq 1 $NUM_TASKS)
		do
			group=/dev/cpuctl/group_`expr $num % $NUM_GROUPS + 1`;
			./cpuctl_latency_test $TEST_NUM $group &
			if [ $? -ne 0 ]
			then
				echo "TBROK Failed to execute binary"
				exit;
			else
				pid[$num]=$!;
			fi;
		done;

		# Calculate the alowed latency value
		./cpuctl_latency_check_task $TEST_NUM $$ $allowed_latency $group &
		if [ $? -ne 0 ]
		then
			echo "TBROK Failed to execute main binary";
			exit;
		else
			check_task=$!;
		fi;
		;;

	* )	# wrong test num
		echo TBROK "Invalid test number passed to the script"
		exit;
		;;
	esac;

	wait $check_task;
	RC=$?;  # Return status of the task being waited
	if [ $RC -ne 0 ]
	then
		echo "Task $check_task exited abnormaly with return value: $RC";
		echo TBROK "Test could'nt execute for expected duration";
	fi
	cd $PWD;