commit 1338a8b: [Minor] Link with libatomic where possible
Vsevolod Stakhov
vsevolod at rspamd.com
Mon Jul 31 15:14:03 UTC 2023
Author: Vsevolod Stakhov
Date: 2023-07-31 16:06:44 +0100
URL: https://github.com/rspamd/rspamd/commit/1338a8b9272dbea20ce0e4fee2c986bd5eeaa82b (HEAD -> master)
[Minor] Link with libatomic where possible
Issue: #4552
---
CMakeLists.txt | 818 +++++++++++++++++++++++++++++----------------------------
1 file changed, 412 insertions(+), 406 deletions(-)
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 5ea71a060..bea0af828 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -14,12 +14,12 @@ SET(RSPAMD_VERSION_MINOR 6)
SET(RSPAMD_VERSION_MAJOR_NUM ${RSPAMD_VERSION_MAJOR}0)
SET(RSPAMD_VERSION_MINOR_NUM ${RSPAMD_VERSION_MINOR}0)
-IF(GIT_ID)
- SET(GIT_VERSION 1)
- SET(RSPAMD_ID "${GIT_ID}")
-ENDIF()
+IF (GIT_ID)
+ SET(GIT_VERSION 1)
+ SET(RSPAMD_ID "${GIT_ID}")
+ENDIF ()
-SET(RSPAMD_VERSION "${RSPAMD_VERSION_MAJOR}.${RSPAMD_VERSION_MINOR}")
+SET(RSPAMD_VERSION "${RSPAMD_VERSION_MAJOR}.${RSPAMD_VERSION_MINOR}")
PROJECT(rspamd VERSION "${RSPAMD_VERSION}" LANGUAGES C CXX ASM)
@@ -34,34 +34,34 @@ LIST(APPEND CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake/")
SET(RSPAMD_MASTER_SITE_URL "https://rspamd.com")
-IF(NOT RSPAMD_USER)
- SET(RSPAMD_USER "nobody")
- SET(RSPAMD_GROUP "nobody")
-ENDIF(NOT RSPAMD_USER)
+IF (NOT RSPAMD_USER)
+ SET(RSPAMD_USER "nobody")
+ SET(RSPAMD_GROUP "nobody")
+ENDIF (NOT RSPAMD_USER)
# Default for SysV Init
SET(RSPAMD_WORKER_NORMAL "*:11333")
SET(RSPAMD_WORKER_CONTROLLER "*:11334")
############################# OPTIONS SECTION #############################################
-OPTION(ENABLE_LUAJIT "Link with libluajit [default: ON]" ON)
-OPTION(ENABLE_URL_INCLUDE "Enable urls in ucl includes (requires libcurl or libfetch) [default: OFF]" OFF)
-OPTION(NO_SHARED "Build internal libs static [default: ON]" ON)
-OPTION(INSTALL_WEBUI "Install web interface [default: ON]" ON)
-OPTION(WANT_SYSTEMD_UNITS "Install systemd unit files on Linux [default: OFF]" OFF)
-OPTION(ENABLE_SNOWBALL "Enable snowball stemmer [default: ON]" ON)
+OPTION(ENABLE_LUAJIT "Link with libluajit [default: ON]" ON)
+OPTION(ENABLE_URL_INCLUDE "Enable urls in ucl includes (requires libcurl or libfetch) [default: OFF]" OFF)
+OPTION(NO_SHARED "Build internal libs static [default: ON]" ON)
+OPTION(INSTALL_WEBUI "Install web interface [default: ON]" ON)
+OPTION(WANT_SYSTEMD_UNITS "Install systemd unit files on Linux [default: OFF]" OFF)
+OPTION(ENABLE_SNOWBALL "Enable snowball stemmer [default: ON]" ON)
OPTION(ENABLE_CLANG_PLUGIN "Enable clang static analysing plugin [default: OFF]" OFF)
-OPTION(ENABLE_PCRE2 "Enable pcre2 instead of pcre [default: ON]" ON)
-OPTION(ENABLE_JEMALLOC "Build rspamd with jemalloc allocator [default: OFF]" OFF)
-OPTION(ENABLE_UTILS "Build rspamd internal utils [default: OFF]" OFF)
-OPTION(ENABLE_LIBUNWIND "Use libunwind to print crash traces [default: OFF]" OFF)
-OPTION(ENABLE_LUA_TRACE "Trace all Lua C API invocations [default: OFF]" OFF)
-OPTION(ENABLE_LUA_REPL "Enables Lua repl (requires C++11 compiler) [default: ON]" ON)
-OPTION(ENABLE_FASTTEXT "Link with FastText library [default: OFF]" OFF)
-OPTION(SYSTEM_ZSTD "Use system zstd instead of bundled one [default: OFF]" OFF)
-OPTION(SYSTEM_FMT "Use system fmt instead of bundled one [default: OFF]" OFF)
-OPTION(SYSTEM_DOCTEST "Use system doctest instead of bundled one [default: OFF]" OFF)
-OPTION(SYSTEM_XXHASH "Use system xxhash instead of bundled one [default: OFF]" OFF)
+OPTION(ENABLE_PCRE2 "Enable pcre2 instead of pcre [default: ON]" ON)
+OPTION(ENABLE_JEMALLOC "Build rspamd with jemalloc allocator [default: OFF]" OFF)
+OPTION(ENABLE_UTILS "Build rspamd internal utils [default: OFF]" OFF)
+OPTION(ENABLE_LIBUNWIND "Use libunwind to print crash traces [default: OFF]" OFF)
+OPTION(ENABLE_LUA_TRACE "Trace all Lua C API invocations [default: OFF]" OFF)
+OPTION(ENABLE_LUA_REPL "Enables Lua repl (requires C++11 compiler) [default: ON]" ON)
+OPTION(ENABLE_FASTTEXT "Link with FastText library [default: OFF]" OFF)
+OPTION(SYSTEM_ZSTD "Use system zstd instead of bundled one [default: OFF]" OFF)
+OPTION(SYSTEM_FMT "Use system fmt instead of bundled one [default: OFF]" OFF)
+OPTION(SYSTEM_DOCTEST "Use system doctest instead of bundled one [default: OFF]" OFF)
+OPTION(SYSTEM_XXHASH "Use system xxhash instead of bundled one [default: OFF]" OFF)
############################# INCLUDE SECTION #############################################
@@ -78,52 +78,52 @@ INCLUDE(AsmOp)
INCLUDE(FindRagel)
INCLUDE(ProcessPackage)
-IF(NOT RAGEL_FOUND)
- MESSAGE(FATAL_ERROR "Ragel is required to build rspamd")
-ENDIF()
+IF (NOT RAGEL_FOUND)
+ MESSAGE(FATAL_ERROR "Ragel is required to build rspamd")
+ENDIF ()
FIND_PACKAGE(PkgConfig REQUIRED)
FIND_PACKAGE(Perl REQUIRED)
-option (SANITIZE "Enable sanitizer: address, memory, undefined, leak (comma separated list)" "")
+option(SANITIZE "Enable sanitizer: address, memory, undefined, leak (comma separated list)" "")
INCLUDE(Toolset)
INCLUDE(Sanitizer)
INCLUDE(ArchDep)
INCLUDE(Paths)
-IF(ENABLE_PCRE2 MATCHES "ON")
- SET(WITH_PCRE2 1)
- # For utf8 API
- LIST(APPEND CMAKE_REQUIRED_DEFINITIONS "-DPCRE2_CODE_UNIT_WIDTH=8")
-ENDIF()
+IF (ENABLE_PCRE2 MATCHES "ON")
+ SET(WITH_PCRE2 1)
+ # For utf8 API
+ LIST(APPEND CMAKE_REQUIRED_DEFINITIONS "-DPCRE2_CODE_UNIT_WIDTH=8")
+ENDIF ()
############################# CONFIG SECTION #############################################
# Initial set
# Prefer local include dirs to system ones
INCLUDE_DIRECTORIES("${CMAKE_SOURCE_DIR}/"
- "${CMAKE_SOURCE_DIR}/src"
- "${CMAKE_SOURCE_DIR}/src/libutil"
- "${CMAKE_SOURCE_DIR}/src/libserver"
- "${CMAKE_SOURCE_DIR}/src/libmime"
- "${CMAKE_SOURCE_DIR}/src/libstat"
- "${CMAKE_SOURCE_DIR}/src/libcryptobox"
- "${CMAKE_SOURCE_DIR}/contrib/libucl"
- "${CMAKE_SOURCE_DIR}/contrib/replxx/include"
- "${CMAKE_SOURCE_DIR}/contrib/uthash"
- "${CMAKE_SOURCE_DIR}/contrib/http-parser"
- "${CMAKE_SOURCE_DIR}/contrib/fpconv"
- "${CMAKE_SOURCE_DIR}/contrib/libottery"
- "${CMAKE_SOURCE_DIR}/contrib/cdb"
- "${CMAKE_SOURCE_DIR}/contrib/snowball/include"
- "${CMAKE_SOURCE_DIR}/contrib/librdns"
- "${CMAKE_SOURCE_DIR}/contrib/aho-corasick"
- "${CMAKE_SOURCE_DIR}/contrib/lc-btrie"
- "${CMAKE_SOURCE_DIR}/contrib/lua-lpeg"
- "${CMAKE_SOURCE_DIR}/contrib/frozen/include"
- "${CMAKE_SOURCE_DIR}/contrib/fu2/include"
- "${CMAKE_BINARY_DIR}/src" #Stored in the binary dir
- "${CMAKE_BINARY_DIR}/src/libcryptobox")
+ "${CMAKE_SOURCE_DIR}/src"
+ "${CMAKE_SOURCE_DIR}/src/libutil"
+ "${CMAKE_SOURCE_DIR}/src/libserver"
+ "${CMAKE_SOURCE_DIR}/src/libmime"
+ "${CMAKE_SOURCE_DIR}/src/libstat"
+ "${CMAKE_SOURCE_DIR}/src/libcryptobox"
+ "${CMAKE_SOURCE_DIR}/contrib/libucl"
+ "${CMAKE_SOURCE_DIR}/contrib/replxx/include"
+ "${CMAKE_SOURCE_DIR}/contrib/uthash"
+ "${CMAKE_SOURCE_DIR}/contrib/http-parser"
+ "${CMAKE_SOURCE_DIR}/contrib/fpconv"
+ "${CMAKE_SOURCE_DIR}/contrib/libottery"
+ "${CMAKE_SOURCE_DIR}/contrib/cdb"
+ "${CMAKE_SOURCE_DIR}/contrib/snowball/include"
+ "${CMAKE_SOURCE_DIR}/contrib/librdns"
+ "${CMAKE_SOURCE_DIR}/contrib/aho-corasick"
+ "${CMAKE_SOURCE_DIR}/contrib/lc-btrie"
+ "${CMAKE_SOURCE_DIR}/contrib/lua-lpeg"
+ "${CMAKE_SOURCE_DIR}/contrib/frozen/include"
+ "${CMAKE_SOURCE_DIR}/contrib/fu2/include"
+ "${CMAKE_BINARY_DIR}/src" #Stored in the binary dir
+ "${CMAKE_BINARY_DIR}/src/libcryptobox")
SET(TAR "tar")
INCLUDE(OSDep)
@@ -132,132 +132,132 @@ INCLUDE(OSDep)
LIST(APPEND RSPAMD_REQUIRED_LIBRARIES "m")
LIST(APPEND RSPAMD_REQUIRED_LIBRARIES "pthread")
-IF(ENABLE_LUAJIT MATCHES "ON")
- ProcessPackage(LIBLUAJIT LIBRARY "luajit"
- "luajit-2.1"
- "luajit2.1"
- "luajit-2.0"
- "luajit2.0"
- "luajit-5.1"
- INCLUDE luajit.h INCLUDE_SUFFIXES
- "include/luajit-2.1"
- "include/luajit-2.0"
- "include/luajit"
- ROOT ${LUA_ROOT}
- MODULES luajit)
- SET(WITH_LUAJIT 1)
-ELSE(ENABLE_LUAJIT MATCHES "ON")
-
- ProcessPackage(LIBLUA LIBRARY "lua"
- "lua-5.3"
- LIB_SUFFIXES "lua5.3"
- INCLUDE lua.h INCLUDE_SUFFIXES
- "include/lua-5.3"
- "include/lua5.3"
- "include/lua53"
- "include/lua"
- ROOT ${LUA_ROOT}
- MODULES lua53
- OPTIONAL)
-
- IF (NOT WITH_LIBLUA)
- ProcessPackage(LIBLUA LIBRARY "lua"
- "lua-5.4"
- LIB_SUFFIXES "lua5.4"
- INCLUDE lua.h INCLUDE_SUFFIXES
- "include/lua-5.4"
- "include/lua5.4"
- "include/lua54"
- "include/lua"
- ROOT ${LUA_ROOT}
- MODULES lua54
- OPTIONAL)
- IF (NOT WITH_LIBLUA)
- ProcessPackage(LIBLUA LIBRARY "lua"
- "lua-5.2"
- LIB_SUFFIXES "lua5.2"
- INCLUDE lua.h INCLUDE_SUFFIXES
- "include/lua-5.2"
- "include/lua5.2"
- "include/lua52"
- "include/lua"
- ROOT ${LUA_ROOT}
- MODULES lua52
- OPTIONAL)
-
- IF (NOT WITH_LIBLUA)
- ProcessPackage(LIBLUA LIBRARY "lua"
- "lua-5.1"
- INCLUDE lua.h INCLUDE_SUFFIXES
- "include/lua-5.1"
- "include/lua5.1"
- "include/lua51"
- "include/lua"
- ROOT ${LUA_ROOT}
- MODULES lua51)
- ENDIF()
- ENDIF()
- ENDIF()
-ENDIF(ENABLE_LUAJIT MATCHES "ON")
-
-IF(ENABLE_JEMALLOC MATCHES "ON" AND NOT SANITIZE)
- ProcessPackage(JEMALLOC LIBRARY jemalloc_pic jemalloc INCLUDE jemalloc.h INCLUDE_SUFFIXES include/jemalloc
- ROOT ${JEMALLOC_ROOT_DIR})
- SET(WITH_JEMALLOC "1")
-ENDIF()
-
-IF(ENABLE_LIBUNWIND MATCHES "ON")
- ProcessPackage(LIBUNWIND LIBRARY unwind INCLUDE libunwind.h INCLUDE_SUFFIXES include/libunwind
- ROOT ${LIBUNWIND_ROOT_DIR} MODULES libunwind)
- SET(WITH_LIBUNWIND "1")
-ENDIF()
+IF (ENABLE_LUAJIT MATCHES "ON")
+ ProcessPackage(LIBLUAJIT LIBRARY "luajit"
+ "luajit-2.1"
+ "luajit2.1"
+ "luajit-2.0"
+ "luajit2.0"
+ "luajit-5.1"
+ INCLUDE luajit.h INCLUDE_SUFFIXES
+ "include/luajit-2.1"
+ "include/luajit-2.0"
+ "include/luajit"
+ ROOT ${LUA_ROOT}
+ MODULES luajit)
+ SET(WITH_LUAJIT 1)
+ELSE (ENABLE_LUAJIT MATCHES "ON")
+
+ ProcessPackage(LIBLUA LIBRARY "lua"
+ "lua-5.3"
+ LIB_SUFFIXES "lua5.3"
+ INCLUDE lua.h INCLUDE_SUFFIXES
+ "include/lua-5.3"
+ "include/lua5.3"
+ "include/lua53"
+ "include/lua"
+ ROOT ${LUA_ROOT}
+ MODULES lua53
+ OPTIONAL)
+
+ IF (NOT WITH_LIBLUA)
+ ProcessPackage(LIBLUA LIBRARY "lua"
+ "lua-5.4"
+ LIB_SUFFIXES "lua5.4"
+ INCLUDE lua.h INCLUDE_SUFFIXES
+ "include/lua-5.4"
+ "include/lua5.4"
+ "include/lua54"
+ "include/lua"
+ ROOT ${LUA_ROOT}
+ MODULES lua54
+ OPTIONAL)
+ IF (NOT WITH_LIBLUA)
+ ProcessPackage(LIBLUA LIBRARY "lua"
+ "lua-5.2"
+ LIB_SUFFIXES "lua5.2"
+ INCLUDE lua.h INCLUDE_SUFFIXES
+ "include/lua-5.2"
+ "include/lua5.2"
+ "include/lua52"
+ "include/lua"
+ ROOT ${LUA_ROOT}
+ MODULES lua52
+ OPTIONAL)
+
+ IF (NOT WITH_LIBLUA)
+ ProcessPackage(LIBLUA LIBRARY "lua"
+ "lua-5.1"
+ INCLUDE lua.h INCLUDE_SUFFIXES
+ "include/lua-5.1"
+ "include/lua5.1"
+ "include/lua51"
+ "include/lua"
+ ROOT ${LUA_ROOT}
+ MODULES lua51)
+ ENDIF ()
+ ENDIF ()
+ ENDIF ()
+ENDIF (ENABLE_LUAJIT MATCHES "ON")
+
+IF (ENABLE_JEMALLOC MATCHES "ON" AND NOT SANITIZE)
+ ProcessPackage(JEMALLOC LIBRARY jemalloc_pic jemalloc INCLUDE jemalloc.h INCLUDE_SUFFIXES include/jemalloc
+ ROOT ${JEMALLOC_ROOT_DIR})
+ SET(WITH_JEMALLOC "1")
+ENDIF ()
+
+IF (ENABLE_LIBUNWIND MATCHES "ON")
+ ProcessPackage(LIBUNWIND LIBRARY unwind INCLUDE libunwind.h INCLUDE_SUFFIXES include/libunwind
+ ROOT ${LIBUNWIND_ROOT_DIR} MODULES libunwind)
+ SET(WITH_LIBUNWIND "1")
+ENDIF ()
ProcessPackage(GLIB2 LIBRARY glib-2.0 INCLUDE glib.h
- INCLUDE_SUFFIXES include/glib include/glib-2.0
- ROOT ${GLIB_ROOT_DIR} MODULES glib-2.0>=2.28)
+ INCLUDE_SUFFIXES include/glib include/glib-2.0
+ ROOT ${GLIB_ROOT_DIR} MODULES glib-2.0>=2.28)
-IF(ENABLE_PCRE2 MATCHES "ON")
- ProcessPackage(PCRE LIBRARY pcre2 pcre2-8 INCLUDE pcre2.h INCLUDE_SUFFIXES include/pcre2
- ROOT ${PCRE_ROOT_DIR} MODULES pcre2 pcre2-8 libpcre2 libpcre2-8)
-ELSE()
- ProcessPackage(PCRE LIBRARY pcre INCLUDE pcre.h INCLUDE_SUFFIXES include/pcre
- ROOT ${PCRE_ROOT_DIR} MODULES pcre libpcre pcre3 libpcre3)
-ENDIF()
+IF (ENABLE_PCRE2 MATCHES "ON")
+ ProcessPackage(PCRE LIBRARY pcre2 pcre2-8 INCLUDE pcre2.h INCLUDE_SUFFIXES include/pcre2
+ ROOT ${PCRE_ROOT_DIR} MODULES pcre2 pcre2-8 libpcre2 libpcre2-8)
+ELSE ()
+ ProcessPackage(PCRE LIBRARY pcre INCLUDE pcre.h INCLUDE_SUFFIXES include/pcre
+ ROOT ${PCRE_ROOT_DIR} MODULES pcre libpcre pcre3 libpcre3)
+ENDIF ()
ProcessPackage(SQLITE3 LIBRARY sqlite3 INCLUDE sqlite3.h INCLUDE_SUFFIXES include/sqlite3 include/sqlite
- ROOT ${SQLITE3_ROOT_DIR} MODULES sqlite3 sqlite)
+ ROOT ${SQLITE3_ROOT_DIR} MODULES sqlite3 sqlite)
ProcessPackage(ICUDATA LIBRARY icudata INCLUDE unicode/ucnv.h
- ROOT ${ICU_ROOT_DIR} MODULES icu-uc)
+ ROOT ${ICU_ROOT_DIR} MODULES icu-uc)
ProcessPackage(ICUC LIBRARY icuuc INCLUDE unicode/ucnv.h
- ROOT ${ICU_ROOT_DIR} MODULES icu-uc)
+ ROOT ${ICU_ROOT_DIR} MODULES icu-uc)
ProcessPackage(ICUIO LIBRARY icuio INCLUDE unicode/ucnv.h
- ROOT ${ICU_ROOT_DIR} MODULES icu-io)
+ ROOT ${ICU_ROOT_DIR} MODULES icu-io)
ProcessPackage(ICUI18N LIBRARY icui18n INCLUDE unicode/ucnv.h
- ROOT ${ICU_ROOT_DIR} MODULES icu-i18n)
+ ROOT ${ICU_ROOT_DIR} MODULES icu-i18n)
ProcessPackage(LIBCRYPT LIBRARY crypto INCLUDE openssl/evp.h
- ROOT ${OPENSSL_ROOT_DIR} MODULES openssl libcrypt)
+ ROOT ${OPENSSL_ROOT_DIR} MODULES openssl libcrypt)
ProcessPackage(LIBSSL LIBRARY ssl INCLUDE openssl/ssl.h
- ROOT ${OPENSSL_ROOT_DIR} MODULES openssl libssl)
+ ROOT ${OPENSSL_ROOT_DIR} MODULES openssl libssl)
ProcessPackage(LIBZ LIBRARY z INCLUDE zlib.h INCLUDE_SUFFIXES include/zlib
- ROOT ${LIBZ_ROOT_DIR} MODULES z)
+ ROOT ${LIBZ_ROOT_DIR} MODULES z)
ProcessPackage(SODIUM LIBRARY sodium INCLUDE sodium.h
- INCLUDE_SUFFIXES include/libsodium include/sodium
- ROOT ${LIBSODIUM_ROOT_DIR} MODULES libsodium>=1.0.0)
+ INCLUDE_SUFFIXES include/libsodium include/sodium
+ ROOT ${LIBSODIUM_ROOT_DIR} MODULES libsodium>=1.0.0)
-if(ENABLE_FASTTEXT MATCHES "ON")
- ProcessPackage(FASTTEXT LIBRARY fasttext INCLUDE fasttext.h
- INCLUDE_SUFFIXES include/fasttext
- ROOT ${FASTTEXT_ROOT_DIR} MODULES fasttext)
- SET(WITH_FASTTEXT "1")
-endif()
+if (ENABLE_FASTTEXT MATCHES "ON")
+ ProcessPackage(FASTTEXT LIBRARY fasttext INCLUDE fasttext.h
+ INCLUDE_SUFFIXES include/fasttext
+ ROOT ${FASTTEXT_ROOT_DIR} MODULES fasttext)
+ SET(WITH_FASTTEXT "1")
+endif ()
-include (CompilerWarnings)
-include (Hyperscan)
-include (Openblas)
+include(CompilerWarnings)
+include(Hyperscan)
+include(Openblas)
-IF(ENABLE_LUA_TRACE)
- SET(WITH_LUA_TRACE 1)
-ENDIF(ENABLE_LUA_TRACE)
+IF (ENABLE_LUA_TRACE)
+ SET(WITH_LUA_TRACE 1)
+ENDIF (ENABLE_LUA_TRACE)
SET(CMAKE_C_FLAGS "${CMAKE_C_OPT_FLAGS} ${CMAKE_C_FLAGS}")
SET(CMAKE_CXX_FLAGS "${CMAKE_C_OPT_FLAGS} ${CMAKE_CXX_FLAGS}")
@@ -271,34 +271,34 @@ ADD_DEFINITIONS(-DU_CHARSET_IS_UTF8)
# Check platform specific includes
CHECK_INCLUDE_FILES(sys/types.h HAVE_SYS_TYPES_H)
-CHECK_INCLUDE_FILES(sys/uio.h HAVE_SYS_UIO_H)
-
-CHECK_INCLUDE_FILES(fcntl.h HAVE_FCNTL_H)
-CHECK_INCLUDE_FILES(math.h HAVE_MATH_H)
-CHECK_INCLUDE_FILES(stdio.h HAVE_STDIO_H)
-CHECK_INCLUDE_FILES(stdlib.h HAVE_STDLIB_H)
-CHECK_INCLUDE_FILES(string.h HAVE_STRING_H)
-CHECK_INCLUDE_FILES(strings.h HAVE_STRINGS_H)
-CHECK_INCLUDE_FILES(time.h HAVE_TIME_H)
-CHECK_INCLUDE_FILES(unistd.h HAVE_UNISTD_H)
-CHECK_INCLUDE_FILES(stdint.h HAVE_STDINT_H)
-CHECK_INCLUDE_FILES(inttypes.h HAVE_INTTYPES_H)
-CHECK_INCLUDE_FILES(stdbool.h HAVE_STDBOOL_H)
-CHECK_INCLUDE_FILES(endian.h HAVE_ENDIAN_H)
-CHECK_INCLUDE_FILES(sys/endian.h HAVE_SYS_ENDIAN_H)
-CHECK_INCLUDE_FILES(machine/endian.h HAVE_MACHINE_ENDIAN_H)
-CHECK_INCLUDE_FILES(sys/socket.h HAVE_SYS_SOCKET_H)
-CHECK_INCLUDE_FILES(sys/mman.h HAVE_SYS_MMAN_H)
-CHECK_INCLUDE_FILES(sys/un.h HAVE_SYS_UN_H)
-CHECK_INCLUDE_FILES(sys/stat.h HAVE_SYS_STAT_H)
-CHECK_INCLUDE_FILES(sys/wait.h HAVE_SYS_WAIT_H)
-CHECK_INCLUDE_FILES(sys/param.h HAVE_SYS_PARAM_H)
-CHECK_INCLUDE_FILES(sys/file.h HAVE_SYS_FILE_H)
-CHECK_INCLUDE_FILES(sys/resource.h HAVE_SYS_RESOURCE_H)
-CHECK_INCLUDE_FILES(netinet/in.h HAVE_NETINET_IN_H)
-CHECK_INCLUDE_FILES(netinet/tcp.h HAVE_NETINET_TCP_H)
-CHECK_INCLUDE_FILES(arpa/inet.h HAVE_ARPA_INET_H)
-CHECK_INCLUDE_FILES(netdb.h HAVE_NETDB_H)
+CHECK_INCLUDE_FILES(sys/uio.h HAVE_SYS_UIO_H)
+
+CHECK_INCLUDE_FILES(fcntl.h HAVE_FCNTL_H)
+CHECK_INCLUDE_FILES(math.h HAVE_MATH_H)
+CHECK_INCLUDE_FILES(stdio.h HAVE_STDIO_H)
+CHECK_INCLUDE_FILES(stdlib.h HAVE_STDLIB_H)
+CHECK_INCLUDE_FILES(string.h HAVE_STRING_H)
+CHECK_INCLUDE_FILES(strings.h HAVE_STRINGS_H)
+CHECK_INCLUDE_FILES(time.h HAVE_TIME_H)
+CHECK_INCLUDE_FILES(unistd.h HAVE_UNISTD_H)
+CHECK_INCLUDE_FILES(stdint.h HAVE_STDINT_H)
+CHECK_INCLUDE_FILES(inttypes.h HAVE_INTTYPES_H)
+CHECK_INCLUDE_FILES(stdbool.h HAVE_STDBOOL_H)
+CHECK_INCLUDE_FILES(endian.h HAVE_ENDIAN_H)
+CHECK_INCLUDE_FILES(sys/endian.h HAVE_SYS_ENDIAN_H)
+CHECK_INCLUDE_FILES(machine/endian.h HAVE_MACHINE_ENDIAN_H)
+CHECK_INCLUDE_FILES(sys/socket.h HAVE_SYS_SOCKET_H)
+CHECK_INCLUDE_FILES(sys/mman.h HAVE_SYS_MMAN_H)
+CHECK_INCLUDE_FILES(sys/un.h HAVE_SYS_UN_H)
+CHECK_INCLUDE_FILES(sys/stat.h HAVE_SYS_STAT_H)
+CHECK_INCLUDE_FILES(sys/wait.h HAVE_SYS_WAIT_H)
+CHECK_INCLUDE_FILES(sys/param.h HAVE_SYS_PARAM_H)
+CHECK_INCLUDE_FILES(sys/file.h HAVE_SYS_FILE_H)
+CHECK_INCLUDE_FILES(sys/resource.h HAVE_SYS_RESOURCE_H)
+CHECK_INCLUDE_FILES(netinet/in.h HAVE_NETINET_IN_H)
+CHECK_INCLUDE_FILES(netinet/tcp.h HAVE_NETINET_TCP_H)
+CHECK_INCLUDE_FILES(arpa/inet.h HAVE_ARPA_INET_H)
+CHECK_INCLUDE_FILES(netdb.h HAVE_NETDB_H)
CHECK_INCLUDE_FILES(syslog.h HAVE_SYSLOG_H)
CHECK_INCLUDE_FILES(siginfo.h HAVE_SIGINFO_H)
CHECK_INCLUDE_FILES(locale.h HAVE_LOCALE_H)
@@ -339,25 +339,25 @@ CHECK_SYMBOL_EXISTS(getaddrinfo "sys/types.h;sys/socket.h;netdb.h" HAVE_GETADDRI
CHECK_SYMBOL_EXISTS(sched_yield "sched.h" HAVE_SCHED_YIELD)
CHECK_SYMBOL_EXISTS(nftw "sys/types.h;ftw.h" HAVE_NFTW)
CHECK_SYMBOL_EXISTS(memrchr "string.h" HAVE_MEMRCHR)
-IF(ENABLE_PCRE2 MATCHES "ON")
- LIST(APPEND CMAKE_REQUIRED_INCLUDES "${PCRE_INCLUDE}")
- CHECK_SYMBOL_EXISTS(PCRE2_CONFIG_JIT "pcre2.h" HAVE_PCRE_JIT)
-ELSE()
- LIST(APPEND CMAKE_REQUIRED_INCLUDES "${PCRE_INCLUDE}")
- CHECK_SYMBOL_EXISTS(PCRE_CONFIG_JIT "pcre.h" HAVE_PCRE_JIT)
-ENDIF()
+IF (ENABLE_PCRE2 MATCHES "ON")
+ LIST(APPEND CMAKE_REQUIRED_INCLUDES "${PCRE_INCLUDE}")
+ CHECK_SYMBOL_EXISTS(PCRE2_CONFIG_JIT "pcre2.h" HAVE_PCRE_JIT)
+ELSE ()
+ LIST(APPEND CMAKE_REQUIRED_INCLUDES "${PCRE_INCLUDE}")
+ CHECK_SYMBOL_EXISTS(PCRE_CONFIG_JIT "pcre.h" HAVE_PCRE_JIT)
+ENDIF ()
CHECK_SYMBOL_EXISTS(SOCK_SEQPACKET "sys/types.h;sys/socket.h" HAVE_SOCK_SEQPACKET)
CHECK_SYMBOL_EXISTS(O_NOFOLLOW "sys/types.h;sys/fcntl.h" HAVE_ONOFOLLOW)
CHECK_SYMBOL_EXISTS(O_CLOEXEC "sys/types.h;sys/fcntl.h" HAVE_OCLOEXEC)
# OpenSSL specific stuff
LIST(APPEND CMAKE_REQUIRED_INCLUDES "${LIBSSL_INCLUDE}")
-IF(LIBCRYPT_LIBRARY_PATH)
- SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-L${LIBCRYPT_LIBRARY_PATH};${LIBCRYPT_LIBRARY}")
- SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-L${LIBSSL_LIBRARY_PATH};${LIBSSL_LIBRARY}")
-ELSE()
- SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-lcrypt;-lssl")
-ENDIF()
+IF (LIBCRYPT_LIBRARY_PATH)
+ SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-L${LIBCRYPT_LIBRARY_PATH};${LIBCRYPT_LIBRARY}")
+ SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-L${LIBSSL_LIBRARY_PATH};${LIBSSL_LIBRARY}")
+ELSE ()
+ SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-lcrypt;-lssl")
+ENDIF ()
CHECK_SYMBOL_EXISTS(SSL_set_tlsext_host_name "openssl/ssl.h" HAVE_SSL_TLSEXT_HOSTNAME)
CHECK_SYMBOL_EXISTS(FIPS_mode "openssl/crypto.h" HAVE_FIPS_MODE)
@@ -371,19 +371,19 @@ CHECK_SYMBOL_EXISTS(clock_getcpuclockid "sys/types.h;time.h" HAVE_CLOCK_GETCPUCL
CHECK_SYMBOL_EXISTS(RUSAGE_SELF "sys/types.h;sys/resource.h" HAVE_RUSAGE_SELF)
CHECK_SYMBOL_EXISTS(ffsll "strings.h" HAVE_FFSLL)
-IF(ENABLE_PCRE2 MATCHES "ON")
- IF(HAVE_PCRE_JIT)
- SET(HAVE_PCRE_JIT_FAST 1)
- ENDIF()
-ELSE()
- LIST(APPEND CMAKE_REQUIRED_INCLUDES "${PCRE_INCLUDE}")
- IF(PCRE_LIBRARY_PATH)
- SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-L${PCRE_LIBRARY_PATH};${PCRE_LIBRARY}")
- ELSE(PCRE_LIBRARY_PATH)
- SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-lpcre")
- ENDIF(PCRE_LIBRARY_PATH)
-# Some PCRE implementations are lacking of pcre_jit_exec fast path
-SET(_PCRE_FAST_TEST "
+IF (ENABLE_PCRE2 MATCHES "ON")
+ IF (HAVE_PCRE_JIT)
+ SET(HAVE_PCRE_JIT_FAST 1)
+ ENDIF ()
+ELSE ()
+ LIST(APPEND CMAKE_REQUIRED_INCLUDES "${PCRE_INCLUDE}")
+ IF (PCRE_LIBRARY_PATH)
+ SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-L${PCRE_LIBRARY_PATH};${PCRE_LIBRARY}")
+ ELSE (PCRE_LIBRARY_PATH)
+ SET(CMAKE_REQUIRED_LIBRARIES "${CMAKE_REQUIRED_LIBRARIES};-lpcre")
+ ENDIF (PCRE_LIBRARY_PATH)
+ # Some PCRE implementations are lacking of pcre_jit_exec fast path
+ SET(_PCRE_FAST_TEST "
#include \"pcre.h\"
int main (void)
{
@@ -402,18 +402,18 @@ int main (void)
return rc;
}
")
-CHECK_C_SOURCE_COMPILES("${_PCRE_FAST_TEST}" HAVE_PCRE_JIT_FAST)
-IF(HAVE_PCRE_JIT_FAST)
- MESSAGE(STATUS "pcre_jit_exec is supported")
-ELSE(HAVE_PCRE_JIT_FAST)
- MESSAGE(STATUS "pcre_jit_exec is -NOT- supported")
-ENDIF(HAVE_PCRE_JIT_FAST)
-ENDIF()
+ CHECK_C_SOURCE_COMPILES("${_PCRE_FAST_TEST}" HAVE_PCRE_JIT_FAST)
+ IF (HAVE_PCRE_JIT_FAST)
+ MESSAGE(STATUS "pcre_jit_exec is supported")
+ ELSE (HAVE_PCRE_JIT_FAST)
+ MESSAGE(STATUS "pcre_jit_exec is -NOT- supported")
+ ENDIF (HAVE_PCRE_JIT_FAST)
+ENDIF ()
CHECK_C_COMPILER_FLAG(-fPIC SUPPORT_FPIC)
-IF(SUPPORT_FPIC)
- ADD_COMPILE_OPTIONS("-fPIC")
-ENDIF(SUPPORT_FPIC)
+IF (SUPPORT_FPIC)
+ ADD_COMPILE_OPTIONS("-fPIC")
+ENDIF (SUPPORT_FPIC)
FILE(WRITE ${CMAKE_BINARY_DIR}/pthread_setpshared.c "
#include <pthread.h>
@@ -428,34 +428,34 @@ int main (void)
}
")
TRY_RUN(_CAN_RUN _CAN_COMPILE
- "${CMAKE_BINARY_DIR}" "${CMAKE_BINARY_DIR}/pthread_setpshared.c"
- CMAKE_FLAGS CMAKE_C_FLAGS="-pthread")
-IF(_CAN_RUN EQUAL 1)
- SET(HAVE_PTHREAD_PROCESS_SHARED 1 CACHE INTERNAL "")
-ENDIF(_CAN_RUN EQUAL 1)
-IF(HAVE_PTHREAD_PROCESS_SHARED)
- MESSAGE(STATUS "pthread_mutexattr_setpshared is supported")
-ELSE(HAVE_PTHREAD_PROCESS_SHARED)
- MESSAGE(STATUS "pthread_mutexattr_setpshared is -NOT- supported")
-ENDIF(HAVE_PTHREAD_PROCESS_SHARED)
-
-IF(NOT HAVE_GETADDRINFO)
- MESSAGE(FATAL_ERROR "Your system does not support getaddrinfo call, please consider upgrading it to run rspamd")
-ENDIF(NOT HAVE_GETADDRINFO)
-IF(HAVE_SIGINFO_H)
- CHECK_SYMBOL_EXISTS(SA_SIGINFO "signal.h;siginfo.h" HAVE_SA_SIGINFO)
-ELSE(HAVE_SIGINFO_H)
- CHECK_SYMBOL_EXISTS(SA_SIGINFO "signal.h" HAVE_SA_SIGINFO)
-ENDIF(HAVE_SIGINFO_H)
-
-IF(NOT CMAKE_SYSTEM_NAME STREQUAL "SunOS")
-IF(HAVE_CLOCK_GETTIME)
- CHECK_SYMBOL_EXISTS(CLOCK_PROCESS_CPUTIME_ID time.h HAVE_CLOCK_PROCESS_CPUTIME_ID)
- CHECK_SYMBOL_EXISTS(CLOCK_VIRTUAL time.h HAVE_CLOCK_VIRTUAL)
-ELSE(HAVE_CLOCK_GETTIME)
- CHECK_INCLUDE_FILES(sys/timeb.h HAVE_SYS_TIMEB_H)
-ENDIF(HAVE_CLOCK_GETTIME)
-ENDIF(NOT CMAKE_SYSTEM_NAME STREQUAL "SunOS")
+ "${CMAKE_BINARY_DIR}" "${CMAKE_BINARY_DIR}/pthread_setpshared.c"
+ CMAKE_FLAGS CMAKE_C_FLAGS="-pthread")
+IF (_CAN_RUN EQUAL 1)
+ SET(HAVE_PTHREAD_PROCESS_SHARED 1 CACHE INTERNAL "")
+ENDIF (_CAN_RUN EQUAL 1)
+IF (HAVE_PTHREAD_PROCESS_SHARED)
+ MESSAGE(STATUS "pthread_mutexattr_setpshared is supported")
+ELSE (HAVE_PTHREAD_PROCESS_SHARED)
+ MESSAGE(STATUS "pthread_mutexattr_setpshared is -NOT- supported")
+ENDIF (HAVE_PTHREAD_PROCESS_SHARED)
+
+IF (NOT HAVE_GETADDRINFO)
+ MESSAGE(FATAL_ERROR "Your system does not support getaddrinfo call, please consider upgrading it to run rspamd")
+ENDIF (NOT HAVE_GETADDRINFO)
+IF (HAVE_SIGINFO_H)
+ CHECK_SYMBOL_EXISTS(SA_SIGINFO "signal.h;siginfo.h" HAVE_SA_SIGINFO)
+ELSE (HAVE_SIGINFO_H)
+ CHECK_SYMBOL_EXISTS(SA_SIGINFO "signal.h" HAVE_SA_SIGINFO)
+ENDIF (HAVE_SIGINFO_H)
+
+IF (NOT CMAKE_SYSTEM_NAME STREQUAL "SunOS")
+ IF (HAVE_CLOCK_GETTIME)
+ CHECK_SYMBOL_EXISTS(CLOCK_PROCESS_CPUTIME_ID time.h HAVE_CLOCK_PROCESS_CPUTIME_ID)
+ CHECK_SYMBOL_EXISTS(CLOCK_VIRTUAL time.h HAVE_CLOCK_VIRTUAL)
+ ELSE (HAVE_CLOCK_GETTIME)
+ CHECK_INCLUDE_FILES(sys/timeb.h HAVE_SYS_TIMEB_H)
+ ENDIF (HAVE_CLOCK_GETTIME)
+ENDIF (NOT CMAKE_SYSTEM_NAME STREQUAL "SunOS")
CHECK_C_SOURCE_RUNS("
#include <stdbool.h>
@@ -468,11 +468,17 @@ int main(int argc, char **argv) {
}
" HAVE_ATOMIC_BUILTINS)
-IF(NOT HAVE_ATOMIC_BUILTINS)
- MESSAGE(STATUS "atomic builtins are -NOT- supported")
-ELSE()
- MESSAGE(STATUS "atomic builtins are supported")
-ENDIF()
+IF (NOT HAVE_ATOMIC_BUILTINS)
+ MESSAGE(STATUS "atomic builtins are -NOT- supported")
+ELSE ()
+ MESSAGE(STATUS "atomic builtins are supported")
+ENDIF ()
+
+CHECK_LIBRARY_EXISTS(atomic __atomic_fetch_add_4 "" HAVE_LIBATOMIC)
+IF (HAVE_LIBATOMIC)
+ list(APPEND CMAKE_REQUIRED_LIBRARIES "atomic")
+endif ()
+
CHECK_C_SOURCE_RUNS("
#include <x86intrin.h>
@@ -485,29 +491,29 @@ int main(int argc, char **argv) {
}
" HAVE_RDTSC)
-IF(NOT HAVE_RDTSC)
- MESSAGE(STATUS "rdtsc intrinsic is -NOT- supported")
-ELSE()
- MESSAGE(STATUS "rdtsc intrinsic is supported")
-ENDIF()
-
-IF(CMAKE_SYSTEM_NAME STREQUAL "Linux")
- # In linux, we need to mount /run/shm to test which could be unavailable
- # on a build system. On the other hand, we know that linux has stupid
- # but compatible shmem support, so we assume this macro as true
- SET(HAVE_SANE_SHMEM 1)
- CHECK_C_SOURCE_COMPILES ("#define _GNU_SOURCE
+IF (NOT HAVE_RDTSC)
+ MESSAGE(STATUS "rdtsc intrinsic is -NOT- supported")
+ELSE ()
+ MESSAGE(STATUS "rdtsc intrinsic is supported")
+ENDIF ()
+
+IF (CMAKE_SYSTEM_NAME STREQUAL "Linux")
+ # In linux, we need to mount /run/shm to test which could be unavailable
+ # on a build system. On the other hand, we know that linux has stupid
+ # but compatible shmem support, so we assume this macro as true
+ SET(HAVE_SANE_SHMEM 1)
+ CHECK_C_SOURCE_COMPILES("#define _GNU_SOURCE
#include <sys/socket.h>
int main (int argc, char **argv) {
return ((int*)(&recvmmsg))[argc];
}" HAVE_RECVMMSG)
- CHECK_C_SOURCE_COMPILES ("#define _GNU_SOURCE
+ CHECK_C_SOURCE_COMPILES("#define _GNU_SOURCE
*** OUTPUT TRUNCATED, 359 LINES SKIPPED ***
More information about the Commits
mailing list