blob: 36062edd4db19367ae0a36f303f17b6471b70e7d [file] [log] [blame]
Chandler Carruth2946cd72019-01-19 08:50:56 +00001// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
2// See https://llvm.org/LICENSE.txt for license information.
3// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
George Karpenkov10ab2ac2017-08-21 23:25:50 +00004
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +00005// Simple test for a cutom crossover.
George Karpenkov10ab2ac2017-08-21 23:25:50 +00006#include <assert.h>
7#include <cstddef>
8#include <cstdint>
9#include <cstdlib>
10#include <iostream>
11#include <ostream>
12#include <random>
13#include <string.h>
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000014#include <functional>
George Karpenkov10ab2ac2017-08-21 23:25:50 +000015
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000016static const char *Separator = "-########-";
17static const char *Target = "A-########-B";
George Karpenkov10ab2ac2017-08-21 23:25:50 +000018
Kostya Serebryany754e5842017-09-07 05:33:05 +000019static volatile int sink;
20
George Karpenkov10ab2ac2017-08-21 23:25:50 +000021extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
22 assert(Data);
23 std::string Str(reinterpret_cast<const char *>(Data), Size);
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000024 static const size_t TargetHash = std::hash<std::string>{}(std::string(Target));
25 size_t StrHash = std::hash<std::string>{}(Str);
George Karpenkov10ab2ac2017-08-21 23:25:50 +000026
Kostya Serebryany754e5842017-09-07 05:33:05 +000027 // Ensure we have 'A' and 'B' in the corpus.
28 if (Size == 1 && *Data == 'A')
29 sink++;
30 if (Size == 1 && *Data == 'B')
31 sink--;
32
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000033 if (TargetHash == StrHash) {
George Karpenkov10ab2ac2017-08-21 23:25:50 +000034 std::cout << "BINGO; Found the target, exiting\n" << std::flush;
35 exit(1);
36 }
37 return 0;
38}
39
40extern "C" size_t LLVMFuzzerCustomCrossOver(const uint8_t *Data1, size_t Size1,
41 const uint8_t *Data2, size_t Size2,
42 uint8_t *Out, size_t MaxOutSize,
43 unsigned int Seed) {
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000044 static size_t Printed;
George Karpenkov10ab2ac2017-08-21 23:25:50 +000045 static size_t SeparatorLen = strlen(Separator);
46
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000047 if (Printed++ < 32)
48 std::cerr << "In LLVMFuzzerCustomCrossover " << Size1 << " " << Size2 << "\n";
George Karpenkov10ab2ac2017-08-21 23:25:50 +000049
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000050 size_t Size = Size1 + Size2 + SeparatorLen;
George Karpenkov10ab2ac2017-08-21 23:25:50 +000051
52 if (Size > MaxOutSize)
53 return 0;
54
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000055 memcpy(Out, Data1, Size1);
56 memcpy(Out + Size1, Separator, SeparatorLen);
57 memcpy(Out + Size1 + SeparatorLen, Data2, Size2);
George Karpenkov10ab2ac2017-08-21 23:25:50 +000058
Kostya Serebryanyd0386fa2017-09-07 02:04:06 +000059 return Size;
George Karpenkov10ab2ac2017-08-21 23:25:50 +000060}