oss-fuzz/projects/libvips/build.sh

269 lines
6.7 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.
#
################################################################################
export PKG_CONFIG="pkg-config --static"
export PKG_CONFIG_PATH="$WORK/lib/pkgconfig"
export CPPFLAGS="-I$WORK/include"
export LDFLAGS="-L$WORK/lib"
# libz
pushd $SRC/zlib
./configure --static --prefix=$WORK
make -j$(nproc) all
make install
popd
# libexif
pushd $SRC/libexif
autoreconf -fi
./configure \
--enable-static \
--disable-shared \
--disable-nls \
--disable-docs \
--disable-dependency-tracking \
--prefix=$WORK
make -j$(nproc)
make install
popd
# lcms
pushd $SRC/lcms
./autogen.sh
./configure \
--enable-static \
--disable-shared \
--disable-dependency-tracking \
--prefix=$WORK
make -j$(nproc)
make install
popd
# aom
pushd $SRC/aom
mkdir -p build/linux
cd build/linux
extra_libaom_flags='-DAOM_MAX_ALLOCABLE_MEMORY=536870912 -DDO_RANGE_CHECK_CLAMP=1'
cmake \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DCMAKE_INSTALL_PREFIX=$WORK \
-DCONFIG_PIC=1 \
-DENABLE_EXAMPLES=0 \
-DENABLE_DOCS=0 \
-DENABLE_TESTS=0 \
-DENABLE_TOOLS=0 \
-DCONFIG_SIZE_LIMIT=1 \
-DDECODE_HEIGHT_LIMIT=12288 \
-DDECODE_WIDTH_LIMIT=12288 \
-DAOM_EXTRA_C_FLAGS="$extra_libaom_flags" \
-DAOM_EXTRA_CXX_FLAGS="$extra_libaom_flags" \
-DAOM_TARGET_CPU=generic \
../../
make clean
make -j$(nproc)
make install
popd
# libheif
pushd $SRC/libheif
# Ensure libvips finds heif_image_handle_get_raw_color_profile
sed -i '/^Libs.private:/s/-lstdc++/-lc++/' libheif.pc.in
autoreconf -fi
./configure \
--disable-shared \
--enable-static \
--disable-examples \
--disable-go \
--prefix=$WORK
make clean
make -j$(nproc)
make install
popd
# libjpeg-turbo
pushd $SRC/libjpeg-turbo
cmake \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DCMAKE_INSTALL_PREFIX=$WORK \
-DENABLE_STATIC=TRUE \
-DENABLE_SHARED=FALSE \
-DWITH_TURBOJPEG=FALSE \
.
make -j$(nproc)
make install
popd
# libpng
pushd $SRC/libpng
sed -ie 's/option WARNING /& disabled/' scripts/pnglibconf.dfa
autoreconf -fi
./configure \
--prefix=$WORK \
--disable-shared \
--disable-dependency-tracking
make -j$(nproc)
make install
popd
# libspng
pushd $SRC/libspng
meson setup build --prefix=$WORK --libdir=lib --default-library=static --buildtype=debugoptimized \
-Dstatic_zlib=true
ninja -C build
ninja -C build install
popd
# libwebp
pushd $SRC/libwebp
autoreconf -fi
./configure \
--enable-libwebpdemux \
--enable-libwebpmux \
--disable-shared \
--disable-jpeg \
--disable-tiff \
--disable-gif \
--disable-wic \
--disable-threading \
--disable-dependency-tracking \
--prefix=$WORK
make -j$(nproc)
make install
popd
# libtiff ... a bug in libtiff master as of 20 Nov 2019 means we have to
# explicitly disable lzma
pushd $SRC/libtiff
autoreconf -fi
./configure \
--disable-lzma \
--disable-shared \
--disable-dependency-tracking \
--prefix=$WORK
make -j$(nproc)
make install
popd
# jpeg-xl (libjxl)
pushd $SRC/libjxl
# Ensure libvips finds JxlEncoderInitBasicInfo
sed -i '/^Libs.private:/ s/$/ -lc++/' lib/jxl/libjxl.pc.in
# CMake ignores the CPPFLAGS env, so prepend it to -DCMAKE_C{XX,}_FLAGS instead
cmake \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DCMAKE_C_FLAGS="$CPPFLAGS $CFLAGS" \
-DCMAKE_CXX_FLAGS="$CPPFLAGS $CXXFLAGS" \
-DCMAKE_INSTALL_PREFIX=$WORK \
-DZLIB_ROOT=$WORK \
-DBUILD_SHARED_LIBS=0 \
-DBUILD_TESTING=0 \
-DJPEGXL_FORCE_SYSTEM_LCMS2=1 \
-DJPEGXL_FORCE_SYSTEM_BROTLI=1 \
-DJPEGXL_ENABLE_FUZZERS=0 \
-DJPEGXL_ENABLE_TOOLS=0 \
-DJPEGXL_ENABLE_MANPAGES=0 \
-DJPEGXL_ENABLE_BENCHMARK=0 \
-DJPEGXL_ENABLE_EXAMPLES=0 \
-DJPEGXL_ENABLE_SKCMS=0 \
-DJPEGXL_ENABLE_SJPEG=0 \
.
make -j$(nproc)
make install
popd
# libimagequant
pushd $SRC/libimagequant
meson setup build --prefix=$WORK --libdir=lib --default-library=static --buildtype=debugoptimized
ninja -C build
ninja -C build install
popd
# cgif
pushd $SRC/cgif
meson setup build --prefix=$WORK --libdir=lib --default-library=static --buildtype=debugoptimized
ninja -C build
ninja -C build install
popd
# pdfium doesn't need fuzzing, but we want to fuzz the libvips/pdfium link
pushd $SRC/pdfium-latest
cp lib/* $WORK/lib
cp -r include/* $WORK/include
popd
# make a pdfium.pc that libvips can use ... the version number just needs to
# be higher than 4200 to satisfy libvips
cat > $WORK/lib/pkgconfig/pdfium.pc << EOF
prefix=$WORK
exec_prefix=\${prefix}
libdir=\${exec_prefix}/lib
includedir=\${prefix}/include
Name: pdfium
Description: pdfium
Version: 4901
Requires:
Libs: -L\${libdir} -lpdfium
Cflags: -I\${includedir}
EOF
# libvips
# Disable building man pages, gettext po files, tools, and tests
sed -i "/subdir('man')/{N;N;N;N;d;}" meson.build
meson setup build --prefix=$WORK --libdir=lib --default-library=static \
-Ddeprecated=false -Dintrospection=false -Dmodules=disabled
ninja -C build
ninja -C build install
# All shared libraries needed during fuzz target execution should be inside the $OUT/lib directory
mkdir -p $OUT/lib
cp $WORK/lib/*.so $OUT/lib
# Merge the seed corpus in a single directory, exclude files larger than 2k
mkdir -p fuzz/corpus
find \
$SRC/afl-testcases/{gif*,jpeg*,png,tiff,webp}/full/images \
fuzz/*_fuzzer_corpus \
test/test-suite/images \
-type f -size -2k \
-exec bash -c 'hash=($(sha1sum {})); mv {} fuzz/corpus/$hash' ';'
zip -jrq $OUT/seed_corpus.zip fuzz/corpus
# Build fuzzers and link corpus
for fuzzer in fuzz/*_fuzzer.cc; do
target=$(basename "$fuzzer" .cc)
$CXX $CXXFLAGS -std=c++11 "$fuzzer" -o "$OUT/$target" \
$CPPFLAGS \
-I/usr/include/glib-2.0 \
-I/usr/lib/x86_64-linux-gnu/glib-2.0/include \
$LDFLAGS \
-lvips -lexif -llcms2 -ljpeg -lpng -lspng -lz \
-ltiff -lwebpmux -lwebpdemux -lwebp -lsharpyuv -lheif -laom \
-ljxl -ljxl_threads -lhwy -limagequant -lcgif -lpdfium \
$LIB_FUZZING_ENGINE \
-Wl,-Bstatic \
-lfftw3 -lexpat -lbrotlienc -lbrotlidec -lbrotlicommon \
-lgio-2.0 -lgmodule-2.0 -lgobject-2.0 -lffi -lglib-2.0 \
-lresolv -lmount -lblkid -lselinux -lsepol -lpcre \
-Wl,-Bdynamic -pthread \
-Wl,-rpath,'$ORIGIN/lib'
ln -sf "seed_corpus.zip" "$OUT/${target}_seed_corpus.zip"
done
# Copy options and dictionary files to $OUT
find fuzz -name '*_fuzzer.dict' -exec cp -v '{}' $OUT ';'
find fuzz -name '*_fuzzer.options' -exec cp -v '{}' $OUT ';'