2020-03-16 13:50:30 +00:00
|
|
|
option (ENABLE_JEMALLOC "Enable jemalloc allocator" ${ENABLE_LIBRARIES})
|
|
|
|
|
2020-06-22 18:00:50 +00:00
|
|
|
if (SANITIZE OR NOT (ARCH_AMD64 OR ARCH_ARM))
|
2020-03-17 11:22:15 +00:00
|
|
|
set (ENABLE_JEMALLOC OFF)
|
2020-06-22 18:00:50 +00:00
|
|
|
message (STATUS "jemalloc is disabled implicitly: it doesn't work with sanitizers and can only be used with x86_64 or aarch64.")
|
2019-05-31 08:55:01 +00:00
|
|
|
endif ()
|
|
|
|
|
2020-03-16 13:50:30 +00:00
|
|
|
if (ENABLE_JEMALLOC)
|
2020-06-22 18:00:50 +00:00
|
|
|
if (NOT OS_LINUX)
|
|
|
|
message (WARNING "jemalloc support on non-linux is EXPERIMENTAL")
|
|
|
|
endif()
|
|
|
|
|
2020-03-16 13:50:30 +00:00
|
|
|
option (USE_INTERNAL_JEMALLOC "Use internal jemalloc library" ${NOT_UNBUNDLED})
|
2018-08-02 00:20:20 +00:00
|
|
|
|
2020-03-16 13:50:30 +00:00
|
|
|
if (USE_INTERNAL_JEMALLOC)
|
2020-05-22 13:08:08 +00:00
|
|
|
# ThreadPool select job randomly, and there can be some threads that had been
|
|
|
|
# performed some memory heavy task before and will be inactive for some time,
|
|
|
|
# but until it will became active again, the memory will not be freed since by
|
|
|
|
# default each thread has it's own arena, but there should be not more then
|
|
|
|
# 4*CPU arenas (see opt.nareans description).
|
|
|
|
#
|
|
|
|
# By enabling percpu_arena number of arenas limited to number of CPUs and hence
|
|
|
|
# this problem should go away.
|
2020-05-26 18:51:06 +00:00
|
|
|
set (JEMALLOC_CONFIG_MALLOC_CONF "percpu_arena:percpu,oversize_threshold:0")
|
|
|
|
# CACHE variable is empty, to allow changing defaults without necessity
|
|
|
|
# to purge cache
|
|
|
|
set (JEMALLOC_CONFIG_MALLOC_CONF_OVERRIDE "" CACHE STRING "Change default configuration string of JEMalloc" )
|
|
|
|
if (JEMALLOC_CONFIG_MALLOC_CONF_OVERRIDE)
|
|
|
|
set (JEMALLOC_CONFIG_MALLOC_CONF "${JEMALLOC_CONFIG_MALLOC_CONF_OVERRIDE}")
|
|
|
|
endif()
|
2020-05-21 07:35:37 +00:00
|
|
|
message (STATUS "jemalloc malloc_conf: ${JEMALLOC_CONFIG_MALLOC_CONF}")
|
|
|
|
|
2020-03-16 13:50:30 +00:00
|
|
|
set (LIBRARY_DIR "${ClickHouse_SOURCE_DIR}/contrib/jemalloc")
|
|
|
|
|
|
|
|
set (SRCS
|
|
|
|
${LIBRARY_DIR}/src/arena.c
|
|
|
|
${LIBRARY_DIR}/src/background_thread.c
|
|
|
|
${LIBRARY_DIR}/src/base.c
|
|
|
|
${LIBRARY_DIR}/src/bin.c
|
|
|
|
${LIBRARY_DIR}/src/bitmap.c
|
|
|
|
${LIBRARY_DIR}/src/ckh.c
|
|
|
|
${LIBRARY_DIR}/src/ctl.c
|
|
|
|
${LIBRARY_DIR}/src/div.c
|
|
|
|
${LIBRARY_DIR}/src/extent.c
|
|
|
|
${LIBRARY_DIR}/src/extent_dss.c
|
|
|
|
${LIBRARY_DIR}/src/extent_mmap.c
|
|
|
|
${LIBRARY_DIR}/src/hash.c
|
|
|
|
${LIBRARY_DIR}/src/hook.c
|
|
|
|
${LIBRARY_DIR}/src/jemalloc.c
|
|
|
|
${LIBRARY_DIR}/src/large.c
|
|
|
|
${LIBRARY_DIR}/src/log.c
|
|
|
|
${LIBRARY_DIR}/src/malloc_io.c
|
|
|
|
${LIBRARY_DIR}/src/mutex.c
|
|
|
|
${LIBRARY_DIR}/src/mutex_pool.c
|
|
|
|
${LIBRARY_DIR}/src/nstime.c
|
|
|
|
${LIBRARY_DIR}/src/pages.c
|
|
|
|
${LIBRARY_DIR}/src/prng.c
|
|
|
|
${LIBRARY_DIR}/src/prof.c
|
|
|
|
${LIBRARY_DIR}/src/rtree.c
|
|
|
|
${LIBRARY_DIR}/src/sc.c
|
|
|
|
${LIBRARY_DIR}/src/stats.c
|
|
|
|
${LIBRARY_DIR}/src/sz.c
|
|
|
|
${LIBRARY_DIR}/src/tcache.c
|
|
|
|
${LIBRARY_DIR}/src/test_hooks.c
|
|
|
|
${LIBRARY_DIR}/src/ticker.c
|
|
|
|
${LIBRARY_DIR}/src/tsd.c
|
|
|
|
${LIBRARY_DIR}/src/witness.c
|
2020-05-24 09:55:21 +00:00
|
|
|
${LIBRARY_DIR}/src/safety_check.c
|
2020-03-16 13:50:30 +00:00
|
|
|
)
|
|
|
|
if (OS_DARWIN)
|
|
|
|
list(APPEND SRCS ${LIBRARY_DIR}/src/zone.c)
|
|
|
|
endif ()
|
|
|
|
|
2020-03-21 19:49:26 +00:00
|
|
|
add_library(jemalloc ${SRCS})
|
2020-03-16 13:50:30 +00:00
|
|
|
target_include_directories(jemalloc PRIVATE ${LIBRARY_DIR}/include)
|
2020-05-09 23:05:35 +00:00
|
|
|
target_include_directories(jemalloc SYSTEM PUBLIC include)
|
2020-05-21 07:35:37 +00:00
|
|
|
|
2020-06-22 18:00:50 +00:00
|
|
|
set (JEMALLOC_INCLUDE_PREFIX)
|
|
|
|
# OS_
|
|
|
|
if (OS_LINUX)
|
|
|
|
set (JEMALLOC_INCLUDE_PREFIX "include_linux")
|
|
|
|
elseif (OS_FREEBSD)
|
|
|
|
set (JEMALLOC_INCLUDE_PREFIX "include_freebsd")
|
|
|
|
elseif (OS_DARWIN)
|
|
|
|
set (JEMALLOC_INCLUDE_PREFIX "include_darwin")
|
|
|
|
else ()
|
|
|
|
message (FATAL_ERROR "This OS is not supported")
|
|
|
|
endif ()
|
|
|
|
# ARCH_
|
2020-03-16 13:50:30 +00:00
|
|
|
if (ARCH_AMD64)
|
2020-06-22 18:00:50 +00:00
|
|
|
set(JEMALLOC_INCLUDE_PREFIX "${JEMALLOC_INCLUDE_PREFIX}_x86_64")
|
2020-03-16 13:50:30 +00:00
|
|
|
elseif (ARCH_ARM)
|
2020-06-22 18:00:50 +00:00
|
|
|
set(JEMALLOC_INCLUDE_PREFIX "${JEMALLOC_INCLUDE_PREFIX}_aarch64")
|
|
|
|
else ()
|
|
|
|
message (FATAL_ERROR "This arch is not supported")
|
2020-03-16 13:50:30 +00:00
|
|
|
endif ()
|
2020-06-22 18:00:50 +00:00
|
|
|
|
2020-05-21 07:35:37 +00:00
|
|
|
configure_file(${JEMALLOC_INCLUDE_PREFIX}/jemalloc/internal/jemalloc_internal_defs.h.in
|
|
|
|
${JEMALLOC_INCLUDE_PREFIX}/jemalloc/internal/jemalloc_internal_defs.h)
|
|
|
|
target_include_directories(jemalloc SYSTEM PRIVATE
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/${JEMALLOC_INCLUDE_PREFIX}/jemalloc/internal)
|
2020-03-16 13:50:30 +00:00
|
|
|
|
|
|
|
target_compile_definitions(jemalloc PRIVATE -DJEMALLOC_NO_PRIVATE_NAMESPACE)
|
2018-08-02 00:20:20 +00:00
|
|
|
|
2020-03-16 13:50:30 +00:00
|
|
|
if (CMAKE_BUILD_TYPE_UC STREQUAL "DEBUG")
|
|
|
|
target_compile_definitions(jemalloc PRIVATE -DJEMALLOC_DEBUG=1 -DJEMALLOC_PROF=1)
|
2018-08-02 00:20:20 +00:00
|
|
|
|
2020-03-16 13:50:30 +00:00
|
|
|
if (USE_UNWIND)
|
|
|
|
target_compile_definitions (jemalloc PRIVATE -DJEMALLOC_PROF_LIBUNWIND=1)
|
|
|
|
target_link_libraries (jemalloc PRIVATE unwind)
|
|
|
|
endif ()
|
|
|
|
endif ()
|
2020-03-17 11:22:15 +00:00
|
|
|
|
2020-05-09 20:30:28 +00:00
|
|
|
target_compile_options(jemalloc PRIVATE -Wno-redundant-decls)
|
2020-05-24 10:12:00 +00:00
|
|
|
# for RTLD_NEXT
|
|
|
|
target_compile_options(jemalloc PRIVATE -D_GNU_SOURCE)
|
2020-03-16 13:50:30 +00:00
|
|
|
else ()
|
|
|
|
find_library(LIBRARY_JEMALLOC jemalloc)
|
|
|
|
find_path(INCLUDE_JEMALLOC jemalloc/jemalloc.h)
|
2018-08-29 15:54:00 +00:00
|
|
|
|
2020-03-31 18:58:00 +00:00
|
|
|
set(THREADS_PREFER_PTHREAD_FLAG ON)
|
|
|
|
find_package(Threads REQUIRED)
|
|
|
|
|
2020-03-16 13:50:30 +00:00
|
|
|
add_library (jemalloc STATIC IMPORTED)
|
|
|
|
set_property (TARGET jemalloc PROPERTY IMPORTED_LOCATION ${LIBRARY_JEMALLOC})
|
2020-03-21 21:53:35 +00:00
|
|
|
set_property (TARGET jemalloc PROPERTY INTERFACE_INCLUDE_DIRECTORIES ${INCLUDE_JEMALLOC})
|
2020-03-31 18:58:00 +00:00
|
|
|
set_property (TARGET jemalloc PROPERTY INTERFACE_LINK_LIBRARIES Threads::Threads dl)
|
2018-11-28 16:27:39 +00:00
|
|
|
|
2020-03-31 18:58:00 +00:00
|
|
|
set (CMAKE_REQUIRED_LIBRARIES jemalloc)
|
2020-03-16 13:50:30 +00:00
|
|
|
check_cxx_source_compiles (
|
|
|
|
"
|
|
|
|
#include <jemalloc/jemalloc.h>
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
free(mallocx(1, 0));
|
|
|
|
}
|
|
|
|
"
|
|
|
|
EXTERNAL_JEMALLOC_WORKS
|
|
|
|
)
|
|
|
|
|
|
|
|
if (NOT EXTERNAL_JEMALLOC_WORKS)
|
|
|
|
message (FATAL_ERROR "jemalloc is unusable: ${LIBRARY_JEMALLOC} ${INCLUDE_JEMALLOC}")
|
|
|
|
endif ()
|
2018-11-28 16:27:39 +00:00
|
|
|
endif ()
|
2020-03-16 13:50:30 +00:00
|
|
|
|
2020-03-30 12:06:30 +00:00
|
|
|
set_property(TARGET jemalloc APPEND PROPERTY INTERFACE_COMPILE_DEFINITIONS USE_JEMALLOC=1)
|
2020-03-16 13:50:30 +00:00
|
|
|
|
|
|
|
message (STATUS "Using jemalloc")
|
|
|
|
else ()
|
|
|
|
add_library(jemalloc INTERFACE)
|
|
|
|
target_compile_definitions(jemalloc INTERFACE USE_JEMALLOC=0)
|
|
|
|
|
|
|
|
message (STATUS "Not using jemalloc")
|
2018-08-29 15:54:00 +00:00
|
|
|
endif ()
|