Fix libfuzzer detection and shared object symbols issues
Don't export __throw_length_error, and don't import abort
This commit is contained in:
@@ -21,6 +21,10 @@ target_compile_options(conflict_set PRIVATE -fno-exceptions -fvisibility=hidden)
|
||||
target_link_options(conflict_set PRIVATE -nodefaultlibs -lc -fvisibility=hidden)
|
||||
add_custom_command(TARGET conflict_set POST_BUILD COMMAND ${CMAKE_STRIP} -x $<TARGET_FILE:conflict_set>)
|
||||
|
||||
if (NOT APPLE)
|
||||
target_link_options(conflict_set PRIVATE "LINKER:--version-script=${CMAKE_CURRENT_SOURCE_DIR}/linker.map")
|
||||
endif()
|
||||
|
||||
include(CTest)
|
||||
|
||||
# unit test
|
||||
@@ -52,7 +56,7 @@ add_test(NAME conflict_set_cxx_api_test COMMAND conflict_set_cxx_api_test)
|
||||
target_compile_options(conflict_set_cxx_api_test PRIVATE -Wall -Wextra -Wpedantic -Wunreachable-code -Werror)
|
||||
|
||||
# fuzz test
|
||||
set(FUZZ_FLAGS "-fsanitize=fuzzer,address,undefined")
|
||||
set(FUZZ_FLAGS "-fsanitize=fuzzer-no-link,address,undefined")
|
||||
include(CheckCXXCompilerFlag)
|
||||
set(CMAKE_REQUIRED_LINK_OPTIONS ${FUZZ_FLAGS})
|
||||
check_cxx_compiler_flag(${FUZZ_FLAGS} HAS_LIB_FUZZER)
|
||||
@@ -64,5 +68,5 @@ if (HAS_LIB_FUZZER)
|
||||
target_compile_options(conflict_set_fuzz_test PRIVATE -UNDEBUG)
|
||||
target_compile_options(conflict_set_fuzz_test PRIVATE -Wall -Wextra -Wpedantic -Wunreachable-code)
|
||||
target_compile_options(conflict_set_fuzz_test PRIVATE ${FUZZ_FLAGS})
|
||||
target_link_options(conflict_set_fuzz_test PRIVATE ${FUZZ_FLAGS})
|
||||
target_link_options(conflict_set_fuzz_test PRIVATE ${FUZZ_FLAGS} -fsanitize=fuzzer)
|
||||
endif()
|
||||
|
Reference in New Issue
Block a user