Mercurial > hg > CbC > CbC_llvm
view projects/compiler-rt/test/fuzzer/LargeTest.cpp @ 181:df311c476dd5
CreateIdentifierInfo in ParseCbC (not yet worked)
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 31 May 2020 12:30:11 +0900 |
parents | f476a9ba4795 |
children |
line wrap: on
line source
// 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 <cstdint> #include <cstdlib> 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; }