mirror of https://github.com/google/oss-fuzz.git
76 lines
2.5 KiB
Bash
Executable File
76 lines
2.5 KiB
Bash
Executable File
#!/bin/bash -eu
|
|
# Copyright 2019 Google Inc.
|
|
#
|
|
# 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.
|
|
#
|
|
################################################################################
|
|
|
|
# Mostly copied from
|
|
# https://github.com/google/oss-fuzz/blob/7f8013db108e62727fba1c3cbcccac07d543682b/projects/grpc/build.sh
|
|
|
|
# Copy $CFLAGS and $CXXFLAGS into Bazel command-line flags, for both
|
|
# compilation and linking.
|
|
#
|
|
# Some flags, such as `-stdlib=libc++`, generate warnings if used on a C source
|
|
# file. Since the build runs with `-Werror` this will cause it to break, so we
|
|
# use `--conlyopt` and `--cxxopt` instead of `--copt`.
|
|
readonly EXTRA_BAZEL_FLAGS="$(
|
|
for f in ${CFLAGS}; do
|
|
echo "--conlyopt=${f}" "--linkopt=${f}"
|
|
done
|
|
for f in ${CXXFLAGS}; do
|
|
echo "--cxxopt=${f}" "--linkopt=${f}"
|
|
done
|
|
if [ "${SANITIZER}" = "undefined" ]
|
|
then
|
|
# Bazel uses clang to link binary, which does not link clang_rt ubsan library for C++ automatically.
|
|
# See issue: https://github.com/bazelbuild/bazel/issues/8777
|
|
echo "--linkopt=$(find $(llvm-config --libdir) -name libclang_rt.ubsan_standalone_cxx-x86_64.a | head -1)"
|
|
fi
|
|
)"
|
|
|
|
# Temporary hack, see https://github.com/google/oss-fuzz/issues/383
|
|
readonly NO_VPTR='--copt=-fno-sanitize=vptr --linkopt=-fno-sanitize=vptr'
|
|
|
|
readonly FUZZER_TARGETS=(
|
|
'oak/server:wasm_node_fuzz'
|
|
)
|
|
|
|
bazel build \
|
|
--client_env=CC=${CC} \
|
|
--client_env=CXX=${CXX} \
|
|
--dynamic_mode=off \
|
|
--spawn_strategy=standalone \
|
|
--genrule_strategy=standalone \
|
|
${NO_VPTR} \
|
|
--strip=never \
|
|
--linkopt=-lc++ \
|
|
--linkopt=-pthread \
|
|
--cxxopt=-std=c++11 \
|
|
--copt=${LIB_FUZZING_ENGINE} \
|
|
--linkopt=${LIB_FUZZING_ENGINE} \
|
|
--remote_cache=https://storage.googleapis.com/oak-bazel-cache \
|
|
--remote_upload_local_results=false \
|
|
${EXTRA_BAZEL_FLAGS} \
|
|
${FUZZER_TARGETS[@]}
|
|
|
|
for target in ${FUZZER_TARGETS}; do
|
|
# Replace : with /.
|
|
fuzzer_name="${target/:/\/}"
|
|
cp "./bazel-bin/${fuzzer_name}" "${OUT}/"
|
|
done
|
|
|
|
# Cleanup bazel- symlinks to avoid oss-fuzz trying to copy out of the build
|
|
# cache.
|
|
rm -f ./bazel-*
|