Mercurial > hg > CbC > CbC_llvm
view projects/compiler-rt/test/fuzzer/CustomCrossOverAndMutateTest.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. // Test that libFuzzer does not crash when LLVMFuzzerMutate called from // LLVMFuzzerCustomCrossOver. #include <algorithm> #include <cstddef> #include <cstdint> #include <cstdlib> #include <string.h> #include <string> #include <vector> #include "FuzzerInterface.h" static volatile int sink; extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { std::string Str(reinterpret_cast<const char *>(Data), Size); if (Size && Data[0] == '0') sink++; return 0; } extern "C" size_t LLVMFuzzerCustomCrossOver(const uint8_t *Data1, size_t Size1, const uint8_t *Data2, size_t Size2, uint8_t *Out, size_t MaxOutSize, unsigned int Seed) { std::vector<uint8_t> Buffer(MaxOutSize * 10); LLVMFuzzerMutate(Buffer.data(), Buffer.size(), Buffer.size()); size_t Size = std::min(Size1, MaxOutSize); memcpy(Out, Data1, Size); return Size; }