blob: 2c4e58e29d16fa6a4882e567b4b1bd03e47c31bb [file] [log] [blame]
Jonathan Rudenberg7db7d5b2018-01-13 19:51:07 -05001#!/bin/bash
2# SPDX-License-Identifier: LGPL-2.1+
3#
4# Copyright 2017 Jonathan Rudenberg
5#
6# systemd is free software; you can redistribute it and/or modify it
7# under the terms of the GNU Lesser General Public License as published by
8# the Free Software Foundation; either version 2.1 of the License, or
9# (at your option) any later version.
10#
11# systemd is distributed in the hope that it will be useful, but
12# WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14# Lesser General Public License for more details.
15#
16# You should have received a copy of the GNU Lesser General Public License
17# along with systemd; If not, see <http://www.gnu.org/licenses/>.
18
19set -ex
20
21export LC_CTYPE=C.UTF-8
22
Jonathan Rudenberg31e57a32018-01-16 10:25:43 -050023SANITIZER=${SANITIZER:-address -fsanitize-address-use-after-scope}
24flags="-O1 -fno-omit-frame-pointer -gline-tables-only -DFUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION -fsanitize=$SANITIZER -fsanitize-coverage=trace-pc-guard,trace-cmp"
25
26export CFLAGS=${CFLAGS:-$flags}
27export CXXFLAGS=${CXXFLAGS:-$flags}
28export CC=${CC:-clang}
29export CXX=${CXX:-clang++}
30export WORK=${WORK:-$(pwd)}
31export OUT=${OUT:-$(pwd)/out}
32mkdir -p $OUT
33
Jonathan Rudenberg7d941c02018-01-16 08:36:56 -050034build=$WORK/build
35rm -rf $build
36mkdir -p $build
37
Jonathan Rudenberg31e57a32018-01-16 10:25:43 -050038fuzzflag="oss-fuzz=true"
39if [ -z "$FUZZING_ENGINE" ]; then
40 fuzzflag="llvm-fuzz=true"
41fi
42
43meson $build -D$fuzzflag -Db_lundef=false
Jonathan Rudenberg7d941c02018-01-16 08:36:56 -050044ninja -C $build fuzzers
Jonathan Rudenberg7db7d5b2018-01-13 19:51:07 -050045
Jonathan Rudenberg2bd37c52018-01-19 19:44:56 -050046for d in "$(dirname "$0")/../test/fuzz-corpus/"*; do
47 zip -jqr $OUT/fuzz-$(basename "$d")_seed_corpus.zip "$d"
48done
49
50# get fuzz-dns-packet corpus
Jonathan Rudenberg7d941c02018-01-16 08:36:56 -050051df=$build/dns-fuzzing
Jonathan Rudenberg7db7d5b2018-01-13 19:51:07 -050052git clone --depth 1 https://github.com/CZ-NIC/dns-fuzzing $df
53zip -jqr $OUT/fuzz-dns-packet_seed_corpus.zip $df/packet
54
55mkdir -p $OUT/src/shared
Jonathan Rudenberg7d941c02018-01-16 08:36:56 -050056mv $build/src/shared/libsystemd-shared-*.so $OUT/src/shared
Jonathan Rudenberg7db7d5b2018-01-13 19:51:07 -050057
Jonathan Rudenberg7d941c02018-01-16 08:36:56 -050058find $build -maxdepth 1 -type f -executable -name "fuzz-*" -exec mv {} $OUT \;
Jonathan Rudenberg31e57a32018-01-16 10:25:43 -050059cp src/fuzz/*.options $OUT