blob: 0c91b21c45518ea075bdfbbfa9e60f3f67c7e24e (
plain) (
blame)
| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
 | #include <stdio.h>
#include <string.h>
#include <stdint.h>
#include <stdarg.h>
#include <stdlib.h>
#include <stdint.h>
#include <unistd.h>
int LLVMFuzzerTestOneInput(const uint8_t *buf, size_t i) {
  if (i < 15) return -1;
  if (buf[0] != 'A') return 0;
  int *icmp = (int *)(buf + 1);
  if (*icmp != 0x69694141) return 0;
  if (memcmp(buf + 5, "1234EF", 6) == 0) abort();
  return 0;
}
#ifdef __AFL_COMPILER
int main(int argc, char *argv[]) {
  unsigned char buf[1024];
  ssize_t       i;
  while (__AFL_LOOP(1000)) {
    i = read(0, (char *)buf, sizeof(buf) - 1);
    if (i > 0) buf[i] = 0;
    LLVMFuzzerTestOneInput(buf, i);
  }
  return 0;
}
#endif
 |