blob: 8b4d61905d00a154a9ee36207cba4f8de344bb7f [file] [log] [blame]
Kostya Serebryany16d03bd2015-03-30 22:09:51 +00001set(LIBFUZZER_FLAGS_BASE "${CMAKE_CXX_FLAGS_RELEASE}")
2# Disable the coverage and sanitizer instrumentation for the fuzzer itself.
3set(CMAKE_CXX_FLAGS_RELEASE "${LIBFUZZER_FLAGS_BASE} -O2 -fno-sanitize=all")
Aaron Ballmanf77031f2015-04-06 16:09:13 +00004if( LLVM_USE_SANITIZE_COVERAGE )
Kostya Serebryanyf3424592015-05-22 22:35:31 +00005 add_library(LLVMFuzzerNoMainObjects OBJECT
Aaron Ballmanef116982015-01-29 16:58:29 +00006 FuzzerCrossOver.cpp
Kostya Serebryanyf3424592015-05-22 22:35:31 +00007 FuzzerInterface.cpp
Kostya Serebryany22526252015-05-11 21:16:27 +00008 FuzzerTraceState.cpp
Kostya Serebryany016852c2015-02-19 18:45:37 +00009 FuzzerDriver.cpp
Aaron Ballmanef116982015-01-29 16:58:29 +000010 FuzzerIO.cpp
11 FuzzerLoop.cpp
Aaron Ballmanef116982015-01-29 16:58:29 +000012 FuzzerMutate.cpp
Kostya Serebryanydb4d6452015-02-06 19:52:07 +000013 FuzzerSanitizerOptions.cpp
Kostya Serebryany96eab652015-05-14 22:41:49 +000014 FuzzerSHA1.cpp
Aaron Ballmanef116982015-01-29 16:58:29 +000015 FuzzerUtil.cpp
16 )
Kostya Serebryanyf3424592015-05-22 22:35:31 +000017 add_library(LLVMFuzzerNoMain STATIC
18 $<TARGET_OBJECTS:LLVMFuzzerNoMainObjects>
19 )
Kostya Serebryany71672552015-01-30 23:26:57 +000020 add_library(LLVMFuzzer STATIC
21 FuzzerMain.cpp
Kostya Serebryanyf3424592015-05-22 22:35:31 +000022 $<TARGET_OBJECTS:LLVMFuzzerNoMainObjects>
Kostya Serebryany71672552015-01-30 23:26:57 +000023 )
Aaron Ballmanef116982015-01-29 16:58:29 +000024
25 if( LLVM_INCLUDE_TESTS )
26 add_subdirectory(test)
27 endif()
28endif()