mirror of https://github.com/google/oss-fuzz.git
67 lines
2.1 KiB
Bash
Executable File
67 lines
2.1 KiB
Bash
Executable File
#!/bin/bash -eu
|
|
# Copyright 2021 Google LLC
|
|
#
|
|
# 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.
|
|
#
|
|
################################################################################
|
|
|
|
git apply --ignore-space-change --ignore-whitespace $SRC/patch.diff
|
|
|
|
function copy_lib
|
|
{
|
|
local fuzzer_path=$1
|
|
local lib=$2
|
|
cp $(ldd ${fuzzer_path} | grep "${lib}" | awk '{ print $3 }') ${OUT}/lib
|
|
}
|
|
|
|
mkdir -p $OUT/lib
|
|
|
|
if [ "$SANITIZER" = "coverage" ]
|
|
then
|
|
# so that we do not get openssl
|
|
export CXXFLAGS="$CXXFLAGS -fsanitize=fuzzer-no-link,address"
|
|
export CFLAGS="$CFLAGS -fsanitize=fuzzer-no-link,address"
|
|
fi
|
|
|
|
# build project
|
|
./bootstrap
|
|
# java fails with Source option 6 is no longer supported. Use 7 or later.
|
|
./configure --disable-java --enable-fuzzing --disable-shared
|
|
|
|
# patch bluez
|
|
sed -i 's/sys\/socket.h>/sys\/socket.h>\n#include <linux\/sockios.h>/g' ./third_party/bluez/repo/tools/l2test.c
|
|
sed -i 's/sys\/stat.h>/sys\/stat.h>\n#include <linux\/sockios.h>/g' ./third_party/bluez/repo/tools/rctest.c
|
|
|
|
# OpenSSL now declares RAND_bytes so we must patch
|
|
find ./src/test-apps/fuzz/ -name "FuzzP*.cpp" -exec sed -i 's/RAND_bytes/RAND_bytes2/g' {} \;
|
|
|
|
make -j$(nproc)
|
|
|
|
find src/test-apps/fuzz/ -type f -executable -name "Fuzz*" | while read i; do
|
|
patchelf --set-rpath '$ORIGIN/lib' ${i}
|
|
copy_lib ${i} libglib
|
|
copy_lib ${i} libdbus
|
|
cp ${i} $OUT/
|
|
done
|
|
|
|
# build corpus
|
|
ls $SRC/openweave-core/src/test-apps/fuzz/corpus/ | while read f; do
|
|
zip -j $OUT/${f}_seed_corpus.zip $SRC/openweave-core/src/test-apps/fuzz/corpus/${f}/*;
|
|
done
|
|
|
|
cd $OUT/
|
|
ls *_seed_corpus.zip | grep PASE | while read c; do
|
|
cp $c Fuzz$c;
|
|
done
|
|
|