blob: 726eec6b74304ea22d3abf9031253c1d8242f5e5 [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.
Kostya Serebryany90bcdb52016-02-18 02:02:40 +00003set(CMAKE_CXX_FLAGS_RELEASE "${LIBFUZZER_FLAGS_BASE} -O2 -fno-sanitize=all -fno-sanitize-coverage=edge,trace-cmp,indirect-calls,8bit-counters ")
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 )
Peter Collingbourne16c19782015-12-16 02:14:57 +000020 if( HAVE_LIBPTHREAD )
21 target_link_libraries(LLVMFuzzerNoMain pthread)
22 endif()
Kostya Serebryany71672552015-01-30 23:26:57 +000023 add_library(LLVMFuzzer STATIC
24 FuzzerMain.cpp
Kostya Serebryanyf3424592015-05-22 22:35:31 +000025 $<TARGET_OBJECTS:LLVMFuzzerNoMainObjects>
Kostya Serebryany71672552015-01-30 23:26:57 +000026 )
Peter Collingbourne16c19782015-12-16 02:14:57 +000027 if( HAVE_LIBPTHREAD )
28 target_link_libraries(LLVMFuzzer pthread)
29 endif()
Aaron Ballmanef116982015-01-29 16:58:29 +000030
31 if( LLVM_INCLUDE_TESTS )
32 add_subdirectory(test)
33 endif()
34endif()