oss-fuzz/projects/libwebp/build.sh

72 lines
2.0 KiB
Bash
Raw Normal View History

2018-05-29 16:48:50 +00:00
#!/bin/bash -eu
# Copyright 2018 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.
#
################################################################################
# limit allocation size to reduce spurious OOMs
WEBP_CFLAGS="$CFLAGS -DWEBP_MAX_IMAGE_SIZE=838860800" # 800MiB
2018-05-29 16:48:50 +00:00
./autogen.sh
CFLAGS="$WEBP_CFLAGS" ./configure \
--enable-asserts \
2018-05-29 16:48:50 +00:00
--enable-libwebpdemux \
--enable-libwebpmux \
2018-05-29 16:48:50 +00:00
--disable-shared \
--disable-jpeg \
--disable-tiff \
--disable-gif \
--disable-wic
make clean
make -j$(nproc)
find $SRC/libwebp-test-data -type f -size -32k -iname "*.webp" \
-exec zip -qju fuzz_seed_corpus.zip "{}" \;
2018-05-29 16:48:50 +00:00
webp_libs=(
src/demux/.libs/libwebpdemux.a
src/mux/.libs/libwebpmux.a
2018-05-29 16:48:50 +00:00
src/.libs/libwebp.a
imageio/.libs/libimageio_util.a
)
webp_c_fuzzers=(
advanced_api_fuzzer
animation_api_fuzzer
mux_demux_api_fuzzer
simple_api_fuzzer
)
webp_cxx_fuzzers=(
animdecoder_fuzzer
animencoder_fuzzer
enc_dec_fuzzer
)
for fuzzer in "${webp_c_fuzzers[@]}"; do
$CC $CFLAGS -Isrc -I. tests/fuzzer/${fuzzer}.c -c -o tests/fuzzer/${fuzzer}.o
$CXX $CXXFLAGS $LIB_FUZZING_ENGINE \
tests/fuzzer/${fuzzer}.o -o $OUT/${fuzzer} \
"${webp_libs[@]}"
done
for fuzzer in "${webp_cxx_fuzzers[@]}"; do
$CXX $CXXFLAGS -Isrc -I. $LIB_FUZZING_ENGINE \
tests/fuzzer/${fuzzer}.cc -o $OUT/${fuzzer} \
"${webp_libs[@]}"
done
webp_animencoder: Add target to fuzz animation encoding (#1935) * Add new fuzz target for encoding and misc - Add fuzz_webp_enc_dec and adapt Dockerfile, build.sh - Lint existing targets - Add license headers - Increase fuzz.dict * webp_enc_dec: Convert input images to inline C arrays Local files are not available on oss-fuzz servers. * webp_enc_dec: Fix timeout by skipping crusher The target fuzz_webp_enc_dec with msan crashes (timeout) on a 128*128px image encoding with max compression (crusher). Reduce crusher encoding to 16*16px and below. Bug report 10423 * webp_enc_dec: Replace cruncher by lossy alpha encoding The target fuzz_webp_enc_dec with msan crashes (timeout) during encoding with max compression (cruncher). Reduce alpha cruncher encoding to 16*16px and below. Bug report 10634 * webp_enc_dec: Clamp slow parameters for big images The target fuzz_webp_enc_dec with ubsan crashes (timeout) during encoding with heavy compression. The cause can not be easily removed without reducing performance. Clamp compression parameters for images bigger than 16*16. Bug report 10700 * webp_enc_dec: Limit alpha_quality to 99 when method is 6 The target fuzz_webp_enc_dec with asan crashes (timeout) during encoding with heavy alpha compression. Clamp alpha compression parameters for images bigger than 16*16. Bug report 10838 * webp_animencoder: Add target to fuzz animation encoding Add fuzz_webp_animencoder.cc and modify Dockerfile, build.sh accordingly. The thresholds for input size and encoding parameters are low to prevent timeouts. Some functions used by fuzz_webp_animencoder and fuzz_webp_enc_dec have been moved to fuzz.h.
2018-11-07 19:17:08 +00:00
for fuzzer in "${webp_c_fuzzers[@]}" "${webp_cxx_fuzzers[@]}"; do
cp fuzz_seed_corpus.zip $OUT/${fuzzer}_seed_corpus.zip
cp tests/fuzzer/fuzz.dict $OUT/${fuzzer}.dict
done