From: Kostya Serebryany Date: Thu, 19 Jan 2017 19:07:26 +0000 (+0000) Subject: [libFuzzer] add two tests for experimenting with equivalence fuzzing X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e1feb39408bd1c2685680379e958317f1ddc33bb;p=llvm [libFuzzer] add two tests for experimenting with equivalence fuzzing git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@292509 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Fuzzer/FuzzerLoop.cpp b/lib/Fuzzer/FuzzerLoop.cpp index 9f49d155799..02cbcc76e13 100644 --- a/lib/Fuzzer/FuzzerLoop.cpp +++ b/lib/Fuzzer/FuzzerLoop.cpp @@ -814,4 +814,7 @@ size_t LLVMFuzzerMutate(uint8_t *Data, size_t Size, size_t MaxSize) { assert(fuzzer::F); return fuzzer::F->GetMD().DefaultMutate(Data, Size, MaxSize); } + +// Experimental +void LLVMFuzzerAnnounceOutput(const uint8_t *Data, size_t Size) {} } // extern "C" diff --git a/lib/Fuzzer/test/CMakeLists.txt b/lib/Fuzzer/test/CMakeLists.txt index a95b5e7fc55..2359c208ab0 100644 --- a/lib/Fuzzer/test/CMakeLists.txt +++ b/lib/Fuzzer/test/CMakeLists.txt @@ -72,6 +72,8 @@ set(Tests CustomMutatorTest DivTest EmptyTest + EquivalenceATest + EquivalenceBTest FourIndependentBranchesTest FullCoverageSetTest InitializeTest diff --git a/lib/Fuzzer/test/EquivalenceATest.cpp b/lib/Fuzzer/test/EquivalenceATest.cpp new file mode 100644 index 00000000000..101fe127f5d --- /dev/null +++ b/lib/Fuzzer/test/EquivalenceATest.cpp @@ -0,0 +1,15 @@ +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +#include +#include + +// Test for libFuzzer's "equivalence" fuzzing, part A. +extern "C" void LLVMFuzzerAnnounceOutput(const uint8_t *Data, size_t Size); +extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { + if (Size > 100) return 0; + uint8_t Result[100]; + for (size_t i = 0; i < Size; i++) + Result[Size - i - 1] = Data[i]; + LLVMFuzzerAnnounceOutput(Result, Size); + return 0; +} diff --git a/lib/Fuzzer/test/EquivalenceBTest.cpp b/lib/Fuzzer/test/EquivalenceBTest.cpp new file mode 100644 index 00000000000..175eed1394f --- /dev/null +++ b/lib/Fuzzer/test/EquivalenceBTest.cpp @@ -0,0 +1,26 @@ +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +#include +#include +#include + +// Test for libFuzzer's "equivalence" fuzzing, part B. +extern "C" void LLVMFuzzerAnnounceOutput(const uint8_t *Data, size_t Size); +extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { + if (Size > 100) return 0; + uint8_t Result[100]; + for (size_t i = 0; i < Size; i++) + Result[Size - i - 1] = Data[i]; + + // Be a bit different from EquivalenceATest + if (Size > 42 && Data[10] == 'B') { + static int c; + if (!c) + fprintf(stderr, "ZZZZZZZ\n"); + c = 1; + Result[42]++; + } + + LLVMFuzzerAnnounceOutput(Result, Size); + return 0; +}