123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- #!/bin/bash
- #
- # This is a template for a script used for day-to-day size and
- # performance monitoring of SQLite. Typical usage:
- #
- # sh speed-check.sh trunk # Baseline measurement of trunk
- # sh speed-check.sh x1 # Measure some experimental change
- # fossil xdiff --tk cout-trunk.txt cout-x1.txt # View chanages
- #
- # There are multiple output files, all with a base name given by
- # the first argument:
- #
- # summary-$BASE.txt # Copy of standard output
- # cout-$BASE.txt # cachegrind output
- # explain-$BASE.txt # EXPLAIN listings (only with --explain)
- #
- if test "$1" = ""
- then
- echo "Usage: $0 OUTPUTFILE [OPTIONS]"
- exit
- fi
- NAME=$1
- shift
- #CC_OPTS="-DSQLITE_ENABLE_RTREE -DSQLITE_ENABLE_MEMSYS5"
- CC_OPTS="-DSQLITE_ENABLE_MEMSYS5"
- CC=gcc
- SPEEDTEST_OPTS="--shrink-memory --reprepare --stats --heap 10000000 64"
- SIZE=5
- LEAN_OPTS="-DSQLITE_THREADSAFE=0"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_DEFAULT_MEMSTATUS=0"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_DEFAULT_WAL_SYNCHRONOUS=1"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_LIKE_DOESNT_MATCH_BLOBS"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_MAX_EXPR_DEPTH=0"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_DECLTYPE"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_DEPRECATED"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_PROGRESS_CALLBACK"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_SHARED_CACHE"
- LEAN_OPTS="$LEAN_OPTS -DSQLITE_USE_ALLOCA"
- BASELINE="trunk"
- doExplain=0
- doCachegrind=1
- doVdbeProfile=0
- doWal=1
- doDiff=1
- while test "$1" != ""; do
- case $1 in
- --nodiff)
- doDiff=0
- ;;
- --reprepare)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --autovacuum)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --utf16be)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --stats)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --without-rowid)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --strict)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --nomemstat)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --multithread)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --singlethread)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --serialized)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
- ;;
- --temp)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --temp 6"
- ;;
- --legacy)
- doWal=0
- CC_OPTS="$CC_OPTS -DSPEEDTEST_OMIT_HASH"
- ;;
- --verify)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --verify"
- ;;
- --wal)
- doWal=1
- ;;
- --size)
- shift; SIZE=$1
- ;;
- --cachesize)
- shift; SPEEDTEST_OPTS="$SPEEDTEST_OPTS --cachesize $1"
- ;;
- --stmtcache)
- shift; SPEEDTEST_OPTS="$SPEEDTEST_OPTS --stmtcache $1"
- ;;
- --checkpoint)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --checkpoint"
- ;;
- --explain)
- doExplain=1
- ;;
- --vdbeprofile)
- rm -f vdbe_profile.out
- CC_OPTS="$CC_OPTS -DVDBE_PROFILE"
- doCachegrind=0
- doVdbeProfile=1
- ;;
- --lean)
- CC_OPTS="$CC_OPTS $LEAN_OPTS"
- ;;
- --clang)
- CC=clang
- ;;
- --icc)
- CC=/home/drh/intel/bin/icc
- ;;
- --gcc7)
- CC=gcc-7
- ;;
- --heap)
- CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_MEMSYS5"
- shift;
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --heap $1 64"
- ;;
- --lookaside)
- shift;
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --lookaside $1 $2"
- shift;
- ;;
- --repeat)
- CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_RCACHE"
- shift;
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --repeat $1"
- ;;
- --mmap)
- shift;
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --mmap $1"
- ;;
- --rtree)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset rtree"
- CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_RTREE"
- ;;
- --persist)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --persist"
- ;;
- --orm)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset orm"
- ;;
- --cte)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset cte"
- ;;
- --fp)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset fp"
- ;;
- --parsenumber)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset parsenumber"
- ;;
- --stmtscanstatus)
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --stmtscanstatus"
- ;;
- -*)
- CC_OPTS="$CC_OPTS $1"
- ;;
- *)
- BASELINE=$1
- ;;
- esac
- shift
- done
- if test $doWal -eq 1; then
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --journal wal"
- fi
- SPEEDTEST_OPTS="$SPEEDTEST_OPTS --size $SIZE"
- echo "NAME = $NAME" | tee summary-$NAME.txt
- echo "SPEEDTEST_OPTS = $SPEEDTEST_OPTS" | tee -a summary-$NAME.txt
- echo "CC_OPTS = $CC_OPTS" | tee -a summary-$NAME.txt
- rm -f cachegrind.out.* speedtest1 speedtest1.db sqlite3.o
- if test $doVdbeProfile -eq 1; then
- rm -f vdbe_profile.out
- fi
- $CC -g -Os -Wall -I. $CC_OPTS -c sqlite3.c
- size sqlite3.o | tee -a summary-$NAME.txt
- if test $doExplain -eq 1; then
- $CC -g -Os -Wall -I. $CC_OPTS \
- -DSQLITE_ENABLE_EXPLAIN_COMMENTS \
- ./shell.c ./sqlite3.c -o sqlite3 -ldl -lpthread
- fi
- SRC=./speedtest1.c
- $CC -g -Os -Wall -I. $CC_OPTS $SRC ./sqlite3.o -o speedtest1 -ldl -lpthread
- ls -l speedtest1 | tee -a summary-$NAME.txt
- if test $doCachegrind -eq 1; then
- valgrind --tool=cachegrind ./speedtest1 speedtest1.db \
- $SPEEDTEST_OPTS 2>&1 | tee -a summary-$NAME.txt
- else
- ./speedtest1 speedtest1.db $SPEEDTEST_OPTS 2>&1 | tee -a summary-$NAME.txt
- fi
- size sqlite3.o | tee -a summary-$NAME.txt
- wc sqlite3.c
- if test $doCachegrind -eq 1; then
- cg_anno.tcl cachegrind.out.* >cout-$NAME.txt
- echo '*****************************************************' >>cout-$NAME.txt
- sed 's/^[0-9=-]\{9\}/==00000==/' summary-$NAME.txt >>cout-$NAME.txt
- fi
- if test $doExplain -eq 1; then
- ./speedtest1 --explain $SPEEDTEST_OPTS | ./sqlite3 >explain-$NAME.txt
- fi
- if test $doVdbeProfile -eq 1; then
- tclsh ../sqlite/tool/vdbe_profile.tcl >vdbeprofile-$NAME.txt
- open vdbeprofile-$NAME.txt
- fi
- if test "$NAME" != "$BASELINE" -a $doVdbeProfile -ne 1 -a $doDiff -ne 0; then
- fossil test-diff --tk -c 20 cout-$BASELINE.txt cout-$NAME.txt
- fi
|