aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Fuzzer/test/SimpleCmpTest.cpp
diff options
context:
space:
mode:
authorAlexey Samsonov <vonosmas@gmail.com>2015-07-21 22:51:49 +0000
committerAlexey Samsonov <vonosmas@gmail.com>2015-07-21 22:51:49 +0000
commitdc324e16444f42c3d2e1967ea5cfa6f081a9714c (patch)
treea6dd6f75c6de80574e4cce7c1fcfdfc5fb375c57 /llvm/lib/Fuzzer/test/SimpleCmpTest.cpp
parentbcad06640b8263f42d1a9d52f8bf12d66850f9e8 (diff)
downloadllvm-dc324e16444f42c3d2e1967ea5cfa6f081a9714c.zip
llvm-dc324e16444f42c3d2e1967ea5cfa6f081a9714c.tar.gz
llvm-dc324e16444f42c3d2e1967ea5cfa6f081a9714c.tar.bz2
[Fuzzer] Clearly separate regular and DFSan tests. NFC.
llvm-svn: 242850
Diffstat (limited to 'llvm/lib/Fuzzer/test/SimpleCmpTest.cpp')
-rw-r--r--llvm/lib/Fuzzer/test/SimpleCmpTest.cpp30
1 files changed, 30 insertions, 0 deletions
diff --git a/llvm/lib/Fuzzer/test/SimpleCmpTest.cpp b/llvm/lib/Fuzzer/test/SimpleCmpTest.cpp
new file mode 100644
index 0000000..ee37814
--- /dev/null
+++ b/llvm/lib/Fuzzer/test/SimpleCmpTest.cpp
@@ -0,0 +1,30 @@
+// Simple test for a fuzzer. The fuzzer must find several narrow ranges.
+#include <cstdint>
+#include <cstdlib>
+#include <cstring>
+#include <cstdio>
+
+extern "C" void LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
+ if (Size < 14) return;
+ uint64_t x = 0;
+ int64_t y = 0;
+ int z = 0;
+ unsigned short a = 0;
+ memcpy(&x, Data, 8);
+ memcpy(&y, Data + Size - 8, 8);
+ memcpy(&z, Data + Size / 2, sizeof(z));
+ memcpy(&a, Data + Size / 2 + 4, sizeof(a));
+
+ if (x > 1234567890 &&
+ x < 1234567895 &&
+ y >= 987654321 &&
+ y <= 987654325 &&
+ z < -10000 &&
+ z >= -10005 &&
+ z != -10003 &&
+ a == 4242) {
+ fprintf(stderr, "BINGO; Found the target: size %zd (%zd, %zd, %d, %d), exiting.\n",
+ Size, x, y, z, a);
+ exit(1);
+ }
+}