aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHennadii Stepanov <32963518+hebasto@users.noreply.github.com>2024-07-13 14:26:37 +0100
committerHennadii Stepanov <32963518+hebasto@users.noreply.github.com>2024-08-16 19:27:37 +0100
commit51985c5304dfc52bd45f505b3115989637d79ff5 (patch)
tree067e3462d349204b51394984862b86ae5a3f55a1
parentdb7a198f29c62c5f762eaa25d1d83c57e2f1e211 (diff)
downloadbitcoin-51985c5304dfc52bd45f505b3115989637d79ff5.tar.xz
cmake: Build `crc32c` static library
-rw-r--r--CMakeLists.txt1
-rw-r--r--cmake/crc32c.cmake123
2 files changed, 124 insertions, 0 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index f76e61e5b8..f9dc025784 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -209,6 +209,7 @@ try_append_cxx_flags("-fstack-reuse=none" TARGET core_interface)
# - https://github.com/bitcoin/bitcoin/pull/30312#issuecomment-2191235833
set(CMAKE_SKIP_BUILD_RPATH TRUE)
set(CMAKE_SKIP_INSTALL_RPATH TRUE)
+include(cmake/crc32c.cmake)
add_subdirectory(src)
message("\n")
diff --git a/cmake/crc32c.cmake b/cmake/crc32c.cmake
new file mode 100644
index 0000000000..16fde7f95d
--- /dev/null
+++ b/cmake/crc32c.cmake
@@ -0,0 +1,123 @@
+# Copyright (c) 2023-present The Bitcoin Core developers
+# Distributed under the MIT software license, see the accompanying
+# file COPYING or https://opensource.org/license/mit/.
+
+# This file is part of the transition from Autotools to CMake. Once CMake
+# support has been merged we should switch to using the upstream CMake
+# buildsystem.
+
+include(CheckCXXSourceCompiles)
+
+# Check for __builtin_prefetch support in the compiler.
+check_cxx_source_compiles("
+ int main() {
+ char data = 0;
+ const char* address = &data;
+ __builtin_prefetch(address, 0, 0);
+ return 0;
+ }
+ " HAVE_BUILTIN_PREFETCH
+)
+
+# Check for _mm_prefetch support in the compiler.
+check_cxx_source_compiles("
+ #if defined(_MSC_VER)
+ #include <intrin.h>
+ #else
+ #include <xmmintrin.h>
+ #endif
+
+ int main() {
+ char data = 0;
+ const char* address = &data;
+ _mm_prefetch(address, _MM_HINT_NTA);
+ return 0;
+ }
+ " HAVE_MM_PREFETCH
+)
+
+# Check for SSE4.2 support in the compiler.
+if(MSVC)
+ set(SSE42_CXXFLAGS /arch:AVX)
+else()
+ set(SSE42_CXXFLAGS -msse4.2)
+endif()
+check_cxx_source_compiles_with_flags("${SSE42_CXXFLAGS}" "
+ #include <cstdint>
+ #if defined(_MSC_VER)
+ #include <intrin.h>
+ #elif defined(__GNUC__) && defined(__SSE4_2__)
+ #include <nmmintrin.h>
+ #endif
+
+ int main() {
+ uint64_t l = 0;
+ l = _mm_crc32_u8(l, 0);
+ l = _mm_crc32_u32(l, 0);
+ l = _mm_crc32_u64(l, 0);
+ return l;
+ }
+ " HAVE_SSE42
+)
+
+# Check for ARMv8 w/ CRC and CRYPTO extensions support in the compiler.
+set(ARM64_CRC_CXXFLAGS -march=armv8-a+crc+crypto)
+check_cxx_source_compiles_with_flags("${ARM64_CRC_CXXFLAGS}" "
+ #include <arm_acle.h>
+ #include <arm_neon.h>
+
+ int main() {
+ #ifdef __aarch64__
+ __crc32cb(0, 0); __crc32ch(0, 0); __crc32cw(0, 0); __crc32cd(0, 0);
+ vmull_p64(0, 0);
+ #else
+ #error crc32c library does not support hardware acceleration on 32-bit ARM
+ #endif
+ return 0;
+ }
+ " HAVE_ARM64_CRC32C
+)
+
+add_library(crc32c_common INTERFACE)
+target_compile_definitions(crc32c_common INTERFACE
+ HAVE_BUILTIN_PREFETCH=$<BOOL:${HAVE_BUILTIN_PREFETCH}>
+ HAVE_MM_PREFETCH=$<BOOL:${HAVE_MM_PREFETCH}>
+ HAVE_STRONG_GETAUXVAL=$<BOOL:${HAVE_STRONG_GETAUXVAL}>
+ BYTE_ORDER_BIG_ENDIAN=$<STREQUAL:${CMAKE_CXX_BYTE_ORDER},BIG_ENDIAN>
+ HAVE_SSE42=$<BOOL:${HAVE_SSE42}>
+ HAVE_ARM64_CRC32C=$<BOOL:${HAVE_ARM64_CRC32C}>
+)
+target_link_libraries(crc32c_common INTERFACE
+ core_interface
+)
+
+add_library(crc32c STATIC EXCLUDE_FROM_ALL
+ ${PROJECT_SOURCE_DIR}/src/crc32c/src/crc32c.cc
+ ${PROJECT_SOURCE_DIR}/src/crc32c/src/crc32c_portable.cc
+)
+target_include_directories(crc32c
+ PUBLIC
+ $<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/src/crc32c/include>
+)
+target_link_libraries(crc32c PRIVATE crc32c_common)
+set_target_properties(crc32c PROPERTIES EXPORT_COMPILE_COMMANDS OFF)
+
+if(HAVE_SSE42)
+ add_library(crc32c_sse42 STATIC EXCLUDE_FROM_ALL
+ ${PROJECT_SOURCE_DIR}/src/crc32c/src/crc32c_sse42.cc
+ )
+ target_compile_options(crc32c_sse42 PRIVATE ${SSE42_CXXFLAGS})
+ target_link_libraries(crc32c_sse42 PRIVATE crc32c_common)
+ set_target_properties(crc32c_sse42 PROPERTIES EXPORT_COMPILE_COMMANDS OFF)
+ target_link_libraries(crc32c PRIVATE crc32c_sse42)
+endif()
+
+if(HAVE_ARM64_CRC32C)
+ add_library(crc32c_arm64 STATIC EXCLUDE_FROM_ALL
+ ${PROJECT_SOURCE_DIR}/src/crc32c/src/crc32c_arm64.cc
+ )
+ target_compile_options(crc32c_arm64 PRIVATE ${ARM64_CRC_CXXFLAGS})
+ target_link_libraries(crc32c_arm64 PRIVATE crc32c_common)
+ set_target_properties(crc32c_arm64 PROPERTIES EXPORT_COMPILE_COMMANDS OFF)
+ target_link_libraries(crc32c PRIVATE crc32c_arm64)
+endif()