Jörg Thalheim | ff12a79 | 2020-03-04 09:35:06 +0000 | [diff] [blame] | 1 | #!/usr/bin/env bash |
Yu Watanabe | db9ecf0 | 2020-11-09 13:23:58 +0900 | [diff] [blame] | 2 | # SPDX-License-Identifier: LGPL-2.1-or-later |
Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 3 | |
| 4 | set -ex |
| 5 | |
| 6 | export LC_CTYPE=C.UTF-8 |
| 7 | |
Zbigniew Jędrzejewski-Szmek | 36cd991 | 2018-03-12 15:59:10 +0100 | [diff] [blame] | 8 | export CC=${CC:-clang} |
| 9 | export CXX=${CXX:-clang++} |
| 10 | clang_version="$($CC --version | sed -nr 's/.*version ([^ ]+?) .*/\1/p' | sed -r 's/-$//')" |
| 11 | |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 12 | SANITIZER=${SANITIZER:-address -fsanitize-address-use-after-scope} |
Evgeny Vereshchagin | 9c5c467 | 2019-05-09 00:03:41 +0200 | [diff] [blame] | 13 | flags="-O1 -fno-omit-frame-pointer -gline-tables-only -DFUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION -fsanitize=$SANITIZER" |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 14 | |
Zbigniew Jędrzejewski-Szmek | 36cd991 | 2018-03-12 15:59:10 +0100 | [diff] [blame] | 15 | clang_lib="/usr/lib64/clang/${clang_version}/lib/linux" |
| 16 | [ -d "$clang_lib" ] || clang_lib="/usr/lib/clang/${clang_version}/lib/linux" |
| 17 | |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 18 | export CFLAGS=${CFLAGS:-$flags} |
| 19 | export CXXFLAGS=${CXXFLAGS:-$flags} |
Zbigniew Jędrzejewski-Szmek | 36cd991 | 2018-03-12 15:59:10 +0100 | [diff] [blame] | 20 | export LDFLAGS=${LDFLAGS:--L${clang_lib}} |
| 21 | |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 22 | export WORK=${WORK:-$(pwd)} |
| 23 | export OUT=${OUT:-$(pwd)/out} |
| 24 | mkdir -p $OUT |
| 25 | |
Jonathan Rudenberg | 7d941c0 | 2018-01-16 08:36:56 -0500 | [diff] [blame] | 26 | build=$WORK/build |
| 27 | rm -rf $build |
| 28 | mkdir -p $build |
| 29 | |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 30 | if [ -z "$FUZZING_ENGINE" ]; then |
Zbigniew Jędrzejewski-Szmek | cc5549c | 2019-04-04 14:10:42 +0200 | [diff] [blame] | 31 | fuzzflag="llvm-fuzz=true" |
Evgeny Vereshchagin | 1f03400 | 2020-05-21 08:20:01 +0200 | [diff] [blame] | 32 | else |
| 33 | fuzzflag="oss-fuzz=true" |
| 34 | if [[ "$SANITIZER" == undefined ]]; then |
| 35 | UBSAN_FLAGS="-fsanitize=pointer-overflow -fno-sanitize-recover=pointer-overflow" |
| 36 | CFLAGS="$CFLAGS $UBSAN_FLAGS" |
| 37 | CXXFLAGS="$CXXFLAGS $UBSAN_FLAGS" |
| 38 | fi |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 39 | fi |
| 40 | |
| 41 | meson $build -D$fuzzflag -Db_lundef=false |
Evgeny Vereshchagin | 9c5c467 | 2019-05-09 00:03:41 +0200 | [diff] [blame] | 42 | ninja -v -C $build fuzzers |
Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 43 | |
Zbigniew Jędrzejewski-Szmek | 93b575b | 2018-07-07 17:43:40 +0200 | [diff] [blame] | 44 | # The seed corpus is a separate flat archive for each fuzzer, |
| 45 | # with a fixed name ${fuzzer}_seed_corpus.zip. |
| 46 | for d in "$(dirname "$0")/../test/fuzz/fuzz-"*; do |
Zbigniew Jędrzejewski-Szmek | cc5549c | 2019-04-04 14:10:42 +0200 | [diff] [blame] | 47 | zip -jqr $OUT/$(basename "$d")_seed_corpus.zip "$d" |
Jonathan Rudenberg | 2bd37c5 | 2018-01-19 19:44:56 -0500 | [diff] [blame] | 48 | done |
| 49 | |
| 50 | # get fuzz-dns-packet corpus |
Jonathan Rudenberg | 7d941c0 | 2018-01-16 08:36:56 -0500 | [diff] [blame] | 51 | df=$build/dns-fuzzing |
Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 52 | git clone --depth 1 https://github.com/CZ-NIC/dns-fuzzing $df |
| 53 | zip -jqr $OUT/fuzz-dns-packet_seed_corpus.zip $df/packet |
| 54 | |
Evgeny Vereshchagin | 7cd98cc | 2018-08-16 02:06:35 +0000 | [diff] [blame] | 55 | install -Dt $OUT/src/shared/ $build/src/shared/libsystemd-shared-*.so |
Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 56 | |
Evgeny Vereshchagin | 6315d12 | 2018-08-01 10:25:26 +0000 | [diff] [blame] | 57 | wget -O $OUT/fuzz-json.dict https://raw.githubusercontent.com/rc0r/afl-fuzz/master/dictionaries/json.dict |
| 58 | |
Jonathan Rudenberg | 7d941c0 | 2018-01-16 08:36:56 -0500 | [diff] [blame] | 59 | find $build -maxdepth 1 -type f -executable -name "fuzz-*" -exec mv {} $OUT \; |
Evgeny Vereshchagin | 3ff074b | 2018-11-06 19:51:45 +0100 | [diff] [blame] | 60 | find src -type f -name "fuzz-*.dict" -exec cp {} $OUT \; |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 61 | cp src/fuzz/*.options $OUT |