| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // Simple test for a fuzzer. The fuzzer must find the deep recursion. |
| // To generate a crashy input: |
| // for((i=0;i<110;i++)); do echo -n ABCDEFGHIJ >> INPUT; done |
| static volatile int Sink; |
| void Recursive(const uint8_t *Data, size_t Size, int Depth) { |
| if (Depth > 1000) abort(); |
| if (*Data == ('A' + Depth % 10)) |
| Recursive(Data + 1, Size - 1, Depth + 1); |
| extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { |
| Recursive(Data, Size, 0); |