diff options
| author | Kostya Serebryany <kcc@google.com> | 2016-09-27 00:10:20 +0000 |
|---|---|---|
| committer | Kostya Serebryany <kcc@google.com> | 2016-09-27 00:10:20 +0000 |
| commit | 5ff481fd9e9d8fb4a057a1cfc0b5041facfeca15 (patch) | |
| tree | 718d12ea3e12f62bf2bf1b1f930388d5f56139f4 /llvm/lib/Fuzzer/FuzzerLoop.cpp | |
| parent | bde62d78e92256a2e176e96308119263d04d2648 (diff) | |
| download | bcm5719-llvm-5ff481fd9e9d8fb4a057a1cfc0b5041facfeca15.tar.gz bcm5719-llvm-5ff481fd9e9d8fb4a057a1cfc0b5041facfeca15.zip | |
[libFuzzer] add -exit_on_src_pos to test libFuzzer itself, add a test script for RE2 that uses this flag
llvm-svn: 282458
Diffstat (limited to 'llvm/lib/Fuzzer/FuzzerLoop.cpp')
| -rw-r--r-- | llvm/lib/Fuzzer/FuzzerLoop.cpp | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/llvm/lib/Fuzzer/FuzzerLoop.cpp b/llvm/lib/Fuzzer/FuzzerLoop.cpp index 4a9b5694956..f7d4e4ef362 100644 --- a/llvm/lib/Fuzzer/FuzzerLoop.cpp +++ b/llvm/lib/Fuzzer/FuzzerLoop.cpp @@ -374,7 +374,24 @@ void Fuzzer::SetMaxMutationLen(size_t MaxMutationLen) { this->MaxMutationLen = MaxMutationLen; } +void Fuzzer::CheckExitOnSrcPos() { + if (!Options.ExitOnSrcPos.empty()) { + uintptr_t *PCIDs; + if (size_t NumNewPCIDs = TPC.GetNewPCIDs(&PCIDs)) { + for (size_t i = 0; i < NumNewPCIDs; i++) { + std::string Descr = DescribePC("%L", TPC.GetPCbyPCID(PCIDs[i])); + if (Descr.find(Options.ExitOnSrcPos) != std::string::npos) { + Printf("INFO: found line matching '%s', exiting.\n", + Options.ExitOnSrcPos.c_str()); + _Exit(0); + } + } + } + } +} + void Fuzzer::AddToCorpusAndMaybeRerun(const Unit &U) { + CheckExitOnSrcPos(); Corpus.AddToCorpus(U); if (TPC.GetTotalPCCoverage()) { TPC.ResetMaps(); |

