X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=scripts%2Fbench.sh;h=a4dd0d29ceb1a65b63d0e8f8145d17eed7325b16;hb=f2d07766cf347820f07bd0dc186c13b2b0fc626a;hp=4973e7b2e9261da2faf64e0d912b0cffad48a83c;hpb=7c2cde691b9eb061a0682a7971c63f2c42b39c2c;p=testub10.git diff --git a/scripts/bench.sh b/scripts/bench.sh index 4973e7b..a4dd0d2 100755 --- a/scripts/bench.sh +++ b/scripts/bench.sh @@ -48,12 +48,6 @@ for i in $TEST/*.0; do # create executable gcc -DCALL=\"${i%.0}.call\" -o $TMPNAME $TMPNAME.s $TESTMAIN $CALLCONV - # count instructions - $DUMPINSTR $TMPNAME call >/dev/null - if [ $? != 0 ]; then - echo "$bi FEHLGESCHLAGEN" - continue - fi # extract the exported symbols from the .s file #LABEL=`grep '.globl' $TMPNAME.s | sed 's/^.*\\.globl *\\([a-zA-Z0-9_]\\+\\).*$/\1/g'` @@ -61,9 +55,16 @@ for i in $TEST/*.0; do # this won't work, we need all actual labels LABEL=`grep '[a-zA-Z0-9_.$]\\+:' $TMPNAME.s | sed 's/^\\(.*[^a-zA-Z0-9_.$]\\)\\?\\([a-zA-Z0-9_.$]\\+\\):.*$/\2/g'` + rm -f $TMPNAME.trace MATCHES=0 for j in $LABEL; do - MATCHES="$MATCHES\\|$j" + MATCHES="$MATCHES\\|$j" + # count instructions + $DUMPINSTR $TMPNAME $j > /dev/null + if [ $? != 0 ]; then + echo "$bi FEHLGESCHLAGEN" + continue + fi done # filter trace @@ -76,7 +77,21 @@ for i in $TEST/*.0; do echo "err: fuer den testfall \"$bi\" existiert noch keine referenzdatei" ti=0 fi - echo "$bi: $ni (referenz: $ti)" + + if [ $ni -gt $ti ]; then + #red + bcolor="\033[01;31m" + else + if [ $ni -eq $ti ]; then + #gray + bcolor="\033[01;30m" + else + #green + bcolor="\033[01;32m" + fi + fi + + echo -e "$bcolor $bi: $ni (referenz: $ti) \033[0m" echo "$bi $ni" >> $RESULT let gni=gni+$ni