3 # This is a template for a script used for day-to-day size and
4 # performance monitoring of SQLite. Typical usage:
6 # sh run-speed-test.sh trunk # Baseline measurement of trunk
7 # sh run-speed-test.sh x1 # Measure some experimental change
8 # fossil test-diff --tk cout-trunk.txt cout-x1.txt # View chanages
10 # There are multiple output files, all with a base name given by
13 # summary-$BASE.txt # Copy of standard output
14 # cout-$BASE.txt # cachegrind output
15 # explain-$BASE.txt # EXPLAIN listings (only with --explain)
19 echo "Usage: $0 OUTPUTFILE [OPTIONS]"
24 #CC_OPTS="-DSQLITE_ENABLE_RTREE -DSQLITE_ENABLE_MEMSYS5"
25 CC_OPTS
="-DSQLITE_ENABLE_MEMSYS5"
27 SPEEDTEST_OPTS
="--shrink-memory --reprepare --stats --heap 10000000 64"
29 LEAN_OPTS
="-DSQLITE_THREADSAFE=0"
30 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_DEFAULT_MEMSTATUS=0"
31 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_DEFAULT_WAL_SYNCHRONOUS=1"
32 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_LIKE_DOESNT_MATCH_BLOBS"
33 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_MAX_EXPR_DEPTH=0"
34 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_OMIT_DECLTYPE"
35 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_OMIT_DEPRECATED"
36 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_OMIT_PROGRESS_CALLBACK"
37 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_OMIT_SHARED_CACHE"
38 LEAN_OPTS
="$LEAN_OPTS -DSQLITE_USE_ALLOCA"
45 while test "$1" != ""; do
51 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS $1"
54 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS $1"
57 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS $1"
60 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS $1"
63 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS $1"
66 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS $1"
69 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --temp 6"
81 shift; SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --cachesize $1"
87 rm -f vdbe_profile.out
88 CC_OPTS
="$CC_OPTS -DVDBE_PROFILE"
93 CC_OPTS
="$CC_OPTS $LEAN_OPTS"
99 CC
=/home
/drh
/intel
/bin
/icc
105 CC_OPTS
="$CC_OPTS -DSQLITE_ENABLE_MEMSYS5"
107 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --heap $1 64"
111 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --lookaside $1 $2"
115 CC_OPTS
="$CC_OPTS -DSQLITE_ENABLE_RCACHE"
117 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --repeat $1"
121 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --mmap $1"
124 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --testset rtree"
125 CC_OPTS
="$CC_OPTS -DSQLITE_ENABLE_RTREE"
128 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --testset orm"
131 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --testset cte"
134 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --testset fp"
137 CC_OPTS
="$CC_OPTS $1"
145 if test $doWal -eq 1; then
146 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --journal wal"
148 SPEEDTEST_OPTS
="$SPEEDTEST_OPTS --size $SIZE"
149 echo "NAME = $NAME" |
tee summary-
$NAME.txt
150 echo "SPEEDTEST_OPTS = $SPEEDTEST_OPTS" |
tee -a summary-
$NAME.txt
151 echo "CC_OPTS = $CC_OPTS" |
tee -a summary-
$NAME.txt
152 rm -f cachegrind.out.
* speedtest1 speedtest1.db sqlite3.o
153 if test $doVdbeProfile -eq 1; then
154 rm -f vdbe_profile.out
156 $CC -g -Os -Wall -I.
$CC_OPTS -c sqlite3.c
157 size sqlite3.o |
tee -a summary-
$NAME.txt
158 if test $doExplain -eq 1; then
159 $CC -g -Os -Wall -I.
$CC_OPTS \
160 -DSQLITE_ENABLE_EXPLAIN_COMMENTS \
161 .
/shell.c .
/sqlite3.c
-o sqlite3
-ldl -lpthread
164 $CC -g -Os -Wall -I.
$CC_OPTS $SRC .
/sqlite3.o
-o speedtest1
-ldl -lpthread
165 ls -l speedtest1 |
tee -a summary-
$NAME.txt
166 if test $doCachegrind -eq 1; then
167 valgrind
--tool=cachegrind .
/speedtest1 speedtest1.db \
168 $SPEEDTEST_OPTS 2>&1 |
tee -a summary-
$NAME.txt
170 .
/speedtest1 speedtest1.db
$SPEEDTEST_OPTS 2>&1 |
tee -a summary-
$NAME.txt
172 size sqlite3.o |
tee -a summary-
$NAME.txt
174 if test $doCachegrind -eq 1; then
175 cg_anno.tcl cachegrind.out.
* >cout-
$NAME.txt
176 echo '*****************************************************' >>cout-
$NAME.txt
177 sed 's/^[0-9=-]\{9\}/==00000==/' summary-
$NAME.txt
>>cout-
$NAME.txt
179 if test $doExplain -eq 1; then
180 .
/speedtest1
--explain $SPEEDTEST_OPTS | .
/sqlite3
>explain-
$NAME.txt
182 if test $doVdbeProfile -eq 1; then
183 tclsh ..
/sqlite
/tool
/vdbe_profile.tcl
>vdbeprofile-
$NAME.txt
184 open vdbeprofile-
$NAME.txt
186 if test "$NAME" != "$BASELINE" -a $doVdbeProfile -ne 1 -a $doDiff -ne 0; then
187 fossil test-diff
--tk -c 20 cout-
$BASELINE.txt cout-
$NAME.txt