You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
2.5 KiB
87 lines
2.5 KiB
4 months ago
|
#!/bin/bash -eu
|
||
|
# Copyright 2016 Google Inc.
|
||
|
#
|
||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
# you may not use this file except in compliance with the License.
|
||
|
# You may obtain a copy of the License at
|
||
|
#
|
||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||
|
#
|
||
|
# Unless required by applicable law or agreed to in writing, software
|
||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
# See the License for the specific language governing permissions and
|
||
|
# limitations under the License.
|
||
|
#
|
||
|
##############################################################################
|
||
|
|
||
|
# 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} --disable-openssl
|
||
|
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
|
||
|
|
||
|
sh autogen.sh
|
||
|
|
||
|
# We need to run configure with leak-checking disabled, or many of the
|
||
|
# test functions will fail.
|
||
|
export ASAN_OPTIONS=detect_leaks=0
|
||
|
|
||
|
./configure --disable-asciidoc --enable-oss-fuzz --disable-memory-sentinels \
|
||
|
--with-libevent-dir=${SRC}/deps \
|
||
|
--with-openssl-dir=${SRC}/deps \
|
||
|
--with-zlib-dir=${SRC}/deps \
|
||
|
--disable-gcc-hardening
|
||
|
|
||
|
make clean
|
||
|
make -j$(nproc) oss-fuzz-fuzzers
|
||
|
|
||
|
TORLIBS="`make show-testing-libs`"
|
||
|
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
|
||
|
output="${fuzzer%.a}"
|
||
|
output="${output##*lib}"
|
||
|
${CXX} ${CXXFLAGS} -std=c++11 $LIB_FUZZING_ENGINE ${fuzzer} ${TORLIBS} -o ${OUT}/${output}
|
||
|
|
||
|
corpus_dir="${SRC}/tor-fuzz-corpora/${output#oss-fuzz-}"
|
||
|
if [ -d "${corpus_dir}" ]; then
|
||
|
set +x
|
||
|
zip -q -j ${OUT}/${output}_seed_corpus.zip ${corpus_dir}/*
|
||
|
set -x
|
||
|
fi
|
||
|
done
|