about summary refs log tree commit diff
path: root/gcc_plugin
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2019-10-23 03:23:14 +0200
committervan Hauser <vh@thc.org>2019-10-23 03:23:14 +0200
commit1398d8d5a64b11a62e8ed25732e2114a5dc47564 (patch)
tree5c5c10101c27ef21328fe5aea38c8f8232b3d9a0 /gcc_plugin
parent6bc874088fff699d170c89dd864c23507150fe3f (diff)
downloadafl++-1398d8d5a64b11a62e8ed25732e2114a5dc47564.tar.gz
gcc sucks
Diffstat (limited to 'gcc_plugin')
-rw-r--r--gcc_plugin/afl-gcc-rt.o.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/gcc_plugin/afl-gcc-rt.o.c b/gcc_plugin/afl-gcc-rt.o.c
index 1dfca9e3..47049167 100644
--- a/gcc_plugin/afl-gcc-rt.o.c
+++ b/gcc_plugin/afl-gcc-rt.o.c
@@ -58,10 +58,11 @@ __thread u32 __afl_prev_loc;
 void __afl_trace(u32 x) {
 
   u32 l = __afl_prev_loc;
-  const u32 n = l ^ x;
-  u8 *const bitmap_ptr = __afl_area_ptr + n;
-  *bitmap_ptr += 1 + (*bitmap_ptr == (u8)~0); /* neverZero */
-
+  __afl_area_ptr[l ^ x]++;
+  /* // neverZero is disable as gcc creates non-performant code. shame on you gcc
+  if (__afl_area_ptr[l ^ x] == 0)
+    __afl_area_ptr[l ^ x]++;
+  */
   __afl_prev_loc = (x >> 1);
   return;