//===- FuzzerDataFlowTrace.h - Internal 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 // //===----------------------------------------------------------------------===// // fuzzer::DataFlowTrace; reads and handles a data-flow trace. // // A data flow trace is generated by e.g. dataflow/DataFlow.cpp // and is stored on disk in a separate directory. // // The trace dir contains a file 'functions.txt' which lists function names, // oner per line, e.g. // ==> functions.txt <== // Func2 // LLVMFuzzerTestOneInput // Func1 // // All other files in the dir are the traces, see dataflow/DataFlow.cpp. // The name of the file is sha1 of the input used to generate the trace. // // Current status: // the data is parsed and the summary is printed, but the data is not yet // used in any other way. //===----------------------------------------------------------------------===// #ifndef LLVM_FUZZER_DATA_FLOW_TRACE #define LLVM_FUZZER_DATA_FLOW_TRACE #include "FuzzerDefs.h" #include "FuzzerIO.h" #include <unordered_map> #include <unordered_set> #include <vector> #include <string> namespace fuzzer { int CollectDataFlow(const std::string &DFTBinary, const std::string &DirPath, const std::vector<SizedFile> &CorporaFiles); class BlockCoverage { … }; class DataFlowTrace { … }; } // namespace fuzzer #endif // LLVM_FUZZER_DATA_FLOW_TRACE