-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathCMakeLists.txt
225 lines (195 loc) · 7.24 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
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
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
cmake_minimum_required(VERSION 3.16)
project(lefdef-SPRoute
LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 17)
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake/Modules")
############################################################################
# Detect the installation path of LEF parser and DEF parser,
# and check if the liblef and libdef library can be found or not
############################################################################
message(STATUS "Detecting environment variable LEF_ROOT...")
set(LEF_ROOT "")
if (DEFINED ENV{LEF_ROOT})
message(STATUS "Environment variable LEF_ROOT detected: " $ENV{LEF_ROOT})
include_directories($ENV{LEF_ROOT}/include)
link_directories($ENV{LEF_ROOT}/lib)
set(LEF_ROOT $ENV{LEF_ROOT})
else ()
message(STATUS "Environment variable LEF_ROOT not found, using ACT_HOME instead")
include_directories($ENV{ACT_HOME}/include)
link_directories($ENV{ACT_HOME}/lib)
set(LEF_ROOT $ENV{ACT_HOME})
endif ()
find_library(
LEF_LIBRARY
NAMES lef
PATHS ${LEF_ROOT}/lib
REQUIRED
)
if (NOT LEF_LIBRARY)
message(FATAL_ERROR "Cannot find liblef.a")
else ()
message(STATUS "Found liblef.a: " ${LEF_LIBRARY})
endif ()
message(STATUS "Detecting environment variable DEF_ROOT...")
set(DEF_ROOT "")
if (DEFINED ENV{DEF_ROOT})
message(STATUS "Environment variable DEF_ROOT detected: " $ENV{DEF_ROOT})
include_directories($ENV{DEF_ROOT}/include)
link_directories($ENV{DEF_ROOT}/lib)
set(DEF_ROOT $ENV{DEF_ROOT})
else ()
message(STATUS "Environment variable DEF_ROOT not found, using ACT_HOME instead")
include_directories($ENV{ACT_HOME}/include)
link_directories($ENV{ACT_HOME}/lib)
set(DEF_ROOT $ENV{ACT_HOME})
endif ()
find_library(
DEF_LIBRARY
NAMES def
PATHS ${DEF_ROOT}/lib
REQUIRED
)
if (NOT DEF_LIBRARY)
message(FATAL_ERROR "Cannot find libdef.a")
else ()
message(STATUS "Found libdef.a: " ${DEF_LIBRARY})
endif ()
if(GALOIS_ENABLE_VTUNE)
set(VTune_ROOT /opt/intel/vtune_amplifier)
find_package(VTune REQUIRED)
include_directories(${VTune_INCLUDE_DIRS})
add_definitions(-DGALOIS_ENABLE_VTUNE)
set(VTune_LIBRARY_PATH_CANDIDATES lib lib64 lib32 bin64/k1om bin32/k1om)
find_path(VTune_INCLUDE_DIRS ittnotify.h PATHS ${VTune_ROOT} PATH_SUFFIXES include)
find_library(VTune_LIBRARY NAMES ittnotify PATHS ${VTune_ROOT} PATH_SUFFIXES ${VTune_LIBRARY_PATH_CANDIDATES})
find_library(VTune_LIBRARIES NAMES dl PATH_SUFFIXES lib lib64 lib32)
link_directories(/opt/intel/oneapi/vtune/latest/lib64/)
endif()
message(STATUS "Detecting environment variable $ENV{ACT_HOME}...")
if (DEFINED ENV{ACT_HOME})
message(STATUS "Environment variable ACT_HOME detected: " $ENV{ACT_HOME})
else ()
message(FATAL_ERROR "Environment variable $ENV{ACT_HOME} not found")
endif ()
include_directories($ENV{ACT_HOME}/include)
link_directories($ENV{ACT_HOME}/lib)
find_library(PHYDB_LIBRARY
NAMES phydb
PATHS $ENV{ACT_HOME}/lib
REQUIRED)
if (NOT PHYDB_LIBRARY)
message(FATAL_ERROR "libphydb.a is not found")
else ()
message(STATUS "libphydb.a found")
endif()
message(STATUS "Detecting Galois libraries...")
set(Galois_FOUND TRUE)
find_library(
GALOIS_EDA_LIBRARY
NAMES galois_eda
PATHS $ENV{ACT_HOME}/lib
)
if (GALOIS_EDA_LIBRARY)
set(Galois_LIBRARIES ${GALOIS_EDA_LIBRARY})
message(STATUS "Found libgalois_eda.a: " ${GALOIS_EDA_LIBRARY})
else()
message(STATUS "Cannot find libgalois_eda.a")
set(Galois_FOUND FALSE)
endif()
find_library(
GALOIS_SHMEM_LIBRARY
NAMES galois_shmem
PATHS $ENV{ACT_HOME}/lib
)
if (GALOIS_SHMEM_LIBRARY)
set(Galois_LIBRARIES ${Galois_LIBRARIES} ${GALOIS_SHMEM_LIBRARY})
message(STATUS "Found libgalois_shmem.a: " ${GALOIS_SHMEM_LIBRARY})
else()
message(STATUS "Cannot find libgalois_shmem.a")
set(Galois_FOUND FALSE)
endif()
if (UNIX AND (NOT APPLE))
find_library(
NUMA_LIBRARY
NAMES numa
)
if (NUMA_LIBRARY)
set(Galois_LIBRARIES ${Galois_LIBRARIES} ${NUMA_LIBRARY})
message(STATUS "Found libnuma: " ${NUMA_LIBRARY})
else()
message(STATUS "Cannot find libnuma")
set(Galois_FOUND FALSE)
endif()
endif()
find_package(Boost 1.71.0 REQUIRED)
message(STATUS "Boost library path: ${Boost_LIBRARY_DIRS}")
message(STATUS "Boost include path: ${Boost_INCLUDE_DIR}")
message(STATUS "Boost libs: ${Boost_LIBRARIES}")
include_directories(${Boost_INCLUDE_DIRS})
#
# This is needed because Boost doesn't auto-detect the C++17 deprecation of
# std::unary_function and std::binary_function
#
add_compile_options("-D_HAS_AUTO_PTR_ETC=0")
# Set a default build type if none was specified
set(default_build_type "RELEASE")
if (NOT CMAKE_BUILD_TYPE)
message(STATUS "Setting build type to '${default_build_type}' as none was specified.")
set(CMAKE_BUILD_TYPE "${default_build_type}")
# Set the possible values of build type for cmake-gui
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS
"DEBUG" "RELEASE")
endif ()
#add_compile_options(-Wall -Wextra -Wshadow -Wnon-virtual-dtor -pedantic)
#set(CMAKE_CXX_FLAGS_DEBUG "-g -Wno-unused-variable -Wno-unused-but-set-variable -Wno-maybe-uninitialized -Wno-unused-function -Wno-shadow -Wno-unused-parameter")
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O3 -DNDEBUG -Wno-unused-variable -Wno-unused-but-set-variable -Wno-maybe-uninitialized -Wno-unused-function -Wno-shadow -Wno-unused-parameter")
#set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O3 -DNDEBUG -Wno-unused-variable -Wno-unused-but-set-variable -Wno-maybe-uninitialized -Wno-unused-function -Wno-shadow -Wno-unused-parameter")
set(CMAKE_CXX_FLAGS_DEBUG "-g")
set(CMAKE_CXX_FLAGS_RELEASE "-O3 -DNDEBUG")
# Set the output directory of static libraries
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/lib)
# Set the output directory of executables
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/bin)
include_directories(include)
FILE(GLOB CPP_SOURCES "src/*.cpp")
FILE(GLOB C_SOURCES "src/*.c")
add_subdirectory(test)
add_library(sproute
STATIC
${CPP_SOURCES} ${C_SOURCES})
target_link_libraries(sproute
lef def galois_shmem pthread phydb)
if(BUILD_BIN)
add_executable(SPRoute
test/main.cpp)
target_link_libraries(SPRoute
lef
def
sproute
pthread
phydb
${Galois_LIBRARIES}
)
endif()
######################################
# specify the installation directory: ${ACT_HOME}
######################################
message(STATUS "Detecting environment variable ACT_HOME...")
if (DEFINED ENV{ACT_HOME})
message(STATUS "Environment variable ACT_HOME detected: " $ENV{ACT_HOME})
else ()
message(FATAL_ERROR "Environment variable ACT_HOME not found")
endif ()
message(STATUS "Changing Installation directory to ACT_HOME")
set(CMAKE_INSTALL_PREFIX $ENV{ACT_HOME} CACHE PATH "installation path" FORCE)
message(STATUS "Current installation directory: " ${CMAKE_INSTALL_PREFIX})
######################################
# Install header files
######################################
install(DIRECTORY include/ DESTINATION include/sproute COMPONENT Development FILES_MATCHING PATTERN "*.h")
######################################
# Install library and FLUTE's files
######################################
install(DIRECTORY lib/
DESTINATION lib)