[tor] Instrument dependencies and enable MSan.

This commit is contained in:
Max Moroz 2017-10-31 14:57:07 -07:00
parent 312cd47208
commit 0a2bd75093
3 changed files with 53 additions and 7 deletions

View File

@ -16,8 +16,11 @@
FROM gcr.io/oss-fuzz-base/base-builder FROM gcr.io/oss-fuzz-base/base-builder
MAINTAINER nickm@torproject.org MAINTAINER nickm@torproject.org
RUN apt-get update && apt-get install -y zlib1g zlib1g-dev libevent-dev libevent-2.0 openssl autoconf automake libssl-dev make RUN apt-get update && apt-get install -y autoconf automake make libtool
RUN git clone https://git.torproject.org/tor.git RUN git clone --depth 1 https://git.torproject.org/tor.git
RUN git clone https://git.torproject.org/fuzzing-corpora.git tor-fuzz-corpora RUN git clone --depth 1 https://git.torproject.org/fuzzing-corpora.git tor-fuzz-corpora
RUN git clone --depth 1 https://github.com/madler/zlib.git
RUN git clone --depth 1 https://github.com/openssl/openssl.git
RUN git clone --depth 1 https://github.com/libevent/libevent.git
WORKDIR tor WORKDIR tor
COPY build.sh $SRC/ COPY build.sh $SRC/

View File

@ -15,6 +15,42 @@
# #
############################################################################## ##############################################################################
# Create a directory for instrumented dependencies.
TOR_DEPS=${SRC}/deps
mkdir -p $TOR_DEPS
# Build libevent with proper instrumentation.
cd ${SRC}/libevent
sh autogen.sh
./configure --prefix=${TOR_DEPS}
make -j$(nproc) clean
make -j$(nproc) all
make install
# Build OpenSSL with proper instrumentation.
cd ${SRC}/openssl
OPENSSL_CONFIGURE_FLAGS=""
if [[ $CFLAGS = *sanitize=memory* ]]
then
OPENSSL_CONFIGURE_FLAGS="no-asm"
fi
./config no-shared --prefix=${TOR_DEPS} \
enable-tls1_3 enable-rc5 enable-md2 enable-ec_nistp_64_gcc_128 enable-ssl3 \
enable-ssl3-method enable-nextprotoneg enable-weak-ssl-ciphers $CFLAGS \
-fno-sanitize=alignment $OPENSSL_CONFIGURE_FLAGS
make -j$(nproc) LDCMD="$CXX $CXXFLAGS"
make install
# Build zlib with proper instrumentation,
cd ${SRC}/zlib
./configure --prefix=${TOR_DEPS}
make -j$(nproc) clean
make -j$(nproc) all
make install
# Build tor and the fuzz targets.
cd ${SRC}/tor cd ${SRC}/tor
sh autogen.sh sh autogen.sh
@ -23,7 +59,11 @@ sh autogen.sh
# test functions will fail. # test functions will fail.
export ASAN_OPTIONS=detect_leaks=0 export ASAN_OPTIONS=detect_leaks=0
./configure --disable-asciidoc --enable-oss-fuzz --disable-memory-sentinels ./configure --disable-asciidoc --enable-oss-fuzz --disable-memory-sentinels \
--with-libevent-dir=${SRC}/deps \
--with-openssl-dir=${SRC}/deps \
--with-zlib-dir=${SRC}/deps
make clean make clean
make -j$(nproc) oss-fuzz-fuzzers make -j$(nproc) oss-fuzz-fuzzers
@ -37,7 +77,8 @@ TORLIBS="$TORLIBS src/common/libor-testing.a"
TORLIBS="$TORLIBS src/common/libor-ctime-testing.a" TORLIBS="$TORLIBS src/common/libor-ctime-testing.a"
TORLIBS="$TORLIBS src/common/libor-event-testing.a" TORLIBS="$TORLIBS src/common/libor-event-testing.a"
TORLIBS="$TORLIBS src/trunnel/libor-trunnel-testing.a" TORLIBS="$TORLIBS src/trunnel/libor-trunnel-testing.a"
TORLIBS="$TORLIBS -lm -Wl,-Bstatic -lssl -lcrypto -levent -lz -Wl,-Bdynamic" TORLIBS="$TORLIBS -lm -Wl,-Bstatic -lssl -lcrypto -levent -lz -L${TOR_DEPS}/lib"
TORLIBS="$TORLIBS -Wl,-Bdynamic"
for fuzzer in src/test/fuzz/*.a; do for fuzzer in src/test/fuzz/*.a; do
output="${fuzzer%.a}" output="${fuzzer%.a}"
@ -49,5 +90,3 @@ for fuzzer in src/test/fuzz/*.a; do
zip -j ${OUT}/${output}_seed_corpus.zip ${corpus_dir}/* zip -j ${OUT}/${output}_seed_corpus.zip ${corpus_dir}/*
fi fi
done done

View File

@ -1,3 +1,7 @@
homepage: "https://www.torproject.org" homepage: "https://www.torproject.org"
primary_contact: "nima@torproject.org" primary_contact: "nima@torproject.org"
auto_ccs: "nick.a.mathewson@gmail.com" auto_ccs: "nick.a.mathewson@gmail.com"
sanitizers:
- address
- memory
- undefined