2016-08-30 22:30:53 +00:00
|
|
|
#!/bin/bash -eu
|
2016-09-01 23:39:04 +00:00
|
|
|
#
|
|
|
|
# Copyright 2016 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.
|
|
|
|
#
|
|
|
|
################################################################################
|
2016-08-30 22:30:53 +00:00
|
|
|
|
2020-06-05 14:36:17 +00:00
|
|
|
if [ "$SANITIZER" = undefined ]; then
|
|
|
|
export CFLAGS="$CFLAGS -fsanitize=unsigned-integer-overflow -fno-sanitize-recover=unsigned-integer-overflow"
|
|
|
|
export CXXFLAGS="$CXXFLAGS -fsanitize=unsigned-integer-overflow -fno-sanitize-recover=unsigned-integer-overflow"
|
|
|
|
fi
|
2016-08-30 22:30:53 +00:00
|
|
|
|
2020-06-05 14:36:17 +00:00
|
|
|
./autogen.sh \
|
|
|
|
--disable-shared \
|
|
|
|
--without-ftp \
|
|
|
|
--without-http \
|
|
|
|
--without-legacy \
|
|
|
|
--without-python
|
|
|
|
make -j$(nproc) V=1
|
2020-06-24 20:01:23 +00:00
|
|
|
make -C fuzz V=1 seed/schema.stamp seed/xml.stamp fuzz.o
|
|
|
|
cp -r test/HTML fuzz/seed/html
|
2018-11-21 20:31:39 +00:00
|
|
|
|
2020-06-24 20:01:23 +00:00
|
|
|
for fuzzer in html schema xml; do
|
|
|
|
make -C fuzz $fuzzer.o
|
2020-06-05 14:36:17 +00:00
|
|
|
# Link with $CXX
|
|
|
|
$CXX $CXXFLAGS \
|
|
|
|
fuzz/$fuzzer.o fuzz/fuzz.o \
|
|
|
|
-o $OUT/$fuzzer \
|
|
|
|
$LIB_FUZZING_ENGINE \
|
|
|
|
.libs/libxml2.a -Wl,-Bstatic -lz -llzma -Wl,-Bdynamic
|
2016-10-12 23:25:06 +00:00
|
|
|
|
2020-06-05 14:36:17 +00:00
|
|
|
zip -j $OUT/${fuzzer}_seed_corpus.zip fuzz/seed/$fuzzer/*
|
2018-11-21 20:31:39 +00:00
|
|
|
done
|
2020-06-05 14:36:17 +00:00
|
|
|
|
2020-06-09 14:41:15 +00:00
|
|
|
cp fuzz/*.dict fuzz/*.options $OUT/
|