]> granicus.if.org Git - llvm/commitdiff
[libFuzzer] improve support for inline-8bit-counters (make it more correct and faster)
authorKostya Serebryany <kcc@google.com>
Fri, 28 Jul 2017 22:00:56 +0000 (22:00 +0000)
committerKostya Serebryany <kcc@google.com>
Fri, 28 Jul 2017 22:00:56 +0000 (22:00 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@309443 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Fuzzer/FuzzerTracePC.cpp
lib/Fuzzer/FuzzerTracePC.h
lib/Fuzzer/test/fuzzer-traces-hooks.test

index 07be441244c7088fe4489cda15820475fa1a294b..bf2a6110e853cd979334cb63e02194ac127ec641 100644 (file)
@@ -309,6 +309,14 @@ static size_t InternalStrnlen2(const char *S1, const char *S2) {
   return Len;
 }
 
+void TracePC::ClearInlineCounters() {
+  for (size_t i = 0; i < NumModulesWithInline8bitCounters; i++) {
+    uint8_t *Beg = ModuleCounters[i].Start;
+    size_t Size = ModuleCounters[i].Stop - Beg;
+    memset(Beg, 0, Size);
+  }
+}
+
 } // namespace fuzzer
 
 extern "C" {
@@ -344,6 +352,10 @@ void __sanitizer_cov_8bit_counters_init(uint8_t *Start, uint8_t *Stop) {
   fuzzer::TPC.HandleInline8bitCountersInit(Start, Stop);
 }
 
+ATTRIBUTE_INTERFACE
+void __sanitizer_cov_pcs_init(const uint8_t *pcs_beg, const uint8_t *pcs_end) {
+}
+
 ATTRIBUTE_INTERFACE
 ATTRIBUTE_NO_SANITIZE_ALL
 void __sanitizer_cov_trace_pc_indir(uintptr_t Callee) {
index fac2b2b9cc821001a10062c7ef7e28ef3154720b..28301d17b2cab4b7d3a93191c391e5f48a439d7f 100644 (file)
@@ -87,8 +87,11 @@ class TracePC {
     ValueProfileMap.Reset();
     memset(Counters(), 0, GetNumPCs());
     ClearExtraCounters();
+    ClearInlineCounters();
   }
 
+  void ClearInlineCounters();
+
   void UpdateFeatureSet(size_t CurrentElementIdx, size_t CurrentElementSize);
   void PrintFeatureSet();
 
@@ -201,8 +204,11 @@ void TracePC::CollectFeatures(Callback HandleFeature) const {
   };
 
   size_t FirstFeature = 0;
-  ForEachNonZeroByte(Counters, Counters + N, FirstFeature, Handle8bitCounter);
-  FirstFeature += N * 8;
+  if (!NumInline8bitCounters) {
+    ForEachNonZeroByte(Counters, Counters + N, FirstFeature, Handle8bitCounter);
+    FirstFeature += N * 8;
+  }
+
   for (size_t i = 0; i < NumModulesWithInline8bitCounters; i++) {
     ForEachNonZeroByte(ModuleCounters[i].Start, ModuleCounters[i].Stop,
                        FirstFeature, Handle8bitCounter);
index 77ca4b47bd018ddb48f0003411d6e4a759d3eea1..3f9f89e461f0a15bcf51ac21a9bec31888228344 100644 (file)
@@ -3,7 +3,7 @@
 UNSUPPORTED: windows
 CHECK: BINGO
 
-RUN: not LLVMFuzzer-MemcmpTest               -seed=1 -runs=2000000   2>&1 | FileCheck %s
+RUN: not LLVMFuzzer-MemcmpTest               -seed=1 -runs=10000000   2>&1 | FileCheck %s
 RUN: not LLVMFuzzer-StrncmpTest              -seed=1 -runs=2000000   2>&1 | FileCheck %s
 RUN: not LLVMFuzzer-StrcmpTest               -seed=1 -runs=2000000   2>&1 | FileCheck %s
 RUN: not LLVMFuzzer-StrstrTest               -seed=1 -runs=2000000   2>&1 | FileCheck %s