[libFuzzer] one more puzzle for value profile
authorKostya Serebryany <kcc@google.com>
Fri, 9 Sep 2016 21:58:42 +0000 (21:58 +0000)
committerKostya Serebryany <kcc@google.com>
Fri, 9 Sep 2016 21:58:42 +0000 (21:58 +0000)
llvm-svn: 281106

llvm/lib/Fuzzer/test/AbsNegAndConstant64Test.cpp [new file with mode: 0644]
llvm/lib/Fuzzer/test/CMakeLists.txt
llvm/lib/Fuzzer/test/value-profile-cmp.test

diff --git a/llvm/lib/Fuzzer/test/AbsNegAndConstant64Test.cpp b/llvm/lib/Fuzzer/test/AbsNegAndConstant64Test.cpp
new file mode 100644 (file)
index 0000000..0d199fc
--- /dev/null
@@ -0,0 +1,23 @@
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+
+// abs(x) < 0 and y == Const puzzle, 64-bit variant.
+#include <cstring>
+#include <cstdint>
+#include <cstdlib>
+#include <cstddef>
+#include <cstdio>
+
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
+  if (Size < 16) return 0;
+  long x;
+  unsigned long y;
+  memcpy(&x, Data, 8);
+  memcpy(&y, Data + 8, 8);
+  if (labs(x) < 0 && y == 0xbaddcafedeadbeefUL) {
+    printf("BINGO; Found the target, exiting; x = 0x%lx y 0x%lx\n", x, y);
+    exit(1);
+  }
+  return 0;
+}
+
index dde189a..1cc02d2 100644 (file)
@@ -63,6 +63,7 @@ set(TestBinaries)
 
 set(Tests
   AbsNegAndConstantTest
+  AbsNegAndConstant64Test
   AccumulateAllocationsTest
   BufferOverflowOnInput
   CallerCalleeTest
index ae06495..d183b76 100644 (file)
@@ -2,5 +2,6 @@ CHECK: BINGO
 RUN: not LLVMFuzzer-SimpleCmpTest -use_value_profile=1 -runs=100000000 2>&1 | FileCheck %s
 RUN: not LLVMFuzzer-SimpleHashTest -use_value_profile=1 -runs=100000000 2>&1 | FileCheck %s
 RUN: not LLVMFuzzer-AbsNegAndConstantTest -use_value_profile=1 -runs=100000000 2>&1 | FileCheck %s
+RUN: not LLVMFuzzer-AbsNegAndConstant64Test -use_value_profile=1 -runs=100000000 2>&1 | FileCheck %s