kcc updated this revision to Diff 106573.
kcc added a comment.
Use EmitObjAction; also link and initialize the targets so
that we actually call the optimizer.
https://reviews.llvm.org/D34267
Files:
tools/clang-fuzzer/CMakeLists.txt
tools/clang-fuzzer/ClangFuzzer.cpp
Index: tools/clang-fuzzer/ClangFuzzer.cpp
===
--- tools/clang-fuzzer/ClangFuzzer.cpp
+++ tools/clang-fuzzer/ClangFuzzer.cpp
@@ -14,18 +14,25 @@
//===--===//
#include "clang/Tooling/Tooling.h"
-#include "clang/Frontend/FrontendActions.h"
+#include "clang/CodeGen/CodeGenAction.h"
#include "clang/Frontend/CompilerInstance.h"
#include "clang/Lex/PreprocessorOptions.h"
#include "llvm/Option/Option.h"
+#include "llvm/Support/TargetSelect.h"
using namespace clang;
extern "C" int LLVMFuzzerTestOneInput(uint8_t *data, size_t size) {
std::string s((const char *)data, size);
+ llvm::InitializeAllTargets();
+ llvm::InitializeAllTargetMCs();
+ llvm::InitializeAllAsmPrinters();
+ llvm::InitializeAllAsmParsers();
+
llvm::opt::ArgStringList CC1Args;
CC1Args.push_back("-cc1");
CC1Args.push_back("./test.cc");
+ CC1Args.push_back("-O2");
llvm::IntrusiveRefCntPtr Files(
new FileManager(FileSystemOptions()));
IgnoringDiagConsumer Diags;
@@ -39,7 +46,7 @@
llvm::MemoryBuffer::getMemBuffer(s);
Invocation->getPreprocessorOpts().addRemappedFile("./test.cc",
Input.release());
std::unique_ptr action(
- tooling::newFrontendActionFactory());
+ tooling::newFrontendActionFactory());
std::shared_ptr PCHContainerOps =
std::make_shared();
action->runInvocation(std::move(Invocation), Files.get(), PCHContainerOps,
Index: tools/clang-fuzzer/CMakeLists.txt
===
--- tools/clang-fuzzer/CMakeLists.txt
+++ tools/clang-fuzzer/CMakeLists.txt
@@ -1,5 +1,5 @@
if( LLVM_USE_SANITIZE_COVERAGE )
- set(LLVM_LINK_COMPONENTS support)
+ set(LLVM_LINK_COMPONENTS ${LLVM_TARGETS_TO_BUILD})
add_clang_executable(clang-fuzzer
EXCLUDE_FROM_ALL
@@ -10,6 +10,7 @@
${CLANG_FORMAT_LIB_DEPS}
clangAST
clangBasic
+clangCodeGen
clangDriver
clangFrontend
clangRewriteFrontend
Index: tools/clang-fuzzer/ClangFuzzer.cpp
===
--- tools/clang-fuzzer/ClangFuzzer.cpp
+++ tools/clang-fuzzer/ClangFuzzer.cpp
@@ -14,18 +14,25 @@
//===--===//
#include "clang/Tooling/Tooling.h"
-#include "clang/Frontend/FrontendActions.h"
+#include "clang/CodeGen/CodeGenAction.h"
#include "clang/Frontend/CompilerInstance.h"
#include "clang/Lex/PreprocessorOptions.h"
#include "llvm/Option/Option.h"
+#include "llvm/Support/TargetSelect.h"
using namespace clang;
extern "C" int LLVMFuzzerTestOneInput(uint8_t *data, size_t size) {
std::string s((const char *)data, size);
+ llvm::InitializeAllTargets();
+ llvm::InitializeAllTargetMCs();
+ llvm::InitializeAllAsmPrinters();
+ llvm::InitializeAllAsmParsers();
+
llvm::opt::ArgStringList CC1Args;
CC1Args.push_back("-cc1");
CC1Args.push_back("./test.cc");
+ CC1Args.push_back("-O2");
llvm::IntrusiveRefCntPtr Files(
new FileManager(FileSystemOptions()));
IgnoringDiagConsumer Diags;
@@ -39,7 +46,7 @@
llvm::MemoryBuffer::getMemBuffer(s);
Invocation->getPreprocessorOpts().addRemappedFile("./test.cc", Input.release());
std::unique_ptr action(
- tooling::newFrontendActionFactory());
+ tooling::newFrontendActionFactory());
std::shared_ptr PCHContainerOps =
std::make_shared();
action->runInvocation(std::move(Invocation), Files.get(), PCHContainerOps,
Index: tools/clang-fuzzer/CMakeLists.txt
===
--- tools/clang-fuzzer/CMakeLists.txt
+++ tools/clang-fuzzer/CMakeLists.txt
@@ -1,5 +1,5 @@
if( LLVM_USE_SANITIZE_COVERAGE )
- set(LLVM_LINK_COMPONENTS support)
+ set(LLVM_LINK_COMPONENTS ${LLVM_TARGETS_TO_BUILD})
add_clang_executable(clang-fuzzer
EXCLUDE_FROM_ALL
@@ -10,6 +10,7 @@
${CLANG_FORMAT_LIB_DEPS}
clangAST
clangBasic
+clangCodeGen
clangDriver
clangFrontend
clangRewriteFrontend
___
cfe-commits mailing list
cfe-commits@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits