diff options
author | Kostya Serebryany <kcc@google.com> | 2017-08-29 02:05:01 +0000 |
---|---|---|
committer | Kostya Serebryany <kcc@google.com> | 2017-08-29 02:05:01 +0000 |
commit | 895df3ed0da58642a4b690506e1c250d0bde2836 (patch) | |
tree | 14583a2db81f1d3f0aeb985e3922b33010cbaf71 /lib/fuzzer/FuzzerLoop.cpp | |
parent | 886bbfa61b2327865e1ccd9916554de6e026bc5d (diff) | |
download | compiler-rt-895df3ed0da58642a4b690506e1c250d0bde2836.tar.gz |
[libFuzzer] refactoring: move reading the seed corpus closer to where it's consumed; NFC
git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@311972 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/fuzzer/FuzzerLoop.cpp')
-rw-r--r-- | lib/fuzzer/FuzzerLoop.cpp | 31 |
1 files changed, 29 insertions, 2 deletions
diff --git a/lib/fuzzer/FuzzerLoop.cpp b/lib/fuzzer/FuzzerLoop.cpp index dd828917f..84ea2d6e8 100644 --- a/lib/fuzzer/FuzzerLoop.cpp +++ b/lib/fuzzer/FuzzerLoop.cpp @@ -380,7 +380,8 @@ void Fuzzer::ShuffleCorpus(UnitVector *V) { } void Fuzzer::ShuffleAndMinimize(UnitVector *InitialCorpus) { - Printf("#0\tREAD units: %zd\n", InitialCorpus->size()); + Printf("#0\tREAD units: %zd; rss: %zdMb\n", InitialCorpus->size(), + GetPeakRSSMb()); if (Options.ShuffleAtStartUp) ShuffleCorpus(InitialCorpus); @@ -624,7 +625,33 @@ void Fuzzer::MutateAndTestOne() { } } -void Fuzzer::Loop() { +void Fuzzer::ReadAndExecuteSeedCorpora(const Vector<std::string> &CorpusDirs) { + const size_t kMaxSaneLen = 1 << 20; + const size_t kMinDefaultLen = 4096; + size_t TemporaryMaxLen = Options.MaxLen ? Options.MaxLen : kMaxSaneLen; + UnitVector InitialCorpus; + for (auto &Inp : CorpusDirs) { + Printf("Loading corpus dir: %s\n", Inp.c_str()); + ReadDirToVectorOfUnits(Inp.c_str(), &InitialCorpus, nullptr, + TemporaryMaxLen, /*ExitOnError=*/false); + } + if (Options.MaxLen == 0) { + size_t MaxLen = 0; + for (auto &U : InitialCorpus) + MaxLen = std::max(U.size(), MaxLen); + SetMaxInputLen(std::min(std::max(kMinDefaultLen, MaxLen), kMaxSaneLen)); + } + + if (InitialCorpus.empty()) { + InitialCorpus.push_back(Unit({'\n'})); // Valid ASCII input. + if (Options.Verbosity) + Printf("INFO: A corpus is not provided, starting from an empty corpus\n"); + } + ShuffleAndMinimize(&InitialCorpus); +} + +void Fuzzer::Loop(const Vector<std::string> &CorpusDirs) { + ReadAndExecuteSeedCorpora(CorpusDirs); TPC.SetPrintNewPCs(Options.PrintNewCovPcs); TPC.SetPrintNewFuncs(Options.PrintNewCovFuncs); system_clock::time_point LastCorpusReload = system_clock::now(); |