1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- //===- FuzzerInterface.h - Interface header for the Fuzzer ------*- C++ -* ===//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- // Define the interface between libFuzzer and the library being tested.
- //===----------------------------------------------------------------------===//
- // NOTE: the libFuzzer interface is thin and in the majority of cases
- // you should not include this file into your target. In 95% of cases
- // all you need is to define the following function in your file:
- // extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
- // WARNING: keep the interface in C.
- #ifndef LLVM_FUZZER_INTERFACE_H
- #define LLVM_FUZZER_INTERFACE_H
- #include <stddef.h>
- #include <stdint.h>
- #ifdef __cplusplus
- extern "C" {
- #endif // __cplusplus
- // Define FUZZER_INTERFACE_VISIBILITY to set default visibility in a way that
- // doesn't break MSVC.
- #if defined(_WIN32)
- #define FUZZER_INTERFACE_VISIBILITY __declspec(dllexport)
- #else
- #define FUZZER_INTERFACE_VISIBILITY __attribute__((visibility("default")))
- #endif
- // Mandatory user-provided target function.
- // Executes the code under test with [Data, Data+Size) as the input.
- // libFuzzer will invoke this function *many* times with different inputs.
- // Must return 0.
- FUZZER_INTERFACE_VISIBILITY int
- LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
- // Optional user-provided initialization function.
- // If provided, this function will be called by libFuzzer once at startup.
- // It may read and modify argc/argv.
- // Must return 0.
- FUZZER_INTERFACE_VISIBILITY int LLVMFuzzerInitialize(int *argc, char ***argv);
- FUZZER_INTERFACE_VISIBILITY void LLVMFuzzerCleanup();
- // Optional user-provided custom mutator.
- // Mutates raw data in [Data, Data+Size) inplace.
- // Returns the new size, which is not greater than MaxSize.
- // Given the same Seed produces the same mutation.
- FUZZER_INTERFACE_VISIBILITY size_t
- LLVMFuzzerCustomMutator(uint8_t *Data, size_t Size, size_t MaxSize,
- unsigned int Seed);
- // Optional user-provided custom cross-over function.
- // Combines pieces of Data1 & Data2 together into Out.
- // Returns the new size, which is not greater than MaxOutSize.
- // Should produce the same mutation given the same Seed.
- FUZZER_INTERFACE_VISIBILITY 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);
- // Experimental, may go away in future.
- // libFuzzer-provided function to be used inside LLVMFuzzerCustomMutator.
- // Mutates raw data in [Data, Data+Size) inplace.
- // Returns the new size, which is not greater than MaxSize.
- FUZZER_INTERFACE_VISIBILITY size_t
- LLVMFuzzerMutate(uint8_t *Data, size_t Size, size_t MaxSize);
- #undef FUZZER_INTERFACE_VISIBILITY
- #ifdef __cplusplus
- } // extern "C"
- #endif // __cplusplus
- #endif // LLVM_FUZZER_INTERFACE_H
|