// This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // A fuzz target with lots of edges. #include #include static inline void break_optimization(const void *arg) { __asm__ __volatile__("" : : "r" (arg) : "memory"); } #define A \ do { \ i++; \ c++; \ if (Data[(i + __LINE__) % Size] == (c % 256)) \ break_optimization(Data); \ else \ break_optimization(0); \ } while (0) // for (int i = 0, n = Data[(__LINE__ - 1) % Size] % 16; i < n; i++) #define B do{A; A; A; A; A; A; A; A; A; A; A; A; A; A; A; A; A; A; }while(0) #define C do{B; B; B; B; B; B; B; B; B; B; B; B; B; B; B; B; B; B; }while(0) #define D do{C; C; C; C; C; C; C; C; C; C; C; C; C; C; C; C; C; C; }while(0) #define E do{D; D; D; D; D; D; D; D; D; D; D; D; D; D; D; D; D; D; }while(0) volatile int sink; extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { if (!Size) return 0; int c = 0; int i = 0; D; return 0; }