diff options
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(); |