diff options
author | van Hauser <vh@thc.org> | 2023-04-25 16:34:23 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-04-25 16:34:23 +0200 |
commit | b96ba509d0e52478445822ae89621c2bf7c04d7d (patch) | |
tree | cc7e62974132610a0ca8e1cd664ae3dcf4c114f2 | |
parent | 2e23418a09e6c610288414d4ab6841b6f39513af (diff) | |
parent | f94a7e88902f1589b105e74ec1a36e3e3bf01f9e (diff) | |
download | afl++-b96ba509d0e52478445822ae89621c2bf7c04d7d.tar.gz |
Merge pull request #1714 from choller/dev
Add env var to ignore coverage from dynamically loaded code after forkserver
-rw-r--r-- | instrumentation/afl-compiler-rt.o.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/instrumentation/afl-compiler-rt.o.c b/instrumentation/afl-compiler-rt.o.c index e0e40983..74506e4c 100644 --- a/instrumentation/afl-compiler-rt.o.c +++ b/instrumentation/afl-compiler-rt.o.c @@ -1563,17 +1563,27 @@ void __sanitizer_cov_trace_pc_guard_init(uint32_t *start, uint32_t *stop) { "[-] FATAL: forkserver is already up, but an instrumented dlopen() " "library loaded afterwards. You must AFL_PRELOAD such libraries to " "be able to fuzz them or LD_PRELOAD to run outside of afl-fuzz.\n" - "To ignore this set AFL_IGNORE_PROBLEMS=1 but this will be bad for " - "coverage.\n"); + "To ignore this set AFL_IGNORE_PROBLEMS=1 but this will lead to " + "ambiguous coverage data.\n" + "In addition, you can set AFL_LLVM_IGNORE_PROBLEMS_COVERAGE=1 to " + "ignore the additional coverage instead (use with caution!).\n"); abort(); } else { + u8 ignore_dso_after_fs = !!getenv("AFL_LLVM_IGNORE_PROBLEMS_COVERAGE"); + if (__afl_debug && ignore_dso_after_fs) { + + fprintf(stderr, "Ignoring coverage from dynamically loaded code\n"); + + } + static u32 offset = 5; while (start < stop) { - if (likely(inst_ratio == 100) || R(100) < inst_ratio) { + if (!ignore_dso_after_fs && + (likely(inst_ratio == 100) || R(100) < inst_ratio)) { *(start++) = offset; |