forked from taskflow/taskflow
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
185 lines (151 loc) · 6.9 KB
/
CMakeLists.txt
File metadata and controls
185 lines (151 loc) · 6.9 KB
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
# CMake version
cmake_minimum_required (VERSION 3.9)
MESSAGE(STATUS "CMAKE_ROOT: " ${CMAKE_ROOT})
# Project name
project(Cpp-TaskFlow)
# Enable memory test
include(CTest)
# Turn on the verbose
set(CMAKE_VERBOSE_MAKEFILE ON)
# Compiler vendors
## g++
if (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
if(CMAKE_CXX_COMPILER_VERSION VERSION_LESS "7.3")
message(FATAL_ERROR "\nCpp-Taskflow requires g++ at least v7.3")
endif()
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -O2")
## clang++
elseif (CMAKE_CXX_COMPILER_ID STREQUAL "Clang")
if(CMAKE_CXX_COMPILER_VERSION VERSION_LESS "5.0")
message(FATAL_ERROR "\nCpp-Taskflow requires clang++ at least v5.0")
endif()
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -O2")
## microsoft visual c++
elseif (CMAKE_CXX_COMPILER_ID STREQUAL "MSVC")
if(NOT MSVC_VERSION GREATER_EQUAL 1914)
message(FATAL_ERROR "\nCpp-Taskflow requires MSVC++ at least v14.14")
endif()
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /O2 /W3")
else()
message(FATAL_ERROR "\n\
Cpp-Taskflow currently supports the following compilers:\n\
- g++ v7.3 or above\n\
- clang++ v5.0 or above\n\
- MSVC++ v19.14 or above\n\
")
endif()
# CXX target properties
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_CXX_EXTENSIONS OFF)
message(STATUS "CMAKE_BUILD_TYPE: " ${CMAKE_BUILD_TYPE})
message(STATUS "CMAKE_CXX_COMPILER: " ${CMAKE_CXX_COMPILER})
message(STATUS "CMAKE_CXX_COMPILER_VERSION: " ${CMAKE_CXX_COMPILER_VERSION})
message(STATUS "CMAKE_CXX_FLAGS: " ${CMAKE_CXX_FLAGS})
# add the binary tree to the search path for include files
include_directories(${PROJECT_SOURCE_DIR})
include_directories(doctest)
include_directories(taskflow)
# Find pthread package
find_package(Threads REQUIRED)
## Find OpenMP package
#include(FindOpenMP)
#
#if(OpenMP_CXX_FOUND)
# message(STATUS "OpenMP_CXX_SPEC_DATE: ${OpenMP_CXX_SPEC_DATE}")
# message(STATUS "OpenMP_CXX_VERSION: ${OpenMP_CXX_VERSION}")
# message(STATUS "OpenMP_CXX_FLAGS: ${OpenMP_CXX_FLAGS}")
# message(STATUS "OpenMP_CXX_LIB_NAMES: ${OpenMP_CXX_LIB_NAMES}")
#else(OpenMP_CXX_FOUND)
# message(WARNING "OpenMP CXX not found")
#endif(OpenMP_CXX_FOUND)
# -----------------------------------------------------------------------------
# Example program
# -----------------------------------------------------------------------------
message(STATUS "Building examples ...")
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${PROJECT_SOURCE_DIR}/example)
add_executable(simple example/simple.cpp)
target_link_libraries(simple Threads::Threads)
add_executable(subflow example/subflow.cpp)
target_link_libraries(subflow Threads::Threads)
add_executable(debug example/debug.cpp)
target_link_libraries(debug Threads::Threads)
add_executable(emplace example/emplace.cpp)
target_link_libraries(emplace Threads::Threads)
add_executable(reduce example/reduce.cpp)
target_link_libraries(reduce Threads::Threads)
add_executable(threadpool example/threadpool.cpp)
target_link_libraries(threadpool Threads::Threads)
add_executable(taskflow example/taskflow.cpp)
target_link_libraries(taskflow Threads::Threads)
add_executable(matrix example/matrix.cpp)
target_link_libraries(matrix Threads::Threads)
add_executable(parallel_for example/parallel_for.cpp)
target_link_libraries(parallel_for Threads::Threads)
add_executable(threadpool_cxx14 example/threadpool_cxx14.cpp)
set_property(TARGET threadpool_cxx14 PROPERTY CXX_STANDARD 14)
target_link_libraries(threadpool_cxx14 Threads::Threads)
add_executable(multiple_dispatch example/multiple_dispatch.cpp)
target_link_libraries(multiple_dispatch Threads::Threads)
add_executable(dispatch example/dispatch.cpp)
target_link_libraries(dispatch Threads::Threads)
add_executable(executor example/executor.cpp)
target_link_libraries(executor Threads::Threads)
# -----------------------------------------------------------------------------
# Unittest
# -----------------------------------------------------------------------------
enable_testing()
message(STATUS "Building unit tests ...")
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${PROJECT_SOURCE_DIR}/unittest)
set(TF_UTEST_DIR ${PROJECT_SOURCE_DIR}/unittest)
# unittest for taskflow
add_executable(taskflow_test_tmp unittest/taskflow.cpp)
target_link_libraries(taskflow_test_tmp Threads::Threads)
set_target_properties(taskflow_test_tmp PROPERTIES OUTPUT_NAME "taskflow")
add_test(builder ${TF_UTEST_DIR}/taskflow -tc=Builder)
add_test(dispatch ${TF_UTEST_DIR}/taskflow -tc=Dispatch)
add_test(executor ${TF_UTEST_DIR}/taskflow -tc=Executor)
add_test(parallel_for ${TF_UTEST_DIR}/taskflow -tc=ParallelFor)
add_test(reduce ${TF_UTEST_DIR}/taskflow -tc=Reduce)
add_test(reduce_min ${TF_UTEST_DIR}/taskflow -tc=ReduceMin)
add_test(reduce_max ${TF_UTEST_DIR}/taskflow -tc=ReduceMax)
add_test(joined_subflow ${TF_UTEST_DIR}/taskflow -tc=JoinedSubflow)
add_test(detached_subflow ${TF_UTEST_DIR}/taskflow -tc=DetachedSubflow)
# unittest for threadpool
add_executable(threadpool_test_tmp unittest/threadpool.cpp)
target_link_libraries(threadpool_test_tmp Threads::Threads)
set_target_properties(threadpool_test_tmp PROPERTIES OUTPUT_NAME "threadpool")
add_test(WorkerQueue.OneThread ${TF_UTEST_DIR}/threadpool -tc=WorkerQueue.OneThread)
add_test(WorkerQueue.TwoThread ${TF_UTEST_DIR}/threadpool -tc=WorkerQueue.TwoThread)
add_test(WorkerQueue.TriThread ${TF_UTEST_DIR}/threadpool -tc=WorkerQueue.TriThread)
add_test(simple_threadpool ${TF_UTEST_DIR}/threadpool -tc=SimpleThreadpool)
add_test(proactive_threadpool ${TF_UTEST_DIR}/threadpool -tc=ProactiveThreadpool)
add_test(speculative_threadpool ${TF_UTEST_DIR}/threadpool -tc=SpeculativeThreadpool)
add_test(privatized_threadpool ${TF_UTEST_DIR}/threadpool -tc=PrivatizedThreadpool)
## threadpool_cxx14 unittest (contributed by Glen Fraser)
add_executable(threadpool_cxx14_tmp unittest/threadpool_cxx14.cpp)
set_target_properties(threadpool_cxx14_tmp PROPERTIES CXX_STANDARD 14)
target_link_libraries(threadpool_cxx14_tmp Threads::Threads)
set_target_properties(threadpool_cxx14_tmp PROPERTIES OUTPUT_NAME "threadpool_cxx14")
add_test(threadpool_cxx14_basic ${TF_UTEST_DIR}/threadpool_cxx14 -tc=Threadpool.Basic)
add_test(threadpool_cxx14_wait_for_all ${TF_UTEST_DIR}/threadpool_cxx14 -tc=Threadpool.WaitForAll)
# -----------------------------------------------------------------------------
# Benchmarking (enabled by TF_BENCHMARKING)
# -----------------------------------------------------------------------------
#if(TF_BENCHMARK EQUAL "1")
#message(STATUS "TF_BENCHMARK: ${TF_BENCHMARK}")
#
## Find OpenMP package
#include(FindOpenMP)
#
#if(NOT OpenMP_CXX_FOUND)
# message(FATAL_ERROR "")
# message(STATUS "OpenMP_CXX_SPEC_DATE: ${OpenMP_CXX_SPEC_DATE}")
# message(STATUS "OpenMP_CXX_VERSION: ${OpenMP_CXX_VERSION}")
# message(STATUS "OpenMP_CXX_FLAGS: ${OpenMP_CXX_FLAGS}")
# message(STATUS "OpenMP_CXX_LIB_NAMES: ${OpenMP_CXX_LIB_NAMES}")
#else(OpenMP_CXX_FOUND)
# message(WARNING "OpenMP CXX not found")
#endif(OpenMP_CXX_FOUND)
#
#endif()