forked from ECP-VeloC/VELOC
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
78 lines (65 loc) · 2.33 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
cmake_minimum_required (VERSION 3.10)
project (VELOC)
##### Global settings
include(GNUInstallDirs)
list(APPEND CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/cmake")
add_definitions(-O2 -g -Wall -D__BENCHMARK -D__ASSERT -D__INFO)
set(CMAKE_CXX_STANDARD 17)
##### Configuration setting
set(VELOC_RESOURCE_MANAGER "LSF" CACHE STRING "Resource Manager for CLI (SLURM LSF ALPS NONE)")
set_property(CACHE VELOC_RESOURCE_MANAGER PROPERTY STRINGS SLURM LSF ALPS NONE)
set(COMM_QUEUE "ipc_queue" CACHE STRING "Communication protocol between client library and active backend")
set_property(CACHE COMM_QUEUE PROPERTY STRINGS ipc_queue socket_queue thallium_queue)
set(POSIX_IO "posix_io" CACHE STRING "POSIX transfer method between scratch and persistent")
set_property(CACHE POSIX_IO PROPERTY STRINGS direct rw)
##### Set preprocessor definitions
if (${POSIX_IO} STREQUAL "direct")
add_definitions(-DWITH_POSIX_DIRECT)
else()
add_definitions(-DWITH_POSIX_RW)
endif()
##### Find dependencies
# PThreads
find_package(Threads REQUIRED)
set(COMM_QUEUE_LIBRARIES ${CMAKE_THREAD_LIBS_INIT})
# Communication protocol
if (${COMM_QUEUE} STREQUAL "ipc_queue")
# Boost is required for ipc_queue
set(Boost_FIND_REQUIRED True)
find_package(Boost 1.40)
include_directories(${Boost_INCLUDE_DIR})
list(APPEND COMM_QUEUE_LIBRARIES "rt")
elseif (${COMM_QUEUE} STREQUAL "thallium_queue")
# Thallium is required for thallium_queue
find_package(thallium REQUIRED)
list(APPEND COMM_QUEUE_LIBRARIES "thallium")
endif ()
configure_file(${PROJECT_SOURCE_DIR}/src/common/comm_queue.in
${PROJECT_SOURCE_DIR}/src/common/comm_queue.hpp
@ONLY)
# OpenSSL
find_package(OpenSSL REQUIRED)
# MPI
find_package(MPI REQUIRED)
include_directories(${MPI_INCLUDE_PATH})
# ER
find_package(ER REQUIRED)
include_directories(${ER_INCLUDE_DIRS})
# AXL
find_package(AXL)
if(AXL_FOUND)
include_directories(${AXL_INCLUDE_DIRS})
add_definitions(-DWITH_AXL)
endif()
# DAOS
find_package(DAOS)
if(DAOS_FOUND)
include_directories(${DAOS_INCLUDE_DIRS})
add_definitions(-DWITH_DAOS)
endif()
# -----------------------------------------------------------------------------------
include_directories(${VELOC_SOURCE_DIR})
add_subdirectory (src)
# -----------------------------------------------------------------------------------
enable_testing()
add_subdirectory (test)