blob: 6bd1d288be825209a5a3ee85d28f423defb7f505 [file] [log] [blame]
Dan Liew676892a2016-05-26 20:55:05 +00001set(LIBFUZZER_FLAGS_BASE "${CMAKE_CXX_FLAGS}")
Kostya Serebryany16d03bd2015-03-30 22:09:51 +00002# Disable the coverage and sanitizer instrumentation for the fuzzer itself.
Dan Liew676892a2016-05-26 20:55:05 +00003set(CMAKE_CXX_FLAGS "${LIBFUZZER_FLAGS_BASE} -fno-sanitize=all -fno-sanitize-coverage=edge,trace-cmp,indirect-calls,8bit-counters -Werror")
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 Serebryany22526252015-05-11 21:16:27 +00007 FuzzerTraceState.cpp
Kostya Serebryany016852c2015-02-19 18:45:37 +00008 FuzzerDriver.cpp
Aaron Ballmanef116982015-01-29 16:58:29 +00009 FuzzerIO.cpp
10 FuzzerLoop.cpp
Aaron Ballmanef116982015-01-29 16:58:29 +000011 FuzzerMutate.cpp
Kostya Serebryany96eab652015-05-14 22:41:49 +000012 FuzzerSHA1.cpp
Kostya Serebryanyda63c1d2016-02-26 21:33:56 +000013 FuzzerTracePC.cpp
Aaron Ballmanef116982015-01-29 16:58:29 +000014 FuzzerUtil.cpp
15 )
Kostya Serebryanyf3424592015-05-22 22:35:31 +000016 add_library(LLVMFuzzerNoMain STATIC
17 $<TARGET_OBJECTS:LLVMFuzzerNoMainObjects>
18 )
Rafael Espindola5cd721a2016-03-01 15:54:40 +000019 target_link_libraries(LLVMFuzzerNoMain ${PTHREAD_LIB})
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 )
Rafael Espindola5cd721a2016-03-01 15:54:40 +000024 target_link_libraries(LLVMFuzzer ${PTHREAD_LIB})
Aaron Ballmanef116982015-01-29 16:58:29 +000025
26 if( LLVM_INCLUDE_TESTS )
27 add_subdirectory(test)
28 endif()
29endif()