| #!/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. |
| # |
| ################################################################################ |
| |
| # build fuzzers |
| make -j$(nproc) CC=$CC CXX=$CXX CFLAGS="$CFLAGS" FUZZ_CXXFLAGS="$CXXFLAGS" \ |
| LIB_FUZZING_ENGINE=$LIB_FUZZING_ENGINE fuzz-all |
| |
| FUZZERS="fuzz-pack-headers fuzz-pack-idx fuzz-commit-graph" |
| |
| # copy fuzzers |
| for fuzzer in $FUZZERS ; do |
| cp $fuzzer $OUT |
| done |
| |
| # build corpora from Git's own packfiles |
| zip -j $OUT/fuzz-pack-idx_seed_corpus.zip .git/objects/pack/*.idx |
| for packfile in .git/objects/pack/*.pack ; do |
| dd ibs=1 skip=12 if=$packfile of=$packfile.trimmed |
| done |
| zip -j $OUT/fuzz-pack-headers_seed_corpus.zip .git/objects/pack/*.pack.trimmed |
| |
| # build commit-graph corpus |
| ASAN_OPTIONS=detect_leaks=0 ./git commit-graph write |
| zip -j $OUT/fuzz-commit-graph_seed_corpus .git/objects/info/commit-graph |
| |
| # Mute stderr |
| for fuzzer in $FUZZERS ; do |
| cat >$OUT/$fuzzer.options << EOF |
| [libfuzzer] |
| close_fd_mask = 2 |
| EOF |
| done |