blob: c2c0a39843c042e40343c0e93f9c968a24d9b4c7 [file] [log] [blame]
George Karpenkov10ab2ac2017-08-21 23:25:501//===- 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
26extern "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.
Petr Hosek68bc4bd2018-01-17 17:24:5633int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
George Karpenkov10ab2ac2017-08-21 23:25:5034
35// Optional user-provided initialization function.
36// If provided, this function will be called by libFuzzer once at startup.
37// It may read and modify argc/argv.
38// Must return 0.
Petr Hosek68bc4bd2018-01-17 17:24:5639int LLVMFuzzerInitialize(int *argc, char ***argv);
George Karpenkov10ab2ac2017-08-21 23:25:5040
41// Optional user-provided custom mutator.
42// Mutates raw data in [Data, Data+Size) inplace.
43// Returns the new size, which is not greater than MaxSize.
44// Given the same Seed produces the same mutation.
Petr Hosek68bc4bd2018-01-17 17:24:5645size_t LLVMFuzzerCustomMutator(uint8_t *Data, size_t Size, size_t MaxSize,
46 unsigned int Seed);
George Karpenkov10ab2ac2017-08-21 23:25:5047
48// Optional user-provided custom cross-over function.
49// Combines pieces of Data1 & Data2 together into Out.
50// Returns the new size, which is not greater than MaxOutSize.
51// Should produce the same mutation given the same Seed.
Petr Hosek68bc4bd2018-01-17 17:24:5652size_t LLVMFuzzerCustomCrossOver(const uint8_t *Data1, size_t Size1,
53 const uint8_t *Data2, size_t Size2,
54 uint8_t *Out, size_t MaxOutSize,
55 unsigned int Seed);
George Karpenkov10ab2ac2017-08-21 23:25:5056
57// Experimental, may go away in future.
58// libFuzzer-provided function to be used inside LLVMFuzzerCustomMutator.
59// Mutates raw data in [Data, Data+Size) inplace.
60// Returns the new size, which is not greater than MaxSize.
Petr Hosek68bc4bd2018-01-17 17:24:5661size_t LLVMFuzzerMutate(uint8_t *Data, size_t Size, size_t MaxSize);
George Karpenkov10ab2ac2017-08-21 23:25:5062
63#ifdef __cplusplus
64} // extern "C"
65#endif // __cplusplus
66
67#endif // LLVM_FUZZER_INTERFACE_H