blob: 879ffa9562b70d618d3a204e27ab08c29e36ff65 [file] [log] [blame]
drhed90a462016-05-21 00:45:54 +00001#!/bin/bash
2#
3# This is a template for a script used for day-to-day size and
4# performance monitoring of SQLite. Typical usage:
5#
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
9#
10# There are multiple output files, all with a base name given by
11# the first argument:
12#
13# summary-$BASE.txt # Copy of standard output
14# cout-$BASE.txt # cachegrind output
15# explain-$BASE.txt # EXPLAIN listings (only with --explain)
16#
17if test "$1" = ""
18then
19 echo "Usage: $0 OUTPUTFILE [OPTIONS]"
20 exit
21fi
22NAME=$1
23shift
drh98ef26b2016-09-21 23:58:49 +000024#CC_OPTS="-DSQLITE_ENABLE_RTREE -DSQLITE_ENABLE_MEMSYS5"
25CC_OPTS="-DSQLITE_ENABLE_MEMSYS5"
drh50828672017-01-20 16:09:12 +000026CC=gcc
drh98ef26b2016-09-21 23:58:49 +000027SPEEDTEST_OPTS="--shrink-memory --reprepare --stats --heap 10000000 64"
drhed90a462016-05-21 00:45:54 +000028SIZE=5
drh98ef26b2016-09-21 23:58:49 +000029LEAN_OPTS="-DSQLITE_THREADSAFE=0"
30LEAN_OPTS="$LEAN_OPTS -DSQLITE_DEFAULT_MEMSTATUS=0"
31LEAN_OPTS="$LEAN_OPTS -DSQLITE_DEFAULT_WAL_SYNCHRONOUS=1"
drhff0a67a2017-10-11 12:20:36 +000032LEAN_OPTS="$LEAN_OPTS -DSQLITE_LIKE_DOESNT_MATCH_BLOBS"
drh87f0e982016-09-24 01:41:59 +000033LEAN_OPTS="$LEAN_OPTS -DSQLITE_MAX_EXPR_DEPTH=0"
drh98ef26b2016-09-21 23:58:49 +000034LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_DECLTYPE"
35LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_DEPRECATED"
36LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_PROGRESS_CALLBACK"
37LEAN_OPTS="$LEAN_OPTS -DSQLITE_OMIT_SHARED_CACHE"
drh1a7df582016-10-01 23:55:23 +000038LEAN_OPTS="$LEAN_OPTS -DSQLITE_USE_ALLOCA"
drhff0a67a2017-10-11 12:20:36 +000039BASELINE="trunk"
drhed90a462016-05-21 00:45:54 +000040doExplain=0
41doCachegrind=1
drhc083cb42018-02-12 20:50:28 +000042doVdbeProfile=0
drh7436f1e2018-02-20 17:02:31 +000043doWal=1
drhcf8784c2018-05-24 16:18:35 +000044doDiff=1
drhed90a462016-05-21 00:45:54 +000045while test "$1" != ""; do
46 case $1 in
drhcf8784c2018-05-24 16:18:35 +000047 --nodiff)
48 doDiff=0
49 ;;
drhed90a462016-05-21 00:45:54 +000050 --reprepare)
51 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
52 ;;
53 --autovacuum)
54 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
55 ;;
56 --utf16be)
57 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
58 ;;
59 --stats)
60 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
61 ;;
62 --without-rowid)
63 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
64 ;;
drh80b957b2021-11-03 12:50:28 +000065 --strict)
66 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
67 ;;
drhed90a462016-05-21 00:45:54 +000068 --nomemstat)
69 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
70 ;;
drhe47d5ca2019-09-21 13:34:59 +000071 --multithread)
72 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
73 ;;
74 --singlethread)
75 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
76 ;;
77 --serialized)
78 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
79 ;;
drhed90a462016-05-21 00:45:54 +000080 --temp)
81 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --temp 6"
82 ;;
drh7436f1e2018-02-20 17:02:31 +000083 --legacy)
84 doWal=0
drh3c99dbb2020-06-26 14:05:58 +000085 CC_OPTS="$CC_OPTS -DSPEEDTEST_OMIT_HASH"
86 ;;
87 --verify)
88 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --verify"
drh7436f1e2018-02-20 17:02:31 +000089 ;;
drhed90a462016-05-21 00:45:54 +000090 --wal)
drh7436f1e2018-02-20 17:02:31 +000091 doWal=1
drhed90a462016-05-21 00:45:54 +000092 ;;
93 --size)
94 shift; SIZE=$1
95 ;;
drh98ef26b2016-09-21 23:58:49 +000096 --cachesize)
97 shift; SPEEDTEST_OPTS="$SPEEDTEST_OPTS --cachesize $1"
98 ;;
drh3e4e6972022-09-12 16:07:24 +000099 --stmtcache)
100 shift; SPEEDTEST_OPTS="$SPEEDTEST_OPTS --stmtcache $1"
101 ;;
drhb1949342020-08-07 14:47:55 +0000102 --checkpoint)
103 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --checkpoint"
104 ;;
drhed90a462016-05-21 00:45:54 +0000105 --explain)
106 doExplain=1
107 ;;
108 --vdbeprofile)
109 rm -f vdbe_profile.out
110 CC_OPTS="$CC_OPTS -DVDBE_PROFILE"
111 doCachegrind=0
drhc083cb42018-02-12 20:50:28 +0000112 doVdbeProfile=1
drhed90a462016-05-21 00:45:54 +0000113 ;;
drh98ef26b2016-09-21 23:58:49 +0000114 --lean)
115 CC_OPTS="$CC_OPTS $LEAN_OPTS"
116 ;;
drh50828672017-01-20 16:09:12 +0000117 --clang)
118 CC=clang
119 ;;
drh2aa31332017-07-08 22:30:30 +0000120 --icc)
121 CC=/home/drh/intel/bin/icc
122 ;;
123 --gcc7)
124 CC=gcc-7
125 ;;
drhed90a462016-05-21 00:45:54 +0000126 --heap)
127 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_MEMSYS5"
128 shift;
129 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --heap $1 64"
130 ;;
drh50828672017-01-20 16:09:12 +0000131 --lookaside)
132 shift;
133 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --lookaside $1 $2"
134 shift;
135 ;;
drhf8a89ca2016-10-18 14:35:55 +0000136 --repeat)
137 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_RCACHE"
138 shift;
139 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --repeat $1"
140 ;;
drh26f41982016-12-12 23:24:08 +0000141 --mmap)
142 shift;
143 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --mmap $1"
144 ;;
drh50828672017-01-20 16:09:12 +0000145 --rtree)
146 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset rtree"
147 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_RTREE"
148 ;;
drh3e4e6972022-09-12 16:07:24 +0000149 --persist)
150 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --persist"
151 ;;
drh2aa31332017-07-08 22:30:30 +0000152 --orm)
153 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset orm"
154 ;;
danf6c37db2017-12-26 14:30:44 +0000155 --cte)
156 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset cte"
157 ;;
158 --fp)
159 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset fp"
160 ;;
drhff0a67a2017-10-11 12:20:36 +0000161 -*)
drhed90a462016-05-21 00:45:54 +0000162 CC_OPTS="$CC_OPTS $1"
163 ;;
drhff0a67a2017-10-11 12:20:36 +0000164 *)
165 BASELINE=$1
166 ;;
drhed90a462016-05-21 00:45:54 +0000167 esac
168 shift
169done
drh7436f1e2018-02-20 17:02:31 +0000170if test $doWal -eq 1; then
171 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --journal wal"
172fi
drhed90a462016-05-21 00:45:54 +0000173SPEEDTEST_OPTS="$SPEEDTEST_OPTS --size $SIZE"
174echo "NAME = $NAME" | tee summary-$NAME.txt
175echo "SPEEDTEST_OPTS = $SPEEDTEST_OPTS" | tee -a summary-$NAME.txt
176echo "CC_OPTS = $CC_OPTS" | tee -a summary-$NAME.txt
177rm -f cachegrind.out.* speedtest1 speedtest1.db sqlite3.o
drhc083cb42018-02-12 20:50:28 +0000178if test $doVdbeProfile -eq 1; then
179 rm -f vdbe_profile.out
180fi
drh50828672017-01-20 16:09:12 +0000181$CC -g -Os -Wall -I. $CC_OPTS -c sqlite3.c
drhed90a462016-05-21 00:45:54 +0000182size sqlite3.o | tee -a summary-$NAME.txt
183if test $doExplain -eq 1; then
drh50828672017-01-20 16:09:12 +0000184 $CC -g -Os -Wall -I. $CC_OPTS \
drhed90a462016-05-21 00:45:54 +0000185 -DSQLITE_ENABLE_EXPLAIN_COMMENTS \
186 ./shell.c ./sqlite3.c -o sqlite3 -ldl -lpthread
187fi
188SRC=./speedtest1.c
drh50828672017-01-20 16:09:12 +0000189$CC -g -Os -Wall -I. $CC_OPTS $SRC ./sqlite3.o -o speedtest1 -ldl -lpthread
drhed90a462016-05-21 00:45:54 +0000190ls -l speedtest1 | tee -a summary-$NAME.txt
191if test $doCachegrind -eq 1; then
192 valgrind --tool=cachegrind ./speedtest1 speedtest1.db \
193 $SPEEDTEST_OPTS 2>&1 | tee -a summary-$NAME.txt
194else
195 ./speedtest1 speedtest1.db $SPEEDTEST_OPTS 2>&1 | tee -a summary-$NAME.txt
196fi
197size sqlite3.o | tee -a summary-$NAME.txt
198wc sqlite3.c
199if test $doCachegrind -eq 1; then
200 cg_anno.tcl cachegrind.out.* >cout-$NAME.txt
drhdccf4f22017-08-12 02:16:34 +0000201 echo '*****************************************************' >>cout-$NAME.txt
202 sed 's/^[0-9=-]\{9\}/==00000==/' summary-$NAME.txt >>cout-$NAME.txt
drhed90a462016-05-21 00:45:54 +0000203fi
204if test $doExplain -eq 1; then
205 ./speedtest1 --explain $SPEEDTEST_OPTS | ./sqlite3 >explain-$NAME.txt
206fi
drhc083cb42018-02-12 20:50:28 +0000207if test $doVdbeProfile -eq 1; then
208 tclsh ../sqlite/tool/vdbe_profile.tcl >vdbeprofile-$NAME.txt
209 open vdbeprofile-$NAME.txt
210fi
drhcf8784c2018-05-24 16:18:35 +0000211if test "$NAME" != "$BASELINE" -a $doVdbeProfile -ne 1 -a $doDiff -ne 0; then
drhff0a67a2017-10-11 12:20:36 +0000212 fossil test-diff --tk -c 20 cout-$BASELINE.txt cout-$NAME.txt
drh27c84672017-01-28 13:40:55 +0000213fi