summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorKostya Serebryany <kcc@google.com>2015-09-11 00:20:58 +0000
committerKostya Serebryany <kcc@google.com>2015-09-11 00:20:58 +0000
commitdd02f1f8abcc53c280ae9825dbf708e69151e09d (patch)
tree71562b16664ec207ff3dbda913b8af7cfc9d92dc /llvm/lib
parent24d07fdd27dd316c923ec633f41678322aef7401 (diff)
downloadbcm5719-llvm-dd02f1f8abcc53c280ae9825dbf708e69151e09d.tar.gz
bcm5719-llvm-dd02f1f8abcc53c280ae9825dbf708e69151e09d.zip
[libFuzzer] perform fewer crossover operations compared to plain mutations
llvm-svn: 247364
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Fuzzer/FuzzerLoop.cpp15
1 files changed, 8 insertions, 7 deletions
diff --git a/llvm/lib/Fuzzer/FuzzerLoop.cpp b/llvm/lib/Fuzzer/FuzzerLoop.cpp
index f1802f65c37..96783dac673 100644
--- a/llvm/lib/Fuzzer/FuzzerLoop.cpp
+++ b/llvm/lib/Fuzzer/FuzzerLoop.cpp
@@ -337,23 +337,24 @@ void Fuzzer::Loop() {
RereadOutputCorpus();
if (TotalNumberOfRuns >= Options.MaxNumberOfRuns)
return;
- // First, simply mutate the unit w/o doing crosses.
CurrentUnit = Corpus[J1];
- MutateAndTestOne(&CurrentUnit);
- // Now, cross with others.
- if (Options.DoCrossOver && !Corpus[J1].empty()) {
- for (size_t J2 = 0; J2 < Corpus.size(); J2++) {
+ // Optionally, cross with another unit.
+ if (Options.DoCrossOver && USF.GetRand().RandBool()) {
+ size_t J2 = USF.GetRand()(Corpus.size());
+ if (!Corpus[J1].empty() && !Corpus[J2].empty()) {
+ assert(!Corpus[J2].empty());
CurrentUnit.resize(Options.MaxLen);
size_t NewSize = USF.CrossOver(
Corpus[J1].data(), Corpus[J1].size(), Corpus[J2].data(),
Corpus[J2].size(), CurrentUnit.data(), CurrentUnit.size());
assert(NewSize > 0 && "CrossOver returned empty unit");
assert(NewSize <= (size_t)Options.MaxLen &&
- "CrossOver return overisized unit");
+ "CrossOver returned overisized unit");
CurrentUnit.resize(NewSize);
- MutateAndTestOne(&CurrentUnit);
}
}
+ // Perform several mutations and runs.
+ MutateAndTestOne(&CurrentUnit);
}
}
}
OpenPOWER on IntegriCloud