minix/commands/worldstone/worldstone.sh
Ben Gras bc0a39238e worldstone benchmark script
. also imports seq(1) to help it
	. add -C option to time(1) to print tsc difference
	. increase col width for ministat for tsc numbers
2011-09-24 14:49:55 +00:00

57 lines
1.2 KiB
Bash

if [ ! "$MAKE" ]; then MAKE=make; fi
ITERATIONS=5
PRECMD="$MAKE clean"
COMMAND="$MAKE all"
TAG=time.$(basename $(git --git-dir=/usr/src/.git describe --all --dirty))
set -e
while getopts "n:d:p:c:r:" c
do
case "$c" in
n) ITERATIONS=$OPTARG ;;
p) PRECMD="$OPTARG" ;;
c) COMMAND="$OPTARG" ;;
t) TAG=$OPTARG ;;
r) echo "Reading settings from $OPTARG"; cat $OPTARG; . $OPTARG ; echo "Reading done.";;
*) exit 1 ;;
esac
done
CONFIGPREFIX=".worldstone"
CONFIGVARS="ITERATIONS PRECMD COMMAND MAKE"
TMPF=.worldstone.tmpconfig.$$
rm -f $TMPF
for d in $CONFIGVARS
do eval "echo $d=\\\"\$$d\\\"" >>$TMPF
done
CONFIGTAG=`crc <$TMPF | awk '{ print $1 }'`
CONFIGFILE=$CONFIGPREFIX.$CONFIGTAG
mv -f $TMPF $CONFIGFILE
LOGFILE=$TAG.worldstone.log
while [ -f $LOGFILE ]
do echo "$0: WARNING: $LOGFILE already exists, appending."
LOGFILE=$LOGFILE.next
done
echo "Logging to $LOGFILE."
echo "First run."
sh -c "$PRECMD"
sh -c "$COMMAND"
for n in `seq 1 $ITERATIONS`
do echo -n "$n"
sh -c "$PRECMD >/dev/null 2>&1"
echo -n "."
sync
time -C sh -c "$COMMAND >/dev/null 2>&1; sync" 2>>$LOGFILE
echo -n " "
done
echo "Done."
echo "Time measurements logfile is $LOGFILE."
echo "Config file is $CONFIGFILE."