-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
223 lines (194 loc) · 6.72 KB
/
CMakeLists.txt
File metadata and controls
223 lines (194 loc) · 6.72 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
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
# Project name and language specification
cmake_minimum_required(VERSION 3.19...3.30)
project(
MLIRPasses
VERSION 1.0
LANGUAGES C CXX)
set(CMAKE_CXX_STANDARD 20)
set(CMAKE_CXX_STANDARD_REQUIRED on)
set(CMAKE_POSITION_INDEPENDENT_CODE TRUE)
set(CMAKE_CXX_FLAGS "-w -fPIC")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-switch")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -frtti -fexceptions")
# Set default build type to Debug if none is specified
if(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE
Debug
CACHE STRING "Build type (Debug, Release)" FORCE)
endif()
# Define macros for Debug builds
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
message("Configuring for Debug mode")
add_compile_definitions(DEBUG)
endif()
include(cmake/ExternalDependencies.cmake) # doxygen dependencies
# ################ MLIR Settings ###########################################
# Find MLIR. (MLIR is usually installed as part of an LLVM distribution.)
find_package(MLIR REQUIRED CONFIG)
message(STATUS "Using MLIRConfig.cmake in: ${MLIR_DIR}")
# Append MLIR's CMake modules.
list(APPEND CMAKE_MODULE_PATH "${MLIR_CMAKE_DIR}")
list(APPEND CMAKE_MODULE_PATH "${LLVM_CMAKE_DIR}")
list(APPEND CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake/Modules")
# Include the MLIR helper macros.
include(TableGen)
include(AddMLIR)
include(AddLLVM)
# Add LLVM, Clang and MLIR headers to the include path
include_directories(SYSTEM ${LLVM_INCLUDE_DIRS} ${MLIR_INCLUDE_DIRS})
# ############### ADDITIONAL PACKAGES #######################################
# Tell where to search for Find<package>.cmake files
set(CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake" ${CMAKE_MODULE_PATH})
# set(CMAKE_CXX_STANDARD 11) Find QDMI package find_package(qdmi REQUIRED) Find
# QInfo package find_package(qinfo REQUIRED)
find_package(Z3 REQUIRED)
find_package(mqt-qcec REQUIRED)
# Find the QMAP package
set(CMAKE_CXX_STANDARD 17)
set(MQT_QMAP_TESTS OFF)
find_package(mqt-qmap REQUIRED)
# Restore the original CXX flags and compiler
set(CMAKE_CXX_STANDARD 20)
# ###################### CUDAQ settings ###################################
set(CUDAQ_MAIN_INCLUDE_DIR "${CUDAQ_SOURCE_DIR}/include")
set(CUDAQ_BINARY_DIR "${CUDAQ_SOURCE_DIR}/build")
set(CUDAQ_CMAKE_DIR "${CUDAQ_SOURCE_DIR}/cmake")
set(CUDAQ_INCLUDE_DIR "${CUDAQ_SOURCE_DIR}/build/include")
set(CUDAQ_LIBRARY_DIR "${CUDAQ_SOURCE_DIR}/build/lib")
set(CUDAQ_TOOLS_DIR "${CUDAQ_SOURCE_DIR}/build/bin")
set(CUDAQ_MLIR_RUNTIME_PATH "${CUDAQ_SOURCE_DIR}/build/lib")
include_directories(BEFORE ${CUDAQ_MAIN_INCLUDE_DIR}
${CUDAQ_BINARY_DIR}/include ${CUDAQ_SOURCE_DIR}/runtime)
# Validate CUDAQ dependencies
if(NOT EXISTS ${CUDAQ_BINARY_DIR}/lib/libcudaq-mlir-runtime.so)
message(
FATAL_ERROR
"Invalid CUDAQ dir: ${CUDAQ_SOURCE_DIR}. Cannot find libcudaq.so in build directory."
)
endif()
# ##############################################################################
set(MQT_QMAP_INCLUDE_DIR "${mqt-qmap_SOURCE_DIR}/include/")
set(MQT_QCEC_INCLUDE_DIR "${mqt-qcec_SOURCE_DIR}/include/")
set(MQT_CORE_INCLUDE_DIR "${mqt-core_SOURCE_DIR}/include/mqt-core")
set(qdmi_INCLUDE_DIRS "${QDMI_INCLUDE_DIRS}/qdmi")
set(qinfo_INCLUDE_DIRS "${qinfo_SOURCE_DIR}/include/qinfo")
message(STATUS "mqt include dir: ${MQT_QMAP_INCLUDE_DIR}")
message(STATUS "QINFO INCLUDE DIRS ${qinfo_INCLUDE_DIRS}")
include_directories(
BEFORE
${CMAKE_CURRENT_SOURCE_DIR}/include
${CMAKE_CURRENT_SOURCE_DIR}/include/Passes/
${CMAKE_CURRENT_SOURCE_DIR}/include/Support/
${CMAKE_CURRENT_SOURCE_DIR}/include/Support/CodeGen/
${CMAKE_CURRENT_SOURCE_DIR}/include/Support/DAG/
${CMAKE_CURRENT_SOURCE_DIR}/include/Optimizer/
${MQT_QMAP_INCLUDE_DIR}
${MQT_CORE_INCLUDE_DIR}
${qdmi_INCLUDE_DIRS}
${qinfo_INCLUDE_DIRS})
# Set explicit paths
file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/include/Passes)
file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/include/Optimizer)
set(LLVM_TARGET_DEFINITIONS
${CMAKE_CURRENT_SOURCE_DIR}/include/Passes/Transforms.td)
# Generate .inc files from TableGen
mlir_tablegen(include/Passes/Transforms.h.inc -gen-pass-decls -name
MQSSOptTransforms)
add_public_tablegen_target(MQSSTransformsPassIncGen)
set(LLVM_TARGET_DEFINITIONS
${CMAKE_CURRENT_SOURCE_DIR}/include/Passes/Decompositions.td)
# Generate .inc files from TableGen
mlir_tablegen(include/Passes/Decompositions.h.inc -gen-pass-decls -name
MQSSOptDecompositions)
add_public_tablegen_target(MQSSDecompositionsPassIncGen)
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR}/include)
# Collect all .cpp files in the src directory
file(GLOB SRC_CODEGEN "${CMAKE_CURRENT_SOURCE_DIR}/lib/Passes/CodeGen/*.cpp")
file(GLOB SRC_DECOMPOSITIONS
"${CMAKE_CURRENT_SOURCE_DIR}/lib/Passes/Decompositions/*.cpp")
file(GLOB SRC_EXAMPLES "${CMAKE_CURRENT_SOURCE_DIR}/lib/Passes/Examples/*.cpp")
file(GLOB SRC_TRANSFORMS
"${CMAKE_CURRENT_SOURCE_DIR}/lib/Passes/Transforms/*.cpp")
file(GLOB SRC_SUPPORT_QUAKE
"${CMAKE_CURRENT_SOURCE_DIR}/lib/Support/CodeGen/Quake/*.cpp"
"${CMAKE_CURRENT_SOURCE_DIR}/lib/Support/DAG/*.cpp")
file(GLOB SRC_OPTIMIZER "${CMAKE_CURRENT_SOURCE_DIR}/lib/Optimizer/*.cpp")
file(GLOB SRC_INTERFACES "${CMAKE_CURRENT_SOURCE_DIR}/lib/Interfaces/*.cpp")
add_mlir_library(
SupportQuake
SHARED
${SRC_SUPPORT_QUAKE}
LINK_LIBS
PUBLIC
MLIRIR
MLIRPass
MLIRTransforms)
add_mlir_library(
Interfaces
SHARED
${SRC_INTERFACES}
LINK_LIBS
PUBLIC
SupportQuake
MQT::CoreIR
MQT::CoreNA
MQT::QMapSC
MLIRIR
MLIRLinalgDialect
MLIRLinalgUtils
MLIRPass
MLIRTransforms)
add_mlir_library(
MLIRPasses
SHARED
${SRC_CODEGEN}
${SRC_DECOMPOSITIONS}
${SRC_EXAMPLES}
${SRC_TRANSFORMS}
DEPENDS
MQSSTransformsPassIncGen
MQSSDecompositionsPassIncGen
LINK_LIBS
PUBLIC
SupportQuake
Interfaces
MQT::CoreIR
MQT::CoreNA
MQT::QMapSC
MQT::QMapSCHeuristic
MLIRTensorDialect
MLIRIR
MLIRPass
MLIRTransforms)
add_mlir_library(
Optimizer
SHARED
${SRC_OPTIMIZER}
LINK_LIBS
PUBLIC
MLIRIR
MLIRPasses)
target_compile_options(Interfaces PRIVATE -fexceptions -frtti)
target_compile_options(SupportQuake PRIVATE -fexceptions -frtti)
target_compile_options(MLIRPasses PRIVATE -fexceptions -frtti)
# Create an alias target for convenience
add_library(MQSS::MLIRPasses ALIAS MLIRPasses)
add_library(MQSS::SupportQuake ALIAS SupportQuake)
add_library(MQSS::Optimizer ALIAS Optimizer)
add_library(MQSS::Interfaces ALIAS Interfaces)
# add tests
if(BUILD_MLIR_PASSES_TESTS)
enable_testing()
include(GoogleTest)
add_subdirectory(tests)
endif()
# add documentation
if(BUILD_MLIR_PASSES_DOCS)
add_subdirectory(docs)
endif()
if(BUILD_MLIR_PASSES_TOOLS)
add_subdirectory(tools)
endif()
install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/include/ DESTINATION include)
# Enable FetchContent for integration
include(FetchContent)