blob: 1e1389f2fd0b6c634c438a555cc63e0d7bd6f029 [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"
32LEAN_OPTS="$LEAN_OPTS -DSQLITE_LIKE_DOESNT_MATCH_BLOB"
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"
drhed90a462016-05-21 00:45:54 +000039doExplain=0
40doCachegrind=1
41while test "$1" != ""; do
42 case $1 in
43 --reprepare)
44 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
45 ;;
46 --autovacuum)
47 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
48 ;;
49 --utf16be)
50 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
51 ;;
52 --stats)
53 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
54 ;;
55 --without-rowid)
56 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
57 ;;
58 --nomemstat)
59 SPEEDTEST_OPTS="$SPEEDTEST_OPTS $1"
60 ;;
61 --temp)
62 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --temp 6"
63 ;;
64 --wal)
65 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --journal wal"
66 ;;
67 --size)
68 shift; SIZE=$1
69 ;;
drh98ef26b2016-09-21 23:58:49 +000070 --cachesize)
71 shift; SPEEDTEST_OPTS="$SPEEDTEST_OPTS --cachesize $1"
72 ;;
drhed90a462016-05-21 00:45:54 +000073 --explain)
74 doExplain=1
75 ;;
76 --vdbeprofile)
77 rm -f vdbe_profile.out
78 CC_OPTS="$CC_OPTS -DVDBE_PROFILE"
79 doCachegrind=0
80 ;;
drh98ef26b2016-09-21 23:58:49 +000081 --lean)
82 CC_OPTS="$CC_OPTS $LEAN_OPTS"
83 ;;
drh50828672017-01-20 16:09:12 +000084 --clang)
85 CC=clang
86 ;;
drhed90a462016-05-21 00:45:54 +000087 --heap)
88 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_MEMSYS5"
89 shift;
90 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --heap $1 64"
91 ;;
drh50828672017-01-20 16:09:12 +000092 --lookaside)
93 shift;
94 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --lookaside $1 $2"
95 shift;
96 ;;
drhf8a89ca2016-10-18 14:35:55 +000097 --repeat)
98 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_RCACHE"
99 shift;
100 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --repeat $1"
101 ;;
drh26f41982016-12-12 23:24:08 +0000102 --mmap)
103 shift;
104 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --mmap $1"
105 ;;
drh50828672017-01-20 16:09:12 +0000106 --rtree)
107 SPEEDTEST_OPTS="$SPEEDTEST_OPTS --testset rtree"
108 CC_OPTS="$CC_OPTS -DSQLITE_ENABLE_RTREE"
109 ;;
drhed90a462016-05-21 00:45:54 +0000110 *)
111 CC_OPTS="$CC_OPTS $1"
112 ;;
113 esac
114 shift
115done
116SPEEDTEST_OPTS="$SPEEDTEST_OPTS --size $SIZE"
117echo "NAME = $NAME" | tee summary-$NAME.txt
118echo "SPEEDTEST_OPTS = $SPEEDTEST_OPTS" | tee -a summary-$NAME.txt
119echo "CC_OPTS = $CC_OPTS" | tee -a summary-$NAME.txt
120rm -f cachegrind.out.* speedtest1 speedtest1.db sqlite3.o
drh50828672017-01-20 16:09:12 +0000121$CC -g -Os -Wall -I. $CC_OPTS -c sqlite3.c
drhed90a462016-05-21 00:45:54 +0000122size sqlite3.o | tee -a summary-$NAME.txt
123if test $doExplain -eq 1; then
drh50828672017-01-20 16:09:12 +0000124 $CC -g -Os -Wall -I. $CC_OPTS \
drhed90a462016-05-21 00:45:54 +0000125 -DSQLITE_ENABLE_EXPLAIN_COMMENTS \
126 ./shell.c ./sqlite3.c -o sqlite3 -ldl -lpthread
127fi
128SRC=./speedtest1.c
drh50828672017-01-20 16:09:12 +0000129$CC -g -Os -Wall -I. $CC_OPTS $SRC ./sqlite3.o -o speedtest1 -ldl -lpthread
drhed90a462016-05-21 00:45:54 +0000130ls -l speedtest1 | tee -a summary-$NAME.txt
131if test $doCachegrind -eq 1; then
132 valgrind --tool=cachegrind ./speedtest1 speedtest1.db \
133 $SPEEDTEST_OPTS 2>&1 | tee -a summary-$NAME.txt
134else
135 ./speedtest1 speedtest1.db $SPEEDTEST_OPTS 2>&1 | tee -a summary-$NAME.txt
136fi
137size sqlite3.o | tee -a summary-$NAME.txt
138wc sqlite3.c
139if test $doCachegrind -eq 1; then
140 cg_anno.tcl cachegrind.out.* >cout-$NAME.txt
141fi
142if test $doExplain -eq 1; then
143 ./speedtest1 --explain $SPEEDTEST_OPTS | ./sqlite3 >explain-$NAME.txt
144fi
drh27c84672017-01-28 13:40:55 +0000145if test "$NAME" != "trunk"; then
146 fossil test-diff --tk cout-trunk.txt cout-$NAME.txt
147fi