diff options
Diffstat (limited to 'llvm/lib/Fuzzer/FuzzerDriver.cpp')
-rw-r--r-- | llvm/lib/Fuzzer/FuzzerDriver.cpp | 14 |
1 files changed, 6 insertions, 8 deletions
diff --git a/llvm/lib/Fuzzer/FuzzerDriver.cpp b/llvm/lib/Fuzzer/FuzzerDriver.cpp index 3dc062b9311..de5e461eda5 100644 --- a/llvm/lib/Fuzzer/FuzzerDriver.cpp +++ b/llvm/lib/Fuzzer/FuzzerDriver.cpp @@ -266,9 +266,13 @@ static bool AllInputsAreFiles() { return true; } -static int FuzzerDriver(const std::vector<std::string> &Args, - UserCallback Callback) { +int FuzzerDriver(int *argc, char ***argv, UserCallback Callback) { using namespace fuzzer; + assert(argc && argv && "Argument pointers cannot be nullptr"); + fuzzer::ExternalFunctions EF; + if (EF.LLVMFuzzerInitialize) + EF.LLVMFuzzerInitialize(argc, argv); + const std::vector<std::string> Args(*argv, *argv + *argc); assert(!Args.empty()); ProgName = new std::string(Args[0]); ParseFlags(Args); @@ -417,10 +421,4 @@ static int FuzzerDriver(const std::vector<std::string> &Args, exit(0); // Don't let F destroy itself. } - -int FuzzerDriver(int argc, char **argv, UserCallback Callback) { - std::vector<std::string> Args(argv, argv + argc); - return FuzzerDriver(Args, Callback); -} - } // namespace fuzzer |