2013-09-29 05:12:21 +08:00
|
|
|
#!/bin/bash
|
|
|
|
#
|
|
|
|
# Run a series of 14 tests under KVM. These are not particularly
|
|
|
|
# well-selected or well-tuned, but are the current set. Run from the
|
|
|
|
# top level of the source tree.
|
|
|
|
#
|
|
|
|
# Edit the definitions below to set the locations of the various directories,
|
|
|
|
# as well as the test duration.
|
|
|
|
#
|
|
|
|
# Usage: sh kvm.sh [ options ]
|
|
|
|
#
|
|
|
|
# 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
|
2013-12-04 01:54:18 +08:00
|
|
|
# along with this program; if not, you can access it online at
|
|
|
|
# http://www.gnu.org/licenses/gpl-2.0.html.
|
2013-09-29 05:12:21 +08:00
|
|
|
#
|
|
|
|
# Copyright (C) IBM Corporation, 2011
|
|
|
|
#
|
|
|
|
# Authors: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
|
|
|
|
|
|
|
|
scriptname=$0
|
2013-10-01 05:49:43 +08:00
|
|
|
args="$*"
|
2013-09-29 05:12:21 +08:00
|
|
|
|
|
|
|
dur=30
|
2013-10-16 01:42:25 +08:00
|
|
|
KVM="`pwd`/tools/testing/selftests/rcutorture"; export KVM
|
2013-10-28 23:57:29 +08:00
|
|
|
PATH=${KVM}/bin:$PATH; export PATH
|
2013-10-16 01:42:25 +08:00
|
|
|
builddir="${KVM}/b1"
|
|
|
|
RCU_INITRD="$KVM/initrd"; export RCU_INITRD
|
2013-10-16 02:51:23 +08:00
|
|
|
RCU_KMAKE_ARG=""; export RCU_KMAKE_ARG
|
2013-09-29 05:12:21 +08:00
|
|
|
resdir=""
|
2013-09-30 02:13:46 +08:00
|
|
|
configs=""
|
2013-09-29 09:44:11 +08:00
|
|
|
ds=`date +%Y.%m.%d-%H:%M:%S`
|
2013-09-29 11:37:45 +08:00
|
|
|
kversion=""
|
2013-09-29 05:12:21 +08:00
|
|
|
|
2013-10-28 23:57:29 +08:00
|
|
|
. functions.sh
|
|
|
|
|
2013-09-29 05:12:21 +08:00
|
|
|
usage () {
|
|
|
|
echo "Usage: $scriptname optional arguments:"
|
2013-10-14 23:19:39 +08:00
|
|
|
echo " --bootargs kernel-boot-arguments"
|
2013-09-29 05:12:21 +08:00
|
|
|
echo " --builddir absolute-pathname"
|
2013-10-11 05:52:07 +08:00
|
|
|
echo " --buildonly"
|
2013-09-29 05:12:21 +08:00
|
|
|
echo " --configs \"config-file list\""
|
2013-09-29 09:44:11 +08:00
|
|
|
echo " --datestamp string"
|
2013-09-29 05:12:21 +08:00
|
|
|
echo " --duration minutes"
|
2013-10-05 04:15:55 +08:00
|
|
|
echo " --interactive"
|
2013-10-16 02:51:23 +08:00
|
|
|
echo " --kmake-arg kernel-make-arguments"
|
2013-09-29 11:37:45 +08:00
|
|
|
echo " --kversion vN.NN"
|
2013-10-05 04:15:55 +08:00
|
|
|
echo " --mac nn:nn:nn:nn:nn:nn"
|
2013-10-16 01:42:25 +08:00
|
|
|
echo " --no-initrd"
|
2013-10-16 00:22:48 +08:00
|
|
|
echo " --qemu-args qemu-system-..."
|
2013-10-01 08:17:57 +08:00
|
|
|
echo " --qemu-cmd qemu-system-..."
|
2013-09-29 05:12:21 +08:00
|
|
|
echo " --results absolute-pathname"
|
|
|
|
echo " --relbuilddir relative-pathname"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
while test $# -gt 0
|
|
|
|
do
|
|
|
|
case "$1" in
|
2013-10-14 23:19:39 +08:00
|
|
|
--bootargs)
|
|
|
|
checkarg --bootargs "(list of kernel boot arguments)" "$#" "$2" '.*' '^--'
|
|
|
|
RCU_BOOTARGS="$2"
|
|
|
|
shift
|
|
|
|
;;
|
2013-09-29 05:12:21 +08:00
|
|
|
--builddir)
|
2013-10-16 00:22:48 +08:00
|
|
|
checkarg --builddir "(absolute pathname)" "$#" "$2" '^/' '^error'
|
2013-09-29 05:12:21 +08:00
|
|
|
builddir=$2
|
|
|
|
gotbuilddir=1
|
|
|
|
shift
|
|
|
|
;;
|
2013-10-11 05:52:07 +08:00
|
|
|
--buildonly)
|
|
|
|
RCU_BUILDONLY=1; export RCU_BUILDONLY
|
|
|
|
;;
|
2013-09-29 05:12:21 +08:00
|
|
|
--configs)
|
|
|
|
checkarg --configs "(list of config files)" "$#" "$2" '^[^/]*$' '^--'
|
|
|
|
configs="$2"
|
|
|
|
shift
|
|
|
|
;;
|
2013-09-29 09:44:11 +08:00
|
|
|
--datestamp)
|
|
|
|
checkarg --datestamp "(relative pathname)" "$#" "$2" '^[^/]*$' '^--'
|
|
|
|
ds=$2
|
|
|
|
shift
|
|
|
|
;;
|
2013-09-29 05:12:21 +08:00
|
|
|
--duration)
|
2013-10-16 00:22:48 +08:00
|
|
|
checkarg --duration "(minutes)" $# "$2" '^[0-9]*$' '^error'
|
2013-09-29 05:12:21 +08:00
|
|
|
dur=$2
|
|
|
|
shift
|
|
|
|
;;
|
2013-10-05 04:15:55 +08:00
|
|
|
--interactive)
|
|
|
|
RCU_QEMU_INTERACTIVE=1; export RCU_QEMU_INTERACTIVE
|
|
|
|
;;
|
2013-10-16 02:51:23 +08:00
|
|
|
--kmake-arg)
|
|
|
|
checkarg --kmake-arg "(kernel make arguments)" $# "$2" '.*' '^error$'
|
|
|
|
RCU_KMAKE_ARG="$2"; export RCU_KMAKE_ARG
|
|
|
|
shift
|
|
|
|
;;
|
2013-09-29 11:37:45 +08:00
|
|
|
--kversion)
|
2013-10-16 00:22:48 +08:00
|
|
|
checkarg --kversion "(kernel version)" $# "$2" '^v[0-9.]*$' '^error'
|
2013-09-29 11:37:45 +08:00
|
|
|
kversion=$2
|
|
|
|
shift
|
|
|
|
;;
|
2013-10-05 04:15:55 +08:00
|
|
|
--mac)
|
|
|
|
checkarg --mac "(MAC address)" $# "$2" '^\([0-9a-fA-F]\{2\}:\)\{5\}[0-9a-fA-F]\{2\}$' error
|
|
|
|
RCU_QEMU_MAC=$2; export RCU_QEMU_MAC
|
|
|
|
shift
|
|
|
|
;;
|
2013-10-16 01:42:25 +08:00
|
|
|
--no-initrd)
|
|
|
|
RCU_INITRD=""; export RCU_INITRD
|
|
|
|
;;
|
2013-10-16 00:22:48 +08:00
|
|
|
--qemu-args)
|
|
|
|
checkarg --qemu-args "-qemu args" $# "$2" '^-' '^error'
|
|
|
|
RCU_QEMU_ARG="$2"
|
|
|
|
shift
|
|
|
|
;;
|
2013-10-01 08:17:57 +08:00
|
|
|
--qemu-cmd)
|
|
|
|
checkarg --qemu-cmd "(qemu-system-...)" $# "$2" 'qemu-system-' '^--'
|
|
|
|
RCU_QEMU_CMD="$2"; export RCU_QEMU_CMD
|
|
|
|
shift
|
|
|
|
;;
|
2013-09-29 05:12:21 +08:00
|
|
|
--relbuilddir)
|
|
|
|
checkarg --relbuilddir "(relative pathname)" "$#" "$2" '^[^/]*$' '^--'
|
|
|
|
relbuilddir=$2
|
|
|
|
gotrelbuilddir=1
|
|
|
|
builddir=${KVM}/${relbuilddir}
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--results)
|
2013-10-16 00:22:48 +08:00
|
|
|
checkarg --results "(absolute pathname)" "$#" "$2" '^/' '^error'
|
2013-09-29 05:12:21 +08:00
|
|
|
resdir=$2
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
*)
|
2013-10-02 01:14:09 +08:00
|
|
|
echo Unknown argument $1
|
2013-09-29 05:12:21 +08:00
|
|
|
usage
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
CONFIGFRAG=${KVM}/configs; export CONFIGFRAG
|
2013-09-30 02:13:46 +08:00
|
|
|
KVPATH=${CONFIGFRAG}/$kversion; export KVPATH
|
|
|
|
|
|
|
|
if test -z "$configs"
|
|
|
|
then
|
|
|
|
configs="`cat $CONFIGFRAG/$kversion/CFLIST`"
|
|
|
|
fi
|
2013-09-29 05:12:21 +08:00
|
|
|
|
|
|
|
if test -z "$resdir"
|
|
|
|
then
|
|
|
|
resdir=$KVM/res
|
2013-10-01 05:49:43 +08:00
|
|
|
if ! test -e $resdir
|
|
|
|
then
|
|
|
|
mkdir $resdir || :
|
|
|
|
fi
|
2013-09-29 05:12:21 +08:00
|
|
|
else
|
2013-10-01 05:49:43 +08:00
|
|
|
if ! test -e $resdir
|
|
|
|
then
|
|
|
|
mkdir -p "$resdir" || :
|
|
|
|
fi
|
2013-09-29 05:12:21 +08:00
|
|
|
fi
|
2013-09-29 09:44:11 +08:00
|
|
|
mkdir $resdir/$ds
|
2013-10-01 05:49:43 +08:00
|
|
|
touch $resdir/$ds/log
|
|
|
|
echo $scriptname $args >> $resdir/$ds/log
|
2013-09-29 09:44:11 +08:00
|
|
|
|
2013-09-29 05:12:21 +08:00
|
|
|
pwd > $resdir/$ds/testid.txt
|
|
|
|
if test -d .git
|
|
|
|
then
|
|
|
|
git status >> $resdir/$ds/testid.txt
|
|
|
|
git rev-parse HEAD >> $resdir/$ds/testid.txt
|
|
|
|
fi
|
|
|
|
builddir=$KVM/b1
|
2013-10-01 05:49:43 +08:00
|
|
|
if ! test -e $builddir
|
|
|
|
then
|
|
|
|
mkdir $builddir || :
|
|
|
|
fi
|
2013-09-29 05:12:21 +08:00
|
|
|
|
|
|
|
for CF in $configs
|
|
|
|
do
|
2013-10-19 21:28:21 +08:00
|
|
|
# Running TREE01 multiple times creates TREE01, TREE01.2, TREE01.3, ...
|
2013-09-29 05:12:21 +08:00
|
|
|
rd=$resdir/$ds/$CF
|
2013-10-19 21:28:21 +08:00
|
|
|
if test -d "${rd}"
|
|
|
|
then
|
|
|
|
n="`ls -d "${rd}"* | grep '\.[0-9]\+$' |
|
|
|
|
sed -e 's/^.*\.\([0-9]\+\)/\1/' |
|
|
|
|
sort -k1n | tail -1`"
|
|
|
|
if test -z "$n"
|
|
|
|
then
|
|
|
|
rd="${rd}.2"
|
|
|
|
else
|
|
|
|
n="`expr $n + 1`"
|
|
|
|
rd="${rd}.${n}"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
mkdir "${rd}"
|
2013-09-29 05:12:21 +08:00
|
|
|
echo Results directory: $rd
|
2013-10-16 00:22:48 +08:00
|
|
|
kvm-test-1-rcu.sh $CONFIGFRAG/$kversion/$CF $builddir $rd $dur "-nographic $RCU_QEMU_ARG" "rcutorture.test_no_idle_hz=1 rcutorture.verbose=1 $RCU_BOOTARGS"
|
2013-09-29 05:12:21 +08:00
|
|
|
done
|
2013-10-16 03:11:24 +08:00
|
|
|
# Tracing: trace_event=rcu:rcu_grace_period,rcu:rcu_future_grace_period,rcu:rcu_grace_period_init,rcu:rcu_nocb_wake,rcu:rcu_preempt_task,rcu:rcu_unlock_preempted_task,rcu:rcu_quiescent_state_report,rcu:rcu_fqs,rcu:rcu_callback,rcu:rcu_kfree_callback,rcu:rcu_batch_start,rcu:rcu_invoke_callback,rcu:rcu_invoke_kfree_callback,rcu:rcu_batch_end,rcu:rcu_torture_read,rcu:rcu_barrier
|
2013-10-16 03:22:32 +08:00
|
|
|
|
|
|
|
echo " --- `date` Test summary:"
|
|
|
|
kvm-recheck.sh $resdir/$ds
|