summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Fuzzer/FuzzerLoop.cpp
diff options
context:
space:
mode:
authorKostya Serebryany <kcc@google.com>2016-09-27 00:10:20 +0000
committerKostya Serebryany <kcc@google.com>2016-09-27 00:10:20 +0000
commit5ff481fd9e9d8fb4a057a1cfc0b5041facfeca15 (patch)
tree718d12ea3e12f62bf2bf1b1f930388d5f56139f4 /llvm/lib/Fuzzer/FuzzerLoop.cpp
parentbde62d78e92256a2e176e96308119263d04d2648 (diff)
downloadbcm5719-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.cpp17
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();
OpenPOWER on IntegriCloud