oss-fuzz/projects/frr/build.sh

66 lines
2.0 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.
#
################################################################################
function copy_lib
{
local fuzzer_path=$1
local lib=$2
cp $(ldd ${fuzzer_path} | grep "${lib}" | awk '{ print $3 }') ${OUT}/lib/ || true
}
mkdir -p $OUT/lib
# build dependency
(
cd $SRC/libyang
mkdir build; cd build
cmake -DBUILD_SHARED_LIBS=OFF -DENABLE_LYD_PRIV=ON -DCMAKE_INSTALL_PREFIX:PATH=/usr \
-D CMAKE_BUILD_TYPE:String="Release" ..
make -j$(nproc)
make install
)
# build project
export ASAN_OPTIONS=detect_leaks=0
export CFLAGS="${CFLAGS} -DFUZZING_OVERRIDE_LLVMFuzzerTestOneInput"
export CXXFLAGS="${CXXFLAGS} -DFUZZING_OVERRIDE_LLVMFuzzerTestOneInput"
./bootstrap.sh
./configure --enable-libfuzzer --enable-static --enable-static-bin --sbindir=$SRC/bin
make -j$(nproc)
make install
cp ./lib/.libs/libfrr.so.0 $OUT/lib/
cp $SRC/bin/bgpd $OUT/
cp $SRC/bin/ospfd $OUT/
cp $SRC/bin/pimd $OUT/
cp $SRC/bin/zebra $OUT/
# build corpus
cd $SRC/corpi
find . -type d -maxdepth 1 | while read i; do zip -j $OUT/"$i"_seed_corpus.zip "$i"/*; done
find $OUT -maxdepth 1 -type f -executable | while read i; do
grep "LLVMFuzzerTestOneInput" ${i} > /dev/null 2>&1 || continue
patchelf --set-rpath '$ORIGIN/lib' ${i}
copy_lib ${i} libpcre2
copy_lib ${i} libyang
copy_lib ${i} libelf
copy_lib ${i} libjson-c
done
patchelf --remove-needed libpcre2-8.so.0 $OUT/lib/libyang.so.2