Rework all.sh to use MSan instead of valgrind

This commit is contained in:
Manuel Pégourié-Gonnard 2014-11-20 13:10:22 +01:00
parent cf4de32f58
commit 9bda9b3b92

View file

@ -6,8 +6,8 @@
# CMake configuration. After this script is run, the CMake cache is lost and # CMake configuration. After this script is run, the CMake cache is lost and
# CMake is not initialised any more! # CMake is not initialised any more!
# #
# Assumes gcc and clang (recent enough for using ASan) are available, # Assumes gcc and clang (recent enough for using ASan with gcc and MemSen with
# as well as cmake and valgrind. # clang) are available, as well as cmake and GNU find.
# Abort on errors (and uninitiliased variables) # Abort on errors (and uninitiliased variables)
set -eu set -eu
@ -24,12 +24,9 @@ MEMORY=0
while [ $# -gt 0 ]; do while [ $# -gt 0 ]; do
case "$1" in case "$1" in
-m1) -m*)
MEMORY=1 MEMORY=1
;; ;;
-m2)
MEMORY=2
;;
*) *)
echo "Unknown argument: '$1'" >&2 echo "Unknown argument: '$1'" >&2
echo "Use the source, Luke!" >&2 echo "Use the source, Luke!" >&2
@ -60,7 +57,8 @@ msg()
{ {
echo "" echo ""
echo "******************************************************************" echo "******************************************************************"
echo "* $1" echo "* $1 "
echo -n "* "; date
echo "******************************************************************" echo "******************************************************************"
} }
@ -72,28 +70,20 @@ msg()
# #
# Indicative running times are given for reference. # Indicative running times are given for reference.
msg "build: cmake, -Werror (gcc)" # ~ 1 min msg "build: cmake, gcc, ASan" # ~ 1 min
cleanup cleanup
CC=gcc cmake -D CMAKE_BUILD_TYPE:String=Check . CC=gcc cmake -D CMAKE_BUILD_TYPE:String=Asan .
make make
msg "test: main suites with valgrind" # ~ 2 min 10s msg "test: main suites and selftest (ASan build)" # ~ 10s + 30s
make memcheck make test
programs/test/selftest
msg "build: with ASan (clang)" # ~ 1 min
cleanup
CC=clang cmake -D CMAKE_BUILD_TYPE:String=ASan .
make
msg "test: ssl-opt.sh (ASan build)" # ~ 1 min 10s msg "test: ssl-opt.sh (ASan build)" # ~ 1 min 10s
cd tests cd tests
./ssl-opt.sh ./ssl-opt.sh
cd .. cd ..
msg "test: main suites and selftest (ASan build)" # ~ 10s + 30s
make test
programs/test/selftest
msg "test: ref-configs (ASan build)" # ~ 4 min 45 s msg "test: ref-configs (ASan build)" # ~ 4 min 45 s
tests/scripts/test-ref-configs.pl tests/scripts/test-ref-configs.pl
@ -107,15 +97,15 @@ cd tests
./compat.sh ./compat.sh
cd .. cd ..
msg "build: cmake, full config" # ~ 40s msg "build: cmake, full config, clang" # ~ 40s
cleanup cleanup
cp "$CONFIG_H" "$CONFIG_BAK" cp "$CONFIG_H" "$CONFIG_BAK"
scripts/config.pl full scripts/config.pl full
scripts/config.pl unset POLARSSL_MEMORY_BACKTRACE # too slow for tests scripts/config.pl unset POLARSSL_MEMORY_BACKTRACE # too slow for tests
cmake -D CMAKE_BUILD_TYPE:String=Check . CC=clang cmake -D CMAKE_BUILD_TYPE:String=Check .
make make
msg "test: main suites (full config)" msg "test: main suites (full config)" # ~ 30s (?)
make test make test
msg "test: ssl-opt.sh default (full config)" msg "test: ssl-opt.sh default (full config)"
@ -132,22 +122,30 @@ msg "build: Unix make, -O2 (gcc)" # ~ 30s
cleanup cleanup
CC=gcc make CC=gcc make
# Optional parts that take a long time to run msg "build: MSan (clang)" # ~ 1 min 30s
cleanup
cp "$CONFIG_H" "$CONFIG_BAK"
scripts/config.pl unset POLARSSL_AESNI_C # memsan doesn't grok asm
CC=clang cmake -D CMAKE_BUILD_TYPE:String=MemSan .
make
if [ "$MEMORY" -ge 1 ]; then msg "test: main suites (MSan)" # ~ 15s
msg "test: ssl-opt --memcheck (-02 build)" # ~ 8 min make test
msg "test: ssl-opt.sh (MSan)" # ~ 1 min
cd tests
./ssl-opt.sh
cd ..
# Optional part(s)
if [ "$MEMORY" -gt 0 ]; then
msg "test: compat.sh (MSan)" # ~ 6 min 20s
cd tests cd tests
./ssl-opt.sh --memcheck ./compat.sh
cd .. cd ..
if [ "$MEMORY" -ge 2 ]; then
msg "test: compat --memcheck (-02 build)" # ~ 42 min
cd tests
./compat.sh --memcheck
cd ..
fi
fi fi
echo "Done." msg "Done, cleaning up"
cleanup cleanup