blob: 3fae903c44cca4408d08b7c10fe199ce3ace7658 [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
Kostya Serebryanyda63c1d2016-02-26 21:33:56 +000015 FuzzerTracePC.cpp
Aaron Ballmanef116982015-01-29 16:58:29 +000016 FuzzerUtil.cpp
17 )
Kostya Serebryanyf3424592015-05-22 22:35:31 +000018 add_library(LLVMFuzzerNoMain STATIC
19 $<TARGET_OBJECTS:LLVMFuzzerNoMainObjects>
20 )
Rafael Espindola5cd721a2016-03-01 15:54:40 +000021 target_link_libraries(LLVMFuzzerNoMain ${PTHREAD_LIB})
Kostya Serebryany71672552015-01-30 23:26:57 +000022 add_library(LLVMFuzzer STATIC
23 FuzzerMain.cpp
Kostya Serebryanyf3424592015-05-22 22:35:31 +000024 $<TARGET_OBJECTS:LLVMFuzzerNoMainObjects>
Kostya Serebryany71672552015-01-30 23:26:57 +000025 )
Rafael Espindola5cd721a2016-03-01 15:54:40 +000026 target_link_libraries(LLVMFuzzer ${PTHREAD_LIB})
Aaron Ballmanef116982015-01-29 16:58:29 +000027
28 if( LLVM_INCLUDE_TESTS )
29 add_subdirectory(test)
30 endif()
31endif()