blob: ee378146dae1de2754f0e8fc4c61c9e77e0b0d4c [file] [log] [blame]
Kostya Serebryany16d03bd2015-03-30 22:09:51 +00001// Simple test for a fuzzer. The fuzzer must find several narrow ranges.
2#include <cstdint>
3#include <cstdlib>
4#include <cstring>
5#include <cstdio>
6
Kostya Serebryany566bc5a2015-05-06 22:19:00 +00007extern "C" void LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
Kostya Serebryany16d03bd2015-03-30 22:09:51 +00008 if (Size < 14) return;
9 uint64_t x = 0;
10 int64_t y = 0;
11 int z = 0;
12 unsigned short a = 0;
13 memcpy(&x, Data, 8);
14 memcpy(&y, Data + Size - 8, 8);
15 memcpy(&z, Data + Size / 2, sizeof(z));
16 memcpy(&a, Data + Size / 2 + 4, sizeof(a));
17
18 if (x > 1234567890 &&
19 x < 1234567895 &&
20 y >= 987654321 &&
21 y <= 987654325 &&
22 z < -10000 &&
23 z >= -10005 &&
24 z != -10003 &&
25 a == 4242) {
Kostya Serebryanya407dde2015-05-07 00:11:33 +000026 fprintf(stderr, "BINGO; Found the target: size %zd (%zd, %zd, %d, %d), exiting.\n",
Kostya Serebryany16d03bd2015-03-30 22:09:51 +000027 Size, x, y, z, a);
28 exit(1);
29 }
30}