Bash程序  |  137行  |  5.86 KB

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

#################################################################################
#  Copyright (c) International Business Machines  Corp., 2007                   #
#                                                                               #
#  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: parameters.sh                                                   #
#                                                                               #
# Description: 	This file has functions for the setup for testing cpucontroller #
#               setup includes creating controller device, mounting it with     #
#               cgroup filesystem with option cpu and creating groups in it.    #
#                                                                               #
# Functions:    get_num_groups(): decides number of groups based on num of cpus	#
#               setup(): creaes /dev/cpuctl, mounts cgroup fs on it, creates 	#
#               groups in that, creates fifo to fire tasks at one time.         #
#               cleanup(): Does full system cleanup                             #
#                                                                               #
# Author:       Sudhir Kumar   <skumar@linux.vnet.ibm.com>                      #
#                                                                               #
# History:                                                                      #
#                                                                               #
#  DATE         NAME           EMAIL                         DESC               #
#                                                                               #
#  20/12/07  Sudhir Kumar <skumar@linux.vnet.ibm.com>   Created this test       #
#                                                                               #
#################################################################################


set_def_group() #default group spinning a task to create ideal scenario
{
	[ -d /dev/cpuctl/group_def ] || mkdir /dev/cpuctl/group_def;
	if [ $? -ne 0 ]
	then
		echo "ERROR: Can't create default group... "
			"Check your permissions..Exiting test";
		cleanup;
		exit -1;
	fi
	# Migrate all the running tasks to this group
	# rt tasks require a finite value to cpu.rt_runtime_us
	echo 10000 > /dev/cpuctl/group_def/cpu.rt_runtime_us;
	for task in `cat /dev/cpuctl/tasks`; do
		echo $task > /dev/cpuctl/group_def/tasks 2>/dev/null 1>&2;
	done
}

get_num_groups()        # Number of tasks should be >= number of cpu's (to check scheduling fairness)
{
        NUM_GROUPS=$(( (NUM_CPUS*3 + 1)/2 ))
}

	# Write the cleanup function
cleanup ()
{
        echo "Cleanup called";
	killall cpuctl_def_task01 1>/dev/null 2>&1;
	killall cpuctl_def_task02 1>/dev/null 2>&1;
	killall cpuctl_task_* 1>/dev/null 2>&1;
	sleep 1
        rm -f cpuctl_task_* 2>/dev/null
	for task in `cat /dev/cpuctl/group_def/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 2>/dev/null

}
        # Create /dev/cpuctl &  mount the cgroup file system with cpu controller
        #clean any group created eralier (if any)

do_setup ()
{
        if [ -e /dev/cpuctl ]
        then
                echo "WARN:/dev/cpuctl already exist..overwriting"; # or a warning ?
                cleanup;
                mkdir /dev/cpuctl;
        else
                mkdir /dev/cpuctl
        fi
        mount -t cgroup -ocpu cgroup /dev/cpuctl 2> /dev/null
        if [ $? -ne 0 ]
        then
                echo "ERROR: Could not mount cgroup filesystem on /dev/cpuctl..Exiting test";
                cleanup;
                exit -1;
        fi

        # Group created earlier may again be visible if not cleaned properly...so clean them
	groups=/dev/cpuctl/group*
        if [ -z "$groups" ]
        then
                rmdir /dev/cpuctl/group*
                echo "WARN: Earlier groups found and removed...";
        fi

        #Create a fifo to make all tasks wait on it
        mkfifo myfifo 2> /dev/null;
        if [ $? -ne 0 ]
        then
                echo "ERROR: Can't create fifo...Check your permissions..Exiting test";
                cleanup;
                exit -1;
        fi

        # Create different groups
        for i in $(seq 1 $NUM_GROUPS)
        do
                group=group_$i;
                mkdir /dev/cpuctl/$group;# 2>/dev/null
                if [ $? -ne 0 ]
                then
                        echo "ERROR: Can't create $group...Check your permissions..Exiting test";
                        cleanup;
                        exit -1;
                fi
        done
}