Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | # SPDX-License-Identifier: LGPL-2.1+ |
| 3 | # |
| 4 | # Copyright 2017 Jonathan Rudenberg |
Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 5 | |
| 6 | set -ex |
| 7 | |
| 8 | export LC_CTYPE=C.UTF-8 |
| 9 | |
Zbigniew Jędrzejewski-Szmek | 36cd991 | 2018-03-12 15:59:10 +0100 | [diff] [blame] | 10 | export CC=${CC:-clang} |
| 11 | export CXX=${CXX:-clang++} |
| 12 | clang_version="$($CC --version | sed -nr 's/.*version ([^ ]+?) .*/\1/p' | sed -r 's/-$//')" |
| 13 | |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 14 | SANITIZER=${SANITIZER:-address -fsanitize-address-use-after-scope} |
| 15 | flags="-O1 -fno-omit-frame-pointer -gline-tables-only -DFUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION -fsanitize=$SANITIZER -fsanitize-coverage=trace-pc-guard,trace-cmp" |
| 16 | |
Zbigniew Jędrzejewski-Szmek | 36cd991 | 2018-03-12 15:59:10 +0100 | [diff] [blame] | 17 | clang_lib="/usr/lib64/clang/${clang_version}/lib/linux" |
| 18 | [ -d "$clang_lib" ] || clang_lib="/usr/lib/clang/${clang_version}/lib/linux" |
| 19 | |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 20 | export CFLAGS=${CFLAGS:-$flags} |
| 21 | export CXXFLAGS=${CXXFLAGS:-$flags} |
Zbigniew Jędrzejewski-Szmek | 36cd991 | 2018-03-12 15:59:10 +0100 | [diff] [blame] | 22 | export LDFLAGS=${LDFLAGS:--L${clang_lib}} |
| 23 | |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 24 | export WORK=${WORK:-$(pwd)} |
| 25 | export OUT=${OUT:-$(pwd)/out} |
| 26 | mkdir -p $OUT |
| 27 | |
Jonathan Rudenberg | 7d941c0 | 2018-01-16 08:36:56 -0500 | [diff] [blame] | 28 | build=$WORK/build |
| 29 | rm -rf $build |
| 30 | mkdir -p $build |
| 31 | |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 32 | fuzzflag="oss-fuzz=true" |
| 33 | if [ -z "$FUZZING_ENGINE" ]; then |
| 34 | fuzzflag="llvm-fuzz=true" |
| 35 | fi |
| 36 | |
| 37 | meson $build -D$fuzzflag -Db_lundef=false |
Jonathan Rudenberg | 7d941c0 | 2018-01-16 08:36:56 -0500 | [diff] [blame] | 38 | ninja -C $build fuzzers |
Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 39 | |
Jonathan Rudenberg | 2bd37c5 | 2018-01-19 19:44:56 -0500 | [diff] [blame] | 40 | for d in "$(dirname "$0")/../test/fuzz-corpus/"*; do |
| 41 | zip -jqr $OUT/fuzz-$(basename "$d")_seed_corpus.zip "$d" |
| 42 | done |
| 43 | |
| 44 | # get fuzz-dns-packet corpus |
Jonathan Rudenberg | 7d941c0 | 2018-01-16 08:36:56 -0500 | [diff] [blame] | 45 | df=$build/dns-fuzzing |
Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 46 | git clone --depth 1 https://github.com/CZ-NIC/dns-fuzzing $df |
| 47 | zip -jqr $OUT/fuzz-dns-packet_seed_corpus.zip $df/packet |
| 48 | |
Zbigniew Jędrzejewski-Szmek | 3c31f3a | 2018-05-08 17:00:19 +0200 | [diff] [blame^] | 49 | # install the private shared library without executable permissions |
| 50 | install -Dt $OUT/src/shared/ -m 0644 $build/src/shared/libsystemd-shared-*.so |
Jonathan Rudenberg | 7db7d5b | 2018-01-13 19:51:07 -0500 | [diff] [blame] | 51 | |
Jonathan Rudenberg | 7d941c0 | 2018-01-16 08:36:56 -0500 | [diff] [blame] | 52 | find $build -maxdepth 1 -type f -executable -name "fuzz-*" -exec mv {} $OUT \; |
Jonathan Rudenberg | 31e57a3 | 2018-01-16 10:25:43 -0500 | [diff] [blame] | 53 | cp src/fuzz/*.options $OUT |