#!/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. # ################################################################################ # Build CUPS pushd $SRC/cups # Fix bad line sed -i '2110s/\(\s\)f->value/\1(int)f->value/' cups/ppd-cache.c LSB_BUILD=y ./configure --prefix="$WORK" --libdir="$OUT" --disable-gnutls \ --disable-libusb --with-components=core make clean make install-headers install-libs make -C filter libs install-libs install -m755 cups-config "$WORK"/cups-config popd rm -rf cups/libs || die rm -rf freetype || die rm -rf zlib || die mv $SRC/freetype freetype CUPSCONFIG="$WORK/cups-config" CUPS_CFLAGS=$($CUPSCONFIG --cflags) CUPS_LDFLAGS=$($CUPSCONFIG --ldflags) CUPS_LIBS=$($CUPSCONFIG --image --libs) export CXXFLAGS="$CXXFLAGS $CUPS_CFLAGS" CPPFLAGS="${CPPFLAGS:-} $CUPS_CFLAGS -DPACIFY_VALGRIND" ./autogen.sh \ CUPSCONFIG=$CUPSCONFIG \ --enable-freetype --enable-fontconfig \ --enable-cups --with-ijs --with-jbig2dec \ --with-drivers=pdfwrite,cups,ljet4,laserjet,pxlmono,pxlcolor,pcl3,uniprint,pgmraw,ps2write,png16m,tiffsep1,faxg3,psdcmyk,eps2write make -j$(nproc) libgs fuzzers="gstoraster_fuzzer \ gstoraster_fuzzer_all_colors \ gstoraster_ps_fuzzer \ gstoraster_pdf_fuzzer \ gs_device_pdfwrite_fuzzer \ gs_device_pxlmono_fuzzer \ gs_device_pgmraw_fuzzer \ gs_device_ps2write_fuzzer \ gs_device_png16m_fuzzer \ gs_device_psdcmyk_fuzzer \ gs_device_eps2write_fuzzer \ gs_device_faxg3_fuzzer \ gs_device_tiffsep1_fuzzer" for fuzzer in $fuzzers; do $CXX $CXXFLAGS $CUPS_LDFLAGS -std=c++11 -I. -I$SRC \ $SRC/${fuzzer}.cc \ -o "$OUT/${fuzzer}" \ -Wl,-rpath='$ORIGIN' \ $CUPS_LIBS \ $LIB_FUZZING_ENGINE bin/gs.a done # Create PDF seed corpus zip -j "$OUT/gstoraster_pdf_fuzzer_seed_corpus.zip" $SRC/pdf_seeds/* # Create corpus for gstoraster_fuzzer_all_colors. Only use seeds of a few KB in size. mkdir -p "$WORK/all_color_seeds" for f in examples/ridt91.eps examples/snowflak.ps $SRC/pdf_seeds/pdf.pdf; do # Prepend a single byte to seed, because it's used to determine the color # scheme in the gstoraster_fuzzer_all_colors. printf "\x01" | cat - "$f" > tmp_file.txt mv tmp_file.txt $f s=$(sha1sum "$f" | awk '{print $1}') cp "$f" "$WORK/all_color_seeds/$s" done zip -j "$OUT/gstoraster_fuzzer_all_colors_seed_corpus.zip" "$WORK"/all_color_seeds/* # Create seeds for gstoraster_fuzzer mkdir -p "$WORK/seeds" for f in examples/*.{ps,pdf}; do s=$(sha1sum "$f" | awk '{print $1}') cp "$f" "$WORK/seeds/$s" done # Create corpus for gstoraster_fuzzer zip -j "$OUT/gstoraster_fuzzer_seed_corpus.zip" "$WORK"/seeds/* cp "$OUT/gstoraster_fuzzer_seed_corpus.zip" "$OUT/gs_device_pdfwrite_fuzzer_seed_corpus.zip" cp "$OUT/gstoraster_fuzzer_seed_corpus.zip" "$OUT/gs_device_pxlmono_fuzzer_seed_corpus.zip" cp "$OUT/gstoraster_fuzzer_seed_corpus.zip" "$OUT/gs_device_eps2write_fuzzer_seed_corpus.zip" # Copy out options cp $SRC/*.options $OUT/ # Copy out dictionary cp $SRC/dicts/pdf.dict $OUT/gstoraster_pdf_fuzzer.dict cp $SRC/dicts/ps.dict $OUT/gstoraster_ps_fuzzer.dict