| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 | #!/bin/bash## StarPU# Copyright (C) INRIA 2008-2009 (see AUTHORS file)## This program is free software; you can redistribute it and/or modify# it under the terms of the GNU Lesser General Public License as published by# the Free Software Foundation; either version 2.1 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 Lesser General Public License in COPYING.LGPL for more details.#maxiter=2calibrate_point(){	strat=$1	nblocks=$2	prefetch=$3	size=$(($nblocks * 1024))	echo "CALIBRATE size : $size / blocks : $nblocks strat -> $strat prefetch -> $prefetch"	rm -f $SAMPLINGDIR/*		for iter in `seq 1 $maxiter`	do		echo "$iter / $maxiter"		export SCHED=$strat		export CALIBRATE=1		export PREFETCH=$prefetch		val=`$ROOTDIR/examples/heat/heat -pin -nblocks $nblocks -size $size -v3 2> /dev/null`		echo "$val"	done}DIR=$PWDROOTDIR=$DIR/../..TIMINGDIR=$DIR/timings-dmda/SAMPLINGDIR=$DIR/sampling/export PERF_MODEL_DIR=$SAMPLINGDIRmkdir -p $TIMINGDIRmkdir -p $SAMPLINGDIR#schedlist="ws no-prio greedy prio dm random"#schedlist="random random random random"export NCUDA=3export NCPUS=8 #sizelist="2048 4096 6144 8192 10240 12288 14336 16384 24576 28672 30720"sizelist=`seq 2048 2048 30720`outputfile=dmda.datarm -f $outputfilefor size in $sizelistdo	nblocks=$(($size / 1024))	calibrate_point "dm" $nblocks 1	export SCHED="dm"	export CALIBRATE=1	export PREFETCH=1	valdm=$($ROOTDIR/examples/heat/heat -pin -size $size -nblocks $nblocks -v3 2> logdm)	calibrate_point "dmda" $nblocks 1	export SCHED="dmda"	export CALIBRATE=1	export PREFETCH=1	valdmda=$($ROOTDIR/examples/heat/heat -pin -size $size -nblocks $nblocks -v3 2> logdmda)		dmmiss=`grep "TOTAL MSI" logdm|sed -e "s/.*miss.*[1-9]* (\(.*\) %)/\1/"`	dmtotal=`grep "TOTAL transfers" logdm|sed -e "s/TOTAL transfers \(.*\) MB/\1/"`	dmdamiss=`grep "TOTAL MSI" logdmda|sed -e "s/.*miss.*[1-9]* (\(.*\) %)/\1/"`	dmdatotal=`grep "TOTAL transfers" logdmda|sed -e "s/TOTAL transfers \(.*\) MB/\1/"`	echo "$size	$dmmiss	$dmdamiss	$dmtotal	$dmdatotal	$valdm	$valdmda" >> $outputfile	echo "$size	$dmmiss	$dmdamiss	$dmtotal	$dmdatotal	$valdm	$valdmda" done
 |