]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/compiler-rt/lib/fuzzer/FuzzerInterface.h
Add compiler-rt's libFuzzer, not connected to buildworld yet.
[FreeBSD/FreeBSD.git] / contrib / compiler-rt / lib / fuzzer / FuzzerInterface.h
1 //===- FuzzerInterface.h - Interface header for the Fuzzer ------*- C++ -* ===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 // Define the interface between libFuzzer and the library being tested.
10 //===----------------------------------------------------------------------===//
11
12 // NOTE: the libFuzzer interface is thin and in the majority of cases
13 // you should not include this file into your target. In 95% of cases
14 // all you need is to define the following function in your file:
15 // extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
16
17 // WARNING: keep the interface in C.
18
19 #ifndef LLVM_FUZZER_INTERFACE_H
20 #define LLVM_FUZZER_INTERFACE_H
21
22 #include <stddef.h>
23 #include <stdint.h>
24
25 #ifdef __cplusplus
26 extern "C" {
27 #endif  // __cplusplus
28
29 // Mandatory user-provided target function.
30 // Executes the code under test with [Data, Data+Size) as the input.
31 // libFuzzer will invoke this function *many* times with different inputs.
32 // Must return 0.
33 __attribute__((visibility("default"))) int
34 LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
35
36 // Optional user-provided initialization function.
37 // If provided, this function will be called by libFuzzer once at startup.
38 // It may read and modify argc/argv.
39 // Must return 0.
40 __attribute__((visibility("default"))) int LLVMFuzzerInitialize(int *argc,
41                                                                 char ***argv);
42
43 // Optional user-provided custom mutator.
44 // Mutates raw data in [Data, Data+Size) inplace.
45 // Returns the new size, which is not greater than MaxSize.
46 // Given the same Seed produces the same mutation.
47 __attribute__((visibility("default"))) size_t
48 LLVMFuzzerCustomMutator(uint8_t *Data, size_t Size, size_t MaxSize,
49                         unsigned int Seed);
50
51 // Optional user-provided custom cross-over function.
52 // Combines pieces of Data1 & Data2 together into Out.
53 // Returns the new size, which is not greater than MaxOutSize.
54 // Should produce the same mutation given the same Seed.
55 __attribute__((visibility("default"))) size_t
56 LLVMFuzzerCustomCrossOver(const uint8_t *Data1, size_t Size1,
57                           const uint8_t *Data2, size_t Size2, uint8_t *Out,
58                           size_t MaxOutSize, unsigned int Seed);
59
60 // Experimental, may go away in future.
61 // libFuzzer-provided function to be used inside LLVMFuzzerCustomMutator.
62 // Mutates raw data in [Data, Data+Size) inplace.
63 // Returns the new size, which is not greater than MaxSize.
64 __attribute__((visibility("default"))) size_t
65 LLVMFuzzerMutate(uint8_t *Data, size_t Size, size_t MaxSize);
66
67 #ifdef __cplusplus
68 }  // extern "C"
69 #endif  // __cplusplus
70
71 #endif  // LLVM_FUZZER_INTERFACE_H