| #!/bin/bash -eu |
| # 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. |
| # |
| ################################################################################ |
| |
| CONFIGURE_FLAGS="" |
| if [[ $CFLAGS = *sanitize=memory* ]] |
| then |
| CONFIGURE_FLAGS="no-asm" |
| fi |
| |
| ./config --debug enable-fuzz-libfuzzer -DPEDANTIC -DFUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION no-shared enable-tls1_3 enable-rc5 enable-md2 enable-ec_nistp_64_gcc_128 enable-ssl3 enable-ssl3-method enable-nextprotoneg enable-weak-ssl-ciphers --with-fuzzer-lib=/usr/lib/libFuzzingEngine $CFLAGS -fno-sanitize=alignment $CONFIGURE_FLAGS |
| |
| make -j$(nproc) LDCMD="$CXX $CXXFLAGS" |
| |
| fuzzers=$(find fuzz -executable -type f '!' -name \*.py '!' -name \*-test '!' -name \*.pl) |
| for f in $fuzzers; do |
| fuzzer=$(basename $f) |
| cp $f $OUT/ |
| zip -j $OUT/${fuzzer}_seed_corpus.zip fuzz/corpora/${fuzzer}/* |
| done |
| |
| cp $SRC/*.options $OUT/ |
| cp fuzz/oids.txt $OUT/asn1.dict |
| cp fuzz/oids.txt $OUT/x509.dict |