|
| 1 | +PWD=`pwd` |
| 2 | +FUZZER_NAME="fuzzer_libpng" |
| 3 | + |
| 4 | +all: |
| 5 | + # Build the libpng libfuzzer library |
| 6 | + cargo build --release |
| 7 | + |
| 8 | + # Build the libpng harness |
| 9 | + $(PWD)/target/release/libafl_cxx \ |
| 10 | + $(PWD)/harness.cc \ |
| 11 | + $(PWD)/libpng-1.6.37/.libs/libpng16.a \ |
| 12 | + -I$(PWD)/libpng-1.6.37/ \ |
| 13 | + -o $(FUZZER_NAME) \ |
| 14 | + -lm -lz |
| 15 | + |
| 16 | +run: all |
| 17 | + ./$(FUZZER_NAME) & |
| 18 | + sleep 0.2 |
| 19 | + ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 20 | + |
| 21 | +short_test: all |
| 22 | + timeout 11s ./$(FUZZER_NAME) & |
| 23 | + sleep 0.2 |
| 24 | + timeout 10s taskset -c 0 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 25 | + timeout 10s taskset -c 1 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 26 | + timeout 10s taskset -c 2 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 27 | + timeout 10s taskset -c 3 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 28 | + |
| 29 | +test: all |
| 30 | + timeout 60s ./$(FUZZER_NAME) & |
| 31 | + sleep 0.2 |
| 32 | + timeout 59s taskset 0x00000001 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 33 | + timeout 59s taskset 0x00000002 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 34 | + timeout 59s taskset 0x00000004 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 35 | + timeout 59s taskset 0x00000008 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 36 | + # timeout 59s taskset 0x00000010 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 37 | + # timeout 59s taskset 0x00000020 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 38 | + # timeout 59s taskset 0x00000040 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 39 | + # timeout 59s taskset 0x00000080 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 40 | + # timeout 59s taskset 0x00000100 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 41 | + # timeout 59s taskset 0x00000200 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 42 | + # timeout 59s taskset 0x00000400 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 43 | + # timeout 59s taskset 0x00000800 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 44 | + # timeout 59s taskset 0x00001000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 45 | + # timeout 59s taskset 0x00002000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 46 | + # timeout 59s taskset 0x00004000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 47 | + # timeout 59s taskset 0x00008000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 48 | + # timeout 59s taskset 0x00010000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 49 | + # timeout 59s taskset 0x00020000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 50 | + # timeout 59s taskset 0x00040000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 51 | + # timeout 59s taskset 0x00080000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 52 | + # timeout 59s taskset 0x00100000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 53 | + # timeout 59s taskset 0x00200000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 54 | + # timeout 59s taskset 0x00400000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 55 | + # timeout 59s taskset 0x00800000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 56 | + # timeout 59s taskset 0x01000000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 57 | + # timeout 59s taskset 0x02000000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 58 | + # timeout 59s taskset 0x04000000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 59 | + # timeout 59s taskset 0x08000000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 60 | + # timeout 59s taskset 0x10000000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 61 | + # timeout 59s taskset 0x20000000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 62 | + # timeout 59s taskset 0x40000000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
| 63 | + # timeout 59s taskset 0x80000000 ./$(FUZZER_NAME) >/dev/null 2>/dev/null & |
0 commit comments