cmake: Introduce BUILD_FOR_COVERAGE build option

The new `BUILD_FOR_COVERAGE` build option enables instrumentation for
LLVM's Source-based Code Coverage reports.
This commit is contained in:
Hennadii Stepanov 2024-11-28 17:10:49 +00:00
parent dbc8ba12f3
commit 68108fa8b5
No known key found for this signature in database
GPG key ID: 410108112E7EA81F
13 changed files with 60 additions and 5 deletions

View file

@ -172,6 +172,8 @@ option(BUILD_BENCH "Build bench_bitcoin executable." OFF)
option(BUILD_FUZZ_BINARY "Build fuzz binary." OFF) option(BUILD_FUZZ_BINARY "Build fuzz binary." OFF)
option(BUILD_FOR_FUZZING "Build for fuzzing. Enabling this will disable all other targets and override BUILD_FUZZ_BINARY." OFF) option(BUILD_FOR_FUZZING "Build for fuzzing. Enabling this will disable all other targets and override BUILD_FUZZ_BINARY." OFF)
option(BUILD_FOR_COVERAGE "Build with Code Coverage instrumentation" OFF)
option(INSTALL_MAN "Install man pages." ON) option(INSTALL_MAN "Install man pages." ON)
set(APPEND_CPPFLAGS "" CACHE STRING "Preprocessor flags that are appended to the command line after all other flags added by the build system. This variable is intended for debugging and special builds.") set(APPEND_CPPFLAGS "" CACHE STRING "Preprocessor flags that are appended to the command line after all other flags added by the build system. This variable is intended for debugging and special builds.")
@ -372,6 +374,29 @@ if(BUILD_FUZZ_BINARY)
) )
endif() endif()
# The coverage_interface library is intended to be used
# only for code whose coverage report is of interest.
add_library(coverage_interface INTERFACE)
if(BUILD_FOR_COVERAGE)
if(NOT CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
message(FATAL_ERROR "BUILD_FOR_COVERAGE can only be specified when compiling with Clang.")
endif()
if(NOT PROFILE_FILE_PATTERN)
if(NOT PROFILE_DATA_DIR)
file(TO_NATIVE_PATH "${PROJECT_BINARY_DIR}/profiles" PROFILE_DATA_DIR)
endif()
file(TO_NATIVE_PATH "${PROFILE_DATA_DIR}/%m.profraw" PROFILE_FILE_PATTERN)
endif()
target_compile_options(coverage_interface INTERFACE
-fprofile-instr-generate=${PROFILE_FILE_PATTERN}
-fcoverage-mapping
)
target_link_options(coverage_interface INTERFACE
-fprofile-instr-generate=${PROFILE_FILE_PATTERN}
-fcoverage-mapping
)
endif()
include(AddBoostIfNeeded) include(AddBoostIfNeeded)
add_boost_if_needed() add_boost_if_needed()
@ -624,6 +649,7 @@ message(" test_bitcoin ........................ ${BUILD_TESTS}")
message(" test_bitcoin-qt ..................... ${BUILD_GUI_TESTS}") message(" test_bitcoin-qt ..................... ${BUILD_GUI_TESTS}")
message(" bench_bitcoin ....................... ${BUILD_BENCH}") message(" bench_bitcoin ....................... ${BUILD_BENCH}")
message(" fuzz binary ......................... ${BUILD_FUZZ_BINARY}") message(" fuzz binary ......................... ${BUILD_FUZZ_BINARY}")
message(" Code Coverage instrumentation ....... ${BUILD_FOR_COVERAGE}")
message("") message("")
if(CMAKE_CROSSCOMPILING) if(CMAKE_CROSSCOMPILING)
set(cross_status "TRUE, for ${CMAKE_SYSTEM_NAME}, ${CMAKE_SYSTEM_PROCESSOR}") set(cross_status "TRUE, for ${CMAKE_SYSTEM_NAME}, ${CMAKE_SYSTEM_PROCESSOR}")

View file

@ -20,6 +20,7 @@ add_library(bitcoin_clientversion OBJECT EXCLUDE_FROM_ALL
target_link_libraries(bitcoin_clientversion target_link_libraries(bitcoin_clientversion
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
) )
add_dependencies(bitcoin_clientversion generate_build_info) add_dependencies(bitcoin_clientversion generate_build_info)
@ -92,6 +93,7 @@ add_library(bitcoin_consensus STATIC EXCLUDE_FROM_ALL
target_link_libraries(bitcoin_consensus target_link_libraries(bitcoin_consensus
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
bitcoin_crypto bitcoin_crypto
secp256k1 secp256k1
) )
@ -156,6 +158,7 @@ add_library(bitcoin_common STATIC EXCLUDE_FROM_ALL
target_link_libraries(bitcoin_common target_link_libraries(bitcoin_common
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
bitcoin_consensus bitcoin_consensus
bitcoin_util bitcoin_util
univalue univalue
@ -179,6 +182,7 @@ if(ENABLE_WALLET)
add_windows_resources(bitcoin-wallet bitcoin-wallet-res.rc) add_windows_resources(bitcoin-wallet bitcoin-wallet-res.rc)
target_link_libraries(bitcoin-wallet target_link_libraries(bitcoin-wallet
core_interface core_interface
coverage_interface
bitcoin_wallet bitcoin_wallet
bitcoin_common bitcoin_common
bitcoin_util bitcoin_util
@ -289,6 +293,7 @@ add_library(bitcoin_node STATIC EXCLUDE_FROM_ALL
target_link_libraries(bitcoin_node target_link_libraries(bitcoin_node
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
bitcoin_common bitcoin_common
bitcoin_util bitcoin_util
$<TARGET_NAME_IF_EXISTS:bitcoin_zmq> $<TARGET_NAME_IF_EXISTS:bitcoin_zmq>
@ -312,6 +317,7 @@ if(BUILD_DAEMON)
add_windows_resources(bitcoind bitcoind-res.rc) add_windows_resources(bitcoind bitcoind-res.rc)
target_link_libraries(bitcoind target_link_libraries(bitcoind
core_interface core_interface
coverage_interface
bitcoin_node bitcoin_node
$<TARGET_NAME_IF_EXISTS:bitcoin_wallet> $<TARGET_NAME_IF_EXISTS:bitcoin_wallet>
) )
@ -324,6 +330,7 @@ if(WITH_MULTIPROCESS)
) )
target_link_libraries(bitcoin-node target_link_libraries(bitcoin-node
core_interface core_interface
coverage_interface
bitcoin_node bitcoin_node
bitcoin_ipc bitcoin_ipc
$<TARGET_NAME_IF_EXISTS:bitcoin_wallet> $<TARGET_NAME_IF_EXISTS:bitcoin_wallet>
@ -355,6 +362,7 @@ add_library(bitcoin_cli STATIC EXCLUDE_FROM_ALL
target_link_libraries(bitcoin_cli target_link_libraries(bitcoin_cli
PUBLIC PUBLIC
core_interface core_interface
coverage_interface
univalue univalue
) )
@ -365,6 +373,7 @@ if(BUILD_CLI)
add_windows_resources(bitcoin-cli bitcoin-cli-res.rc) add_windows_resources(bitcoin-cli bitcoin-cli-res.rc)
target_link_libraries(bitcoin-cli target_link_libraries(bitcoin-cli
core_interface core_interface
coverage_interface
bitcoin_cli bitcoin_cli
bitcoin_common bitcoin_common
bitcoin_util bitcoin_util
@ -380,6 +389,7 @@ if(BUILD_TX)
add_windows_resources(bitcoin-tx bitcoin-tx-res.rc) add_windows_resources(bitcoin-tx bitcoin-tx-res.rc)
target_link_libraries(bitcoin-tx target_link_libraries(bitcoin-tx
core_interface core_interface
coverage_interface
bitcoin_common bitcoin_common
bitcoin_util bitcoin_util
univalue univalue
@ -393,6 +403,7 @@ if(BUILD_UTIL)
add_windows_resources(bitcoin-util bitcoin-util-res.rc) add_windows_resources(bitcoin-util bitcoin-util-res.rc)
target_link_libraries(bitcoin-util target_link_libraries(bitcoin-util
core_interface core_interface
coverage_interface
bitcoin_common bitcoin_common
bitcoin_util bitcoin_util
) )
@ -425,6 +436,7 @@ if(BUILD_UTIL_CHAINSTATE)
target_link_libraries(bitcoin-chainstate target_link_libraries(bitcoin-chainstate
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
bitcoinkernel bitcoinkernel
) )
endif() endif()

View file

@ -25,6 +25,7 @@ add_library(bitcoin_crypto STATIC EXCLUDE_FROM_ALL
target_link_libraries(bitcoin_crypto target_link_libraries(bitcoin_crypto
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
) )
if(HAVE_SSE41) if(HAVE_SSE41)
@ -33,7 +34,7 @@ if(HAVE_SSE41)
) )
target_compile_definitions(bitcoin_crypto_sse41 PUBLIC ENABLE_SSE41) target_compile_definitions(bitcoin_crypto_sse41 PUBLIC ENABLE_SSE41)
target_compile_options(bitcoin_crypto_sse41 PRIVATE ${SSE41_CXXFLAGS}) target_compile_options(bitcoin_crypto_sse41 PRIVATE ${SSE41_CXXFLAGS})
target_link_libraries(bitcoin_crypto_sse41 PRIVATE core_interface) target_link_libraries(bitcoin_crypto_sse41 PRIVATE core_interface coverage_interface)
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_sse41) target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_sse41)
endif() endif()
@ -43,7 +44,7 @@ if(HAVE_AVX2)
) )
target_compile_definitions(bitcoin_crypto_avx2 PUBLIC ENABLE_AVX2) target_compile_definitions(bitcoin_crypto_avx2 PUBLIC ENABLE_AVX2)
target_compile_options(bitcoin_crypto_avx2 PRIVATE ${AVX2_CXXFLAGS}) target_compile_options(bitcoin_crypto_avx2 PRIVATE ${AVX2_CXXFLAGS})
target_link_libraries(bitcoin_crypto_avx2 PRIVATE core_interface) target_link_libraries(bitcoin_crypto_avx2 PRIVATE core_interface coverage_interface)
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_avx2) target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_avx2)
endif() endif()
@ -53,7 +54,7 @@ if(HAVE_SSE41 AND HAVE_X86_SHANI)
) )
target_compile_definitions(bitcoin_crypto_x86_shani PUBLIC ENABLE_SSE41 ENABLE_X86_SHANI) target_compile_definitions(bitcoin_crypto_x86_shani PUBLIC ENABLE_SSE41 ENABLE_X86_SHANI)
target_compile_options(bitcoin_crypto_x86_shani PRIVATE ${X86_SHANI_CXXFLAGS}) target_compile_options(bitcoin_crypto_x86_shani PRIVATE ${X86_SHANI_CXXFLAGS})
target_link_libraries(bitcoin_crypto_x86_shani PRIVATE core_interface) target_link_libraries(bitcoin_crypto_x86_shani PRIVATE core_interface coverage_interface)
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_x86_shani) target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_x86_shani)
endif() endif()
@ -63,6 +64,6 @@ if(HAVE_ARM_SHANI)
) )
target_compile_definitions(bitcoin_crypto_arm_shani PUBLIC ENABLE_ARM_SHANI) target_compile_definitions(bitcoin_crypto_arm_shani PUBLIC ENABLE_ARM_SHANI)
target_compile_options(bitcoin_crypto_arm_shani PRIVATE ${ARM_SHANI_CXXFLAGS}) target_compile_options(bitcoin_crypto_arm_shani PRIVATE ${ARM_SHANI_CXXFLAGS})
target_link_libraries(bitcoin_crypto_arm_shani PRIVATE core_interface) target_link_libraries(bitcoin_crypto_arm_shani PRIVATE core_interface coverage_interface)
target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_arm_shani) target_link_libraries(bitcoin_crypto PRIVATE bitcoin_crypto_arm_shani)
endif() endif()

View file

@ -19,5 +19,6 @@ target_capnp_sources(bitcoin_ipc ${PROJECT_SOURCE_DIR}
target_link_libraries(bitcoin_ipc target_link_libraries(bitcoin_ipc
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
univalue univalue
) )

View file

@ -81,6 +81,7 @@ add_library(bitcoinkernel
target_link_libraries(bitcoinkernel target_link_libraries(bitcoinkernel
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
bitcoin_clientversion bitcoin_clientversion
bitcoin_crypto bitcoin_crypto
leveldb leveldb

View file

@ -148,6 +148,7 @@ add_executable(test_bitcoin
target_link_libraries(test_bitcoin target_link_libraries(test_bitcoin
core_interface core_interface
coverage_interface
test_util test_util
bitcoin_cli bitcoin_cli
bitcoin_node bitcoin_node
@ -165,6 +166,7 @@ if(WITH_MULTIPROCESS)
target_link_libraries(bitcoin_ipc_test target_link_libraries(bitcoin_ipc_test
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
univalue univalue
) )

View file

@ -134,6 +134,7 @@ add_executable(fuzz
) )
target_link_libraries(fuzz target_link_libraries(fuzz
core_interface core_interface
coverage_interface
test_fuzz test_fuzz
bitcoin_cli bitcoin_cli
bitcoin_common bitcoin_common

View file

@ -13,6 +13,7 @@ add_library(test_fuzz STATIC EXCLUDE_FROM_ALL
target_link_libraries(test_fuzz target_link_libraries(test_fuzz
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
test_util test_util
bitcoin_node bitcoin_node
Boost::headers Boost::headers

View file

@ -23,6 +23,7 @@ add_library(test_util STATIC EXCLUDE_FROM_ALL
target_link_libraries(test_util target_link_libraries(test_util
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
Boost::headers Boost::headers
PUBLIC PUBLIC
univalue univalue

View file

@ -12,7 +12,11 @@ target_include_directories(univalue
PUBLIC PUBLIC
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include> $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
) )
target_link_libraries(univalue PRIVATE core_interface) target_link_libraries(univalue
PRIVATE
core_interface
coverage_interface
)
if(BUILD_TESTS) if(BUILD_TESTS)
add_executable(unitester test/unitester.cpp) add_executable(unitester test/unitester.cpp)
@ -23,6 +27,7 @@ if(BUILD_TESTS)
target_link_libraries(unitester target_link_libraries(unitester
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
univalue univalue
) )
add_test(NAME univalue_test add_test(NAME univalue_test
@ -33,6 +38,7 @@ if(BUILD_TESTS)
target_link_libraries(object target_link_libraries(object
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
univalue univalue
) )
add_test(NAME univalue_object_test add_test(NAME univalue_object_test

View file

@ -39,6 +39,7 @@ add_library(bitcoin_util STATIC EXCLUDE_FROM_ALL
target_link_libraries(bitcoin_util target_link_libraries(bitcoin_util
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
bitcoin_clientversion bitcoin_clientversion
bitcoin_crypto bitcoin_crypto
$<$<PLATFORM_ID:Windows>:ws2_32> $<$<PLATFORM_ID:Windows>:ws2_32>

View file

@ -36,6 +36,7 @@ add_library(bitcoin_wallet STATIC EXCLUDE_FROM_ALL
target_link_libraries(bitcoin_wallet target_link_libraries(bitcoin_wallet
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
bitcoin_common bitcoin_common
univalue univalue
Boost::headers Boost::headers

View file

@ -16,6 +16,7 @@ target_compile_definitions(bitcoin_zmq
target_link_libraries(bitcoin_zmq target_link_libraries(bitcoin_zmq
PRIVATE PRIVATE
core_interface core_interface
coverage_interface
univalue univalue
zeromq zeromq
) )