| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 | #!/bin/sh## Creates fuzzer builds of various kinds# - oss-fuzz emulated mode (makes sure a simulated invocation by oss-fuzz works)# - libFuzzer build (you will need clang)# - afl build (you will need afl)### Copyright (c) 2019 Paul Dreik## For the license information refer to format.h.set -eme=$(basename $0)root=$(readlink -f "$(dirname "$0")/../..")echo $me: root=$roothere=$(pwd)CXXFLAGSALL="-DFUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION= -g"CMAKEFLAGSALL="$root -GNinja -DCMAKE_BUILD_TYPE=Debug -DFMT_DOC=Off -DFMT_TEST=Off -DFMT_FUZZ=On -DCMAKE_CXX_STANDARD=17"CLANG=clang++-11# For performance analysis of the fuzzers.builddir=$here/build-fuzzers-perfanalysismkdir -p $builddircd $builddirCXX="ccache g++" CXXFLAGS="$CXXFLAGSALL -g" cmake \$CMAKEFLAGSALL \-DFMT_FUZZ_LINKMAIN=On \-DCMAKE_BUILD_TYPE=Releasecmake --build $builddir# Builds the fuzzers as oss-fuzz does.builddir=$here/build-fuzzers-ossfuzzmkdir -p $builddircd $builddirCXX=$CLANG \CXXFLAGS="$CXXFLAGSALL -fsanitize=fuzzer-no-link" cmake \cmake $CMAKEFLAGSALL \-DFMT_FUZZ_LINKMAIN=Off \-DFMT_FUZZ_LDFLAGS="-fsanitize=fuzzer"cmake --build $builddir# Builds fuzzers for local fuzzing with libfuzzer with asan+usan.builddir=$here/build-fuzzers-libfuzzermkdir -p $builddircd $builddirCXX=$CLANG \CXXFLAGS="$CXXFLAGSALL -fsanitize=fuzzer-no-link,address,undefined" cmake \cmake $CMAKEFLAGSALL \-DFMT_FUZZ_LINKMAIN=Off \-DFMT_FUZZ_LDFLAGS="-fsanitize=fuzzer"cmake --build $builddir# Builds a fast fuzzer for making coverage fast.builddir=$here/build-fuzzers-fastmkdir -p $builddircd $builddirCXX=$CLANG \CXXFLAGS="$CXXFLAGSALL -fsanitize=fuzzer-no-link -O3" cmake \cmake $CMAKEFLAGSALL \-DFMT_FUZZ_LINKMAIN=Off \-DFMT_FUZZ_LDFLAGS="-fsanitize=fuzzer" \ -DCMAKE_BUILD_TYPE=Releasecmake --build $builddir# Builds fuzzers for local fuzzing with afl.builddir=$here/build-fuzzers-aflmkdir -p $builddircd $builddirCXX="afl-g++" \CXXFLAGS="$CXXFLAGSALL -fsanitize=address,undefined" \cmake $CMAKEFLAGSALL \-DFMT_FUZZ_LINKMAIN=Oncmake --build $builddirecho $me: all good
 |