blob: 860e33b4910d571821420df81e77b715f948e614 [file] [log] [blame]
Geoffrey Martin-Noble552d3f82021-05-25 17:56:09 -07001# Copyright 2019 The IREE Authors
Ben Vanik185d30c2019-09-19 14:24:11 -07002#
Geoffrey Martin-Noble552d3f82021-05-25 17:56:09 -07003# Licensed under the Apache License v2.0 with LLVM Exceptions.
4# See https://llvm.org/LICENSE.txt for license information.
5# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Ben Vanik185d30c2019-09-19 14:24:11 -07006
Scott Todda24c8c52022-05-17 09:22:47 -07007cmake_minimum_required(VERSION 3.21...3.23)
Ben Vanik552c5f42021-06-21 17:39:14 -07008
9# LLVM requires CMP0116 for tblgen: https://reviews.llvm.org/D101083
10# CMP0116: Ninja generators transform `DEPFILE`s from `add_custom_command()`
11# New in CMake 3.20. https://cmake.org/cmake/help/latest/policy/CMP0116.html
12set(CMAKE_POLICY_DEFAULT_CMP0116 OLD)
13
Ben Vanik512d2d32019-09-20 13:22:34 -070014set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
Ben Vanik185d30c2019-09-19 14:24:11 -070015
Stella Laurenzo688670f2021-09-24 18:16:25 -070016project(IREE ASM C CXX)
Lei Zhang6c5907b2020-06-02 09:06:08 -070017set(CMAKE_C_STANDARD 11)
Scott Todd07349fa2022-07-27 12:16:05 -070018set(CMAKE_CXX_STANDARD 17)
Stella Laurenzobc09f0e2022-07-27 16:22:39 -070019# LLVM defines this as a CACHE property and uses a policy that causes the
20# cache value to take precedence. This is causing us to mix 17/14 across
21# the boundary.
22# TODO: Remove this once the LLVM mechanism is updated. See:
23# https://discourse.llvm.org/t/important-new-toolchain-requirements-to-build-llvm-will-most-likely-be-landing-within-a-week-prepare-your-buildbots/61447/9
24set(CMAKE_CXX_STANDARD 17 CACHE STRING "C++ standard to conform to" FORCE)
Ben Vanik185d30c2019-09-19 14:24:11 -070025set(IREE_IDE_FOLDER IREE)
26set_property(GLOBAL PROPERTY USE_FOLDERS ON)
27
Scott Todd1a1aea62022-04-28 09:12:11 -070028if(MSVC)
Ben Vanik96fd2772021-04-19 20:30:56 -070029 enable_language(ASM_MASM)
30else()
31 enable_language(ASM)
32endif()
33
Cindy Liub1bfb9c2022-06-27 10:46:13 -070034# Set the default CMake build type so some of the build type dependent setting
35# in the submodules and functions (IREE assertion) can be set properly.
Cindy Liu23dafd02022-06-22 15:36:21 -070036set(DEFAULT_CMAKE_BUILD_TYPE "Release")
37if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES)
38 message(STATUS "No build type selected, default to ${DEFAULT_CMAKE_BUILD_TYPE}")
39 set(CMAKE_BUILD_TYPE "${DEFAULT_CMAKE_BUILD_TYPE}" CACHE STRING "Build type (default ${DEFAULT_CMAKE_BUILD_TYPE})" FORCE)
40endif()
41
Scott Todd99e9f5b2021-12-30 10:56:12 -080042include(CMakeDependentOption)
43
Lei Zhang7e253da2020-06-10 07:51:19 -070044#-------------------------------------------------------------------------------
45# Project component configuration
46#-------------------------------------------------------------------------------
47
Ben Vanik56d44bf2020-05-15 13:20:50 -070048option(IREE_ENABLE_RUNTIME_TRACING "Enables instrumented runtime tracing." OFF)
Scott Todd1cd9f0a2021-07-29 10:05:44 -070049option(IREE_ENABLE_COMPILER_TRACING "Enables instrumented compiler tracing." OFF)
Geoffrey Martin-Noblefe74bd42021-10-27 22:17:13 -070050option(IREE_ENABLE_THREADING "Builds IREE in with thread library support." ON)
Rob Sudermand42e0022022-06-08 16:38:45 -070051option(IREE_ENABLE_CLANG_TIDY "Builds IREE in with clang tidy enabled on IREE's libraries." OFF)
Ben Vanik512d2d32019-09-20 13:22:34 -070052
Ben Vanik4aae0032022-04-19 15:49:26 -070053# TODO(#8469): remove the dependency on cpuinfo entirely.
54option(IREE_ENABLE_CPUINFO "Enables runtime use of cpuinfo for processor topology detection." ON)
55
Marius Brehleredfc57f2019-12-18 11:19:38 -080056option(IREE_BUILD_COMPILER "Builds the IREE compiler." ON)
Ben Vanik512d2d32019-09-20 13:22:34 -070057option(IREE_BUILD_TESTS "Builds IREE unit tests." ON)
Lei Zhang22f0e242020-03-30 12:09:20 -070058option(IREE_BUILD_DOCS "Builds IREE docs." OFF)
Ben Vanik6b112ef2019-10-03 10:45:14 -070059option(IREE_BUILD_SAMPLES "Builds IREE sample projects." ON)
Scott Todd382fc632022-06-06 10:57:24 -070060option(IREE_BUILD_PYTHON_BINDINGS "Builds the IREE python bindings" OFF)
Stella Laurenzod3770ff2021-10-18 22:54:18 -070061option(IREE_BUILD_TRACY "Builds tracy server tools." OFF)
Ben Vanikcd1132f2021-01-29 15:58:17 -080062
Scott Todd352da3f2022-07-20 15:25:11 -070063option(IREE_BYTECODE_MODULE_FORCE_LLVM_SYSTEM_LINKER "Use the system linker when generating IREE modules in tests/samples/benchmarks (useful for Tracy)." OFF)
bjacob1af90ee2022-03-28 22:10:53 -040064
Stella Laurenzobb1de962021-01-05 08:18:33 -080065# Properties controlling version and naming of release artifacts.
Stella Laurenzof33f5b52022-01-08 17:49:52 +000066set(IREE_RELEASE_PACKAGE_SUFFIX "" CACHE STRING "Suffix to append to distributed package names")
Stella Laurenzobb1de962021-01-05 08:18:33 -080067set(IREE_RELEASE_VERSION "0.1a1" CACHE STRING "Version to embed in distributed packages")
68set(IREE_RELEASE_REVISION "HEAD" CACHE STRING "Version control revision information to embed in distributed packages")
69
Ben Vanikcd1132f2021-01-29 15:58:17 -080070option(IREE_BUILD_BINDINGS_TFLITE "Builds the IREE TFLite C API compatibility shim" ON)
Kojo Acquah5bf39942021-04-22 16:01:28 -070071option(IREE_BUILD_BINDINGS_TFLITE_JAVA "Builds the IREE TFLite Java bindings with the C API compatibility shim" ON)
Ben Vanikcd1132f2021-01-29 15:58:17 -080072
Jerry Wub6b1dee2022-06-01 13:45:16 +000073# Properties building and controlling benchmark suites.
74option(IREE_BUILD_BENCHMARKS "Builds IREE benchmark suites." OFF)
75# TODO(pzread): Currently IREE_ENABLE_COMPILATION_BENCHMARKS needs
76# IREE_BUILD_BENCHMARKS. Eventually we will decouple them.
77cmake_dependent_option(IREE_ENABLE_COMPILATION_BENCHMARKS "Builds IREE benchmark suites for compilation statistics." OFF ${IREE_BUILD_BENCHMARKS} OFF)
78
79option(IREE_BUILD_MICROBENCHMARKS "Builds IREE microbenchmark suites." OFF)
80
Stella Laurenzo0f005e52020-12-27 11:54:33 -080081#-------------------------------------------------------------------------------
82# Experimental project flags
83#-------------------------------------------------------------------------------
84
Stella Laurenzo0f005e52020-12-27 11:54:33 -080085option(IREE_BUILD_EXPERIMENTAL_REMOTING "Builds experimental remoting support." OFF)
Ben Vanika372ab52022-07-25 18:40:22 -070086option(IREE_BUILD_EXPERIMENTAL_VMVX_MMT4D "Enables MMT4D methods in the VMVX module." OFF)
Scott Toddf237b5e2022-01-28 11:02:25 -080087option(IREE_BUILD_EXPERIMENTAL_WEB_SAMPLES "Builds experimental web samples." OFF)
Jerry Wu5263dde2022-09-21 11:30:35 -070088option(IREE_BUILD_EXPERIMENTAL_PYTHON_GENERATED_BENCHMARKS "Builds IREE benchmark suites generated by the python benchmark framework." OFF)
Stella Laurenzo0f005e52020-12-27 11:54:33 -080089
90#-------------------------------------------------------------------------------
Stella Laurenzo74b04b72022-03-02 10:21:11 -080091# Runtime HAL Driver Options
92# By default, all runtime drivers supported by the current platform which do
93# not require external deps are enabled by default. This can be changed with:
94# -DIREE_HAL_DRIVER_DEFAULTS=OFF
Ben Vanik185d30c2019-09-19 14:24:11 -070095#-------------------------------------------------------------------------------
96
Ben Vanik4e6af052022-06-07 17:10:20 -070097# External HAL drivers; see runtime/src/iree/hal/drivers/CMakeLists.txt for more
98# information on how to declare external drivers.
99set(IREE_EXTERNAL_HAL_DRIVERS "" CACHE STRING "")
100
Ben Vanik89160272022-09-26 16:44:11 -0700101# Additional executable loader deps to add dependent libraries to any target
102# using the default executable loader registration utilities.
103# TODO(benvanik): extend the deps to encompass the built-in loaders too so that
104# we have one flag. We could also support a list of deps and automatically
105# generate the registration from that via a configure file.
106set(IREE_HAL_EXECUTABLE_LOADER_EXTRA_DEPS "" CACHE STRING "")
107
Scott Toddd1620f02021-12-22 14:55:38 -0800108option(IREE_HAL_DRIVER_DEFAULTS "Sets the default value for all runtime HAL drivers" ON)
Stella Laurenzo98388662022-02-03 15:37:30 -0800109# CUDA support must be explicitly enabled.
110set(IREE_HAL_DRIVER_CUDA_DEFAULT OFF)
Marius Brehler0a4b67f2020-05-08 13:19:16 -0700111
Scott Toddd1620f02021-12-22 14:55:38 -0800112# Vulkan is not natively supported on Apple platforms.
113# Metal should generally be used instead, though MoltenVK may also work.
Scott Todd1a1aea62022-04-28 09:12:11 -0700114if(APPLE)
Scott Toddd1620f02021-12-22 14:55:38 -0800115 set(IREE_HAL_DRIVER_VULKAN_DEFAULT OFF)
116else()
117 set(IREE_HAL_DRIVER_VULKAN_DEFAULT ${IREE_HAL_DRIVER_DEFAULTS})
118endif()
Marius Brehler0a4b67f2020-05-08 13:19:16 -0700119
Scott Toddd1620f02021-12-22 14:55:38 -0800120option(IREE_HAL_DRIVER_CUDA "Enables the 'cuda' runtime HAL driver" ${IREE_HAL_DRIVER_CUDA_DEFAULT})
Ben Vanike3058072022-06-06 19:21:44 -0700121option(IREE_HAL_DRIVER_LOCAL_SYNC "Enables the 'local-sync' runtime HAL driver" ${IREE_HAL_DRIVER_DEFAULTS})
122option(IREE_HAL_DRIVER_LOCAL_TASK "Enables the 'local-task' runtime HAL driver" ${IREE_HAL_DRIVER_DEFAULTS})
123option(IREE_HAL_DRIVER_VULKAN "Enables the 'vulkan' runtime HAL driver" ${IREE_HAL_DRIVER_VULKAN_DEFAULT})
124
Ben Vanik6e64b6e2022-06-07 09:14:53 -0700125option(IREE_HAL_EXECUTABLE_LOADER_DEFAULTS "Sets the default value for all runtime HAL executable loaders" ON)
126set(IREE_HAL_EXECUTABLE_LOADER_EMBEDDED_ELF_DEFAULT ${IREE_HAL_EXECUTABLE_LOADER_DEFAULTS})
127set(IREE_HAL_EXECUTABLE_LOADER_SYSTEM_LIBRARY_DEFAULT ${IREE_HAL_EXECUTABLE_LOADER_DEFAULTS})
128set(IREE_HAL_EXECUTABLE_LOADER_VMVX_MODULE_DEFAULT ${IREE_HAL_EXECUTABLE_LOADER_DEFAULTS})
Ben Vanike3058072022-06-06 19:21:44 -0700129
130# Emscripten builds don't support embedded ELF libraries.
131if(EMSCRIPTEN)
Ben Vanik2e8540e2022-06-06 20:39:34 -0700132 set(IREE_HAL_EXECUTABLE_LOADER_EMBEDDED_ELF_DEFAULT OFF)
Ben Vanike3058072022-06-06 19:21:44 -0700133endif()
134
135# If forcing system libraries (for TSAN/debugging tools/etc) then ensure the
136# system library loader is linked in.
Scott Todd352da3f2022-07-20 15:25:11 -0700137if(IREE_BYTECODE_MODULE_FORCE_LLVM_SYSTEM_LINKER)
Ben Vanike3058072022-06-06 19:21:44 -0700138 set(IREE_HAL_EXECUTABLE_LOADER_SYSTEM_LIBRARY_DEFAULT ON)
139endif()
140
Ben Vanik6e64b6e2022-06-07 09:14:53 -0700141# If no local driver is enabled then we force all the loaders off; this allows
142# for simpler checks that don't need to see if both the driver and loader is
143# available.
144if(NOT IREE_HAL_DRIVER_LOCAL_SYNC AND NOT IREE_HAL_DRIVER_LOCAL_TASK)
145 set(IREE_HAL_EXECUTABLE_LOADER_EMBEDDED_ELF_DEFAULT OFF)
146 set(IREE_HAL_EXECUTABLE_LOADER_SYSTEM_LIBRARY_DEFAULT OFF)
147 set(IREE_HAL_EXECUTABLE_LOADER_VMVX_MODULE_DEFAULT OFF)
148endif()
149
Ben Vanik2e8540e2022-06-06 20:39:34 -0700150option(IREE_HAL_EXECUTABLE_LOADER_EMBEDDED_ELF "Enables the embedded dynamic library loader for local HAL drivers" ${IREE_HAL_EXECUTABLE_LOADER_EMBEDDED_ELF_DEFAULT})
Ben Vanike3058072022-06-06 19:21:44 -0700151option(IREE_HAL_EXECUTABLE_LOADER_SYSTEM_LIBRARY "Enables the system dynamic library loader for local HAL drivers" ${IREE_HAL_EXECUTABLE_LOADER_SYSTEM_LIBRARY_DEFAULT})
152option(IREE_HAL_EXECUTABLE_LOADER_VMVX_MODULE "Enables the VMVX module loader for local HAL drivers" ${IREE_HAL_EXECUTABLE_LOADER_VMVX_MODULE_DEFAULT})
153
Scott Todd0f1f8eb2022-06-10 15:53:30 -0700154if(IREE_BUILD_COMPILER)
155 # The compiler requires the local task driver with the VMVX loader.
156 set(IREE_HAL_DRIVER_LOCAL_TASK ON)
157 set(IREE_HAL_EXECUTABLE_LOADER_VMVX_MODULE ON)
158endif()
159
Ben Vanike3058072022-06-06 19:21:44 -0700160message(STATUS "IREE HAL drivers:")
Stella Laurenzo74b04b72022-03-02 10:21:11 -0800161if(IREE_HAL_DRIVER_CUDA)
162 message(STATUS " - cuda")
163endif()
Ben Vanike3058072022-06-06 19:21:44 -0700164if(IREE_HAL_DRIVER_LOCAL_SYNC)
165 message(STATUS " - local-sync")
166endif()
167if(IREE_HAL_DRIVER_LOCAL_TASK)
168 message(STATUS " - local-task")
169endif()
Stella Laurenzo74b04b72022-03-02 10:21:11 -0800170if(IREE_HAL_DRIVER_VULKAN)
171 message(STATUS " - vulkan")
172endif()
Ben Vanik4e6af052022-06-07 17:10:20 -0700173if(IREE_EXTERNAL_HAL_DRIVERS)
174 message(STATUS " + external: ${IREE_EXTERNAL_HAL_DRIVERS}")
175endif()
Ben Vanik512d2d32019-09-20 13:22:34 -0700176
Ben Vanike3058072022-06-06 19:21:44 -0700177message(STATUS "IREE HAL local executable library loaders:")
Ben Vanik2e8540e2022-06-06 20:39:34 -0700178if(IREE_HAL_EXECUTABLE_LOADER_EMBEDDED_ELF)
179 message(STATUS " - embedded-elf")
Ben Vanike3058072022-06-06 19:21:44 -0700180endif()
181if(IREE_HAL_EXECUTABLE_LOADER_SYSTEM_LIBRARY)
182 message(STATUS " - system-library")
183endif()
184if(IREE_HAL_EXECUTABLE_LOADER_VMVX_MODULE)
185 message(STATUS " - vmvx-module")
186endif()
187
Lei Zhang0d281b72020-06-01 20:00:23 -0400188#-------------------------------------------------------------------------------
Ben Vanik4e6af052022-06-07 17:10:20 -0700189# Experimental ROCM HAL driver
190#-------------------------------------------------------------------------------
191
192set(IREE_EXTERNAL_ROCM_HAL_DRIVER_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/experimental/rocm")
193set(IREE_EXTERNAL_ROCM_HAL_DRIVER_BINARY_DIR "${CMAKE_CURRENT_BINARY_DIR}/experimental/rocm")
194set(IREE_EXTERNAL_ROCM_HAL_DRIVER_TARGET "iree::experimental::rocm::registration")
195set(IREE_EXTERNAL_ROCM_HAL_DRIVER_REGISTER "iree_hal_rocm_driver_module_register")
196
197#-------------------------------------------------------------------------------
Scott Todd382fc632022-06-06 10:57:24 -0700198# Compiler Target Options
199# By default, all compiler targets supported by the current platform which do
200# not require external deps are enabled by default. This can be changed with:
201# -DIREE_TARGET_BACKEND_DEFAULTS=OFF
202#-------------------------------------------------------------------------------
203
204option(IREE_TARGET_BACKEND_DEFAULTS "Sets the default value for all compiler target backends" ON)
205
206# The VMVX backend is always enabled.
207cmake_dependent_option(IREE_TARGET_BACKEND_VMVX "Enables the 'vmvx' compiler target backend" ON ${IREE_BUILD_COMPILER} OFF)
208
209# Supported default target backends.
Scott Todd352da3f2022-07-20 15:25:11 -0700210cmake_dependent_option(IREE_TARGET_BACKEND_LLVM_CPU "Enables the 'llvm-cpu' compiler target backend" ${IREE_TARGET_BACKEND_DEFAULTS} ${IREE_BUILD_COMPILER} OFF)
211cmake_dependent_option(IREE_TARGET_BACKEND_LLVM_CPU_WASM "Enables WebAssembly in the 'llvm-cpu' compiler target backend" ${IREE_TARGET_BACKEND_DEFAULTS} ${IREE_TARGET_BACKEND_LLVM_CPU} OFF)
Scott Todd382fc632022-06-06 10:57:24 -0700212cmake_dependent_option(IREE_TARGET_BACKEND_METAL_SPIRV "Enables the 'metal-spirv' compiler target backend" ${IREE_TARGET_BACKEND_DEFAULTS} ${IREE_BUILD_COMPILER} OFF)
Scott Todd382fc632022-06-06 10:57:24 -0700213cmake_dependent_option(IREE_TARGET_BACKEND_VULKAN_SPIRV "Enables the 'vulkan-spirv' compiler target backend" ${IREE_TARGET_BACKEND_DEFAULTS} ${IREE_BUILD_COMPILER} OFF)
214
215# Non-default target backends either have additional dependencies or are
216# experimental/niche in some fashion.
217cmake_dependent_option(IREE_TARGET_BACKEND_CUDA "Enables the 'cuda' compiler target backend" OFF ${IREE_BUILD_COMPILER} OFF)
218cmake_dependent_option(IREE_TARGET_BACKEND_ROCM "Enables the 'rocm' compiler target backend" OFF ${IREE_BUILD_COMPILER} OFF)
219# Disable WebGPU by default - it has complex deps and is under development.
220cmake_dependent_option(IREE_TARGET_BACKEND_WEBGPU "Enables the 'webgpu' compiler target backend" OFF ${IREE_BUILD_COMPILER} OFF)
221
222#-------------------------------------------------------------------------------
Scott Todde23d4a72022-07-27 14:16:39 -0700223# Compiler Input Dialects
224#-------------------------------------------------------------------------------
225
226cmake_dependent_option(IREE_INPUT_MHLO "Builds support for compiling MHLO programs" ON ${IREE_BUILD_COMPILER} OFF)
227cmake_dependent_option(IREE_INPUT_TORCH "Builds support for compiling Torch MLIR programs" ON ${IREE_BUILD_COMPILER} OFF)
228cmake_dependent_option(IREE_INPUT_TOSA "Builds support for compiling TOSA programs" ON ${IREE_BUILD_COMPILER} OFF)
229
Marius Brehler36f24512022-08-04 17:39:03 +0200230if(IREE_BUILD_COMPILER)
231 message(STATUS "IREE compiler input dialects:")
232 if(IREE_INPUT_MHLO)
233 message(STATUS " - MHLO")
234 endif()
235 if(IREE_INPUT_TORCH)
236 message(STATUS " - Torch MLIR")
237 endif()
238 if(IREE_INPUT_TOSA)
239 message(STATUS " - TOSA")
240 endif()
Scott Todde23d4a72022-07-27 14:16:39 -0700241endif()
242
243#-------------------------------------------------------------------------------
Scott Todd2a1925c2022-06-13 10:03:52 -0700244# Compiler Output Formats
245#-------------------------------------------------------------------------------
246
Scott Todd2a1925c2022-06-13 10:03:52 -0700247cmake_dependent_option(IREE_OUTPUT_FORMAT_C "Enables the 'vm-c' output format, using MLIR EmitC" ON ${IREE_BUILD_COMPILER} OFF)
248
Marius Brehler36f24512022-08-04 17:39:03 +0200249if(IREE_BUILD_COMPILER)
250 message(STATUS "IREE compiler output formats:")
251 if(IREE_OUTPUT_FORMAT_C)
252 message(STATUS " - C source module")
253 endif()
254 # The 'vm-bytecode' and 'vm-asm' formats are always enabled.
255 message(STATUS " - VM Bytecode")
256 message(STATUS " - VM MLIR Assembly")
Scott Todde23d4a72022-07-27 14:16:39 -0700257endif()
Scott Todde23d4a72022-07-27 14:16:39 -0700258
Scott Todd2a1925c2022-06-13 10:03:52 -0700259#-------------------------------------------------------------------------------
Lei Zhange88470f2020-09-08 13:21:09 -0400260# IREE compilation toolchain configuration
261#-------------------------------------------------------------------------------
262
Lei Zhange88470f2020-09-08 13:21:09 -0400263option(IREE_ENABLE_ASAN "Enable address sanitizer" OFF)
264option(IREE_ENABLE_MSAN "Enable memory sanitizer" OFF)
265option(IREE_ENABLE_TSAN "Enable thread sanitizer" OFF)
bjacob7cf5b842022-04-04 16:48:04 -0400266option(IREE_BYTECODE_MODULE_ENABLE_TSAN "Enable thread sanitizer in IREE modules in tests" OFF)
Jakub Kuderski068b1722022-07-27 18:14:59 -0400267option(IREE_ENABLE_UBSAN "Enable undefined behavior sanitizer" OFF)
bjacob7cf5b842022-04-04 16:48:04 -0400268
269# STREQUAL feels wrong here - we don't care about the exact true-value used,
270# ON or TRUE or something else. But we haven't been able to think of a less bad
Scott Todd7df39732022-06-28 09:21:35 -0700271# alternative. https://github.com/iree-org/iree/pull/8474#discussion_r840790062
bjacob7cf5b842022-04-04 16:48:04 -0400272if(NOT IREE_ENABLE_TSAN STREQUAL IREE_BYTECODE_MODULE_ENABLE_TSAN)
273 message(SEND_ERROR
274 "IREE_ENABLE_TSAN and IREE_BYTECODE_MODULE_ENABLE_TSAN must be "
275 "simultaneously ON or OFF. "
276 "A discrepancy between the two would cause tests to crash as IREE "
277 "runtime code (controlled by IREE_ENABLE_TSAN) calls into test IREE "
278 "modules (controlled by IREE_BYTECODE_MODULE_ENABLE_TSAN)")
279endif()
280
281if(IREE_BYTECODE_MODULE_ENABLE_TSAN)
Scott Todd352da3f2022-07-20 15:25:11 -0700282 if(NOT IREE_BYTECODE_MODULE_FORCE_LLVM_SYSTEM_LINKER)
bjacob7cf5b842022-04-04 16:48:04 -0400283 message(SEND_ERROR
284 "When IREE_BYTECODE_MODULE_ENABLE_TSAN is ON, "
Scott Todd352da3f2022-07-20 15:25:11 -0700285 "IREE_BYTECODE_MODULE_FORCE_LLVM_SYSTEM_LINKER must also be ON. "
bjacob7cf5b842022-04-04 16:48:04 -0400286 "TSAN instrumentation is not currently supported in embedded modules.")
287 endif()
288endif()
289
bjacobe694d952020-11-03 12:05:35 -0500290option(IREE_ENABLE_CCACHE "Use ccache if installed to speed up rebuilds." OFF)
291
Scott Todd1a1aea62022-04-28 09:12:11 -0700292if(IREE_ENABLE_CCACHE)
bjacobe694d952020-11-03 12:05:35 -0500293 find_program(CCACHE_PROGRAM ccache)
294 if(CCACHE_PROGRAM)
295 set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE "${CCACHE_PROGRAM}")
296 endif()
297endif()
Lei Zhange88470f2020-09-08 13:21:09 -0400298
Geoffrey Martin-Noble3fa4f8d2021-09-10 09:25:27 -0700299option(IREE_DEV_MODE "Configure settings to optimize for IREE development (as opposed to CI or release)" OFF)
Stella Laurenzo5b639122021-06-18 14:44:10 -0700300
301#-------------------------------------------------------------------------------
302# IREE assertions
303# We don't love the way this is done, but we have to line it up with how LLVM
304# does it and not diverge, since all implementations and all header users must
305# have the same definition of NDEBUG.
306#
307# LLVM defaults LLVM_ENABLE_ASSERTIONS to ON for Debug builds only but then
308# conditions itself to only update flags if not building Debug. We just let
309# IREE_ENABLE_ASSERTIONS be not conditioned on anything and only update the
310# flags in appropriate build types.
311#
312# If IREE_ENABLE_ASSERTIONS is set ON manually, then
313# - NDEBUG must be undefined
314# - LLVM_ENABLE_ASSERTIONS is forced off in order to keep multiple parties
315# from mucking with globals.
316#
317# Since CMake forces NDEBUG for !Debug builds, some surgery needs to be done
318# at the top level to avoid divergence.
319#-------------------------------------------------------------------------------
320
321option(IREE_ENABLE_ASSERTIONS "Force unset of NDEBUG compile option" OFF)
322
323# Filter -DNDEBUG from CMAKE_CXX_FLAGS_* and CMAKE_C_FLAGS_* (if
324# CMAKE_BUILD_TYPE is not Debug).
325function(iree_fix_ndebug)
Scott Todd1a1aea62022-04-28 09:12:11 -0700326 string(TOUPPER "${CMAKE_BUILD_TYPE}" _UPPERCASE_CMAKE_BUILD_TYPE)
327 if(IREE_ENABLE_ASSERTIONS AND NOT "${_UPPERCASE_CMAKE_BUILD_TYPE}" STREQUAL "DEBUG")
Stella Laurenzo5b639122021-06-18 14:44:10 -0700328 # Also remove /D NDEBUG to avoid MSVC warnings about conflicting defines.
Scott Todd1a1aea62022-04-28 09:12:11 -0700329 foreach(_FLAGS_VAR_TO_SCRUB
330 CMAKE_CXX_FLAGS_${_UPPERCASE_CMAKE_BUILD_TYPE}
331 CMAKE_C_FLAGS_${_UPPERCASE_CMAKE_BUILD_TYPE})
332 set(_ORIGINAL_FLAGS "${${_FLAGS_VAR_TO_SCRUB}}")
333 string(REGEX REPLACE "(^| )[/-]D *NDEBUG($| )" " " _ALTERED_FLAGS "${_ORIGINAL_FLAGS}")
334 if(NOT "${_ORIGINAL_FLAGS}" STREQUAL "${_ALTERED_FLAGS}")
Stella Laurenzo5b639122021-06-18 14:44:10 -0700335 message(STATUS
Scott Todd1a1aea62022-04-28 09:12:11 -0700336 "IREE_ENABLE_ASSERTIONS force disabled NDEBUG for ${_FLAGS_VAR_TO_SCRUB}: '${_ORIGINAL_FLAGS}' -> '${_ALTERED_FLAGS}'")
337 set(${_FLAGS_VAR_TO_SCRUB} "${_ALTERED_FLAGS}" PARENT_SCOPE)
Stella Laurenzo5b639122021-06-18 14:44:10 -0700338 endif()
339 endforeach()
340
341 # Make sure that LLVM doesn't add its own logic for assertion disabling.
342 # We'd like to make sure that we are not dueling over globals.
343 set(LLVM_ENABLE_ASSERTIONS OFF PARENT_SCOPE)
344 endif()
345endfunction()
346iree_fix_ndebug()
347
Lei Zhange88470f2020-09-08 13:21:09 -0400348#-------------------------------------------------------------------------------
Lei Zhang7e253da2020-06-10 07:51:19 -0700349# IREE utility definitions
Lei Zhang0d281b72020-06-01 20:00:23 -0400350#-------------------------------------------------------------------------------
351
Scott Toddd1620f02021-12-22 14:55:38 -0800352list(APPEND CMAKE_MODULE_PATH
353 ${CMAKE_CURRENT_LIST_DIR}/build_tools/cmake/
Scott Toddd1620f02021-12-22 14:55:38 -0800354)
355
Ben Vanik512d2d32019-09-20 13:22:34 -0700356include(iree_macros)
Ben Vanik185d30c2019-09-19 14:24:11 -0700357include(iree_copts)
bjacobc12ba3b2020-11-03 10:32:00 -0500358include(sanitizers)
Ben Vanik6b112ef2019-10-03 10:45:14 -0700359include(iree_cc_binary)
Ben Vanik185d30c2019-09-19 14:24:11 -0700360include(iree_cc_library)
361include(iree_cc_test)
Stella Laurenzo74b04b72022-03-02 10:21:11 -0800362include(iree_external_cmake_options)
Ben Vanikcc2aff92019-09-24 10:23:55 -0700363include(iree_tablegen_library)
Lei Zhang22f0e242020-03-30 12:09:20 -0700364include(iree_tablegen_doc)
CindyLiu40ed02d2021-04-22 16:16:28 +0000365include(iree_c_embed_data)
Scott Todd11adcab2019-12-18 14:10:44 -0800366include(iree_bytecode_module)
Marius Brehler46e83312021-03-25 00:11:39 +0100367include(iree_c_module)
Stella Laurenzo94363e22020-12-15 13:46:14 -0800368include(iree_python)
Geoffrey Martin-Noblef0eaf372020-01-28 10:03:14 -0800369include(iree_lit_test)
Geoffrey Martin-Noble4526dcc2020-03-09 11:59:52 -0700370include(iree_add_all_subdirs)
Geoffrey Martin-Noblee5fd5b52020-03-31 11:31:30 -0700371include(iree_check_test)
bjacob5feef482021-10-21 16:53:58 -0400372include(iree_trace_runner_test)
Geoffrey Martin-Noble435c2702022-01-24 15:56:56 -0800373include(iree_native_test)
Geoffrey Martin-Noble2811e502022-01-25 09:44:40 -0800374include(iree_cc_binary_benchmark)
Geoffrey Martin-Noble66d48892021-10-29 12:24:58 -0700375include(iree_benchmark_suite)
Han-Chung Wanga6fbb762022-04-15 14:25:04 -0700376include(iree_microbenchmark_suite)
Scott Todd434ff0e2021-12-21 10:38:36 -0800377include(iree_hal_cts_test_suite)
CindyLiuae72b952022-08-23 15:26:08 -0700378include(iree_static_linker_test)
Jerry Wu116db872022-09-22 19:33:13 +0000379include(iree_fetch_artifact)
CindyLiu080198f2022-10-06 07:21:17 -0700380include(iree_run_module_test)
Ben Vanik185d30c2019-09-19 14:24:11 -0700381
Marius Brehler06ac36e2020-01-10 14:44:11 -0800382set(CMAKE_POSITION_INDEPENDENT_CODE TRUE)
383
Ben Vanik185d30c2019-09-19 14:24:11 -0700384#-------------------------------------------------------------------------------
Lei Zhange88470f2020-09-08 13:21:09 -0400385# IREE compilation flags
Scott Todd29d654e2020-06-11 15:24:17 -0700386#-------------------------------------------------------------------------------
387
Lei Zhangdd21f322020-09-10 10:47:33 -0400388iree_append_list_to_string(CMAKE_C_FLAGS_DEBUG ${IREE_C_FLAGS_DEBUG_LIST})
389iree_append_list_to_string(CMAKE_CXX_FLAGS_DEBUG ${IREE_CXX_FLAGS_DEBUG_LIST})
Scott Todd29d654e2020-06-11 15:24:17 -0700390
391set(CMAKE_CXX_FLAGS_FASTBUILD "-gmlt" CACHE STRING "Flags used by the C++ compiler during fast builds." FORCE)
392set(CMAKE_C_FLAGS_FASTBUILD "-gmlt" CACHE STRING "Flags used by the C compiler during fast builds." FORCE)
393set(CMAKE_EXE_LINKER_FLAGS_FASTBUILD "-Wl,-S" CACHE STRING "Flags used for linking binaries during fast builds." FORCE)
394set(CMAKE_SHARED_LINKER_FLAGS_FASTBUILD "-Wl,-S" CACHE STRING "Flags used by the shared libraries linker binaries during fast builds." FORCE)
395mark_as_advanced(
396 CMAKE_CXX_FLAGS_FASTBUILD
397 CMAKE_C_FLAGS_FASTBUILD
398 CMAKE_EXE_LINKER_FLAGS_FASTBUILD
399 CMAKE_SHARED_LINKER_FLAGS_FASTBUILD
400)
401
Scott Todd7649dee2022-07-18 11:31:46 -0700402# Override the system's default linker.
403# See also: https://llvm.org/docs/CMake.html#llvm-use-linker.
404set(IREE_USE_LINKER "" CACHE STRING "")
405# Equivalent to setting -DIREE_USE_LINKER=lld.
406# Note that unlike LLVM's LLVM_ENABLE_LLD, this does _not_ build lld. You will
407# need to either install a recent version of lld or build it from source prior
408# to setting this option. See also: https://lld.llvm.org/#using-lld.
409# This option is disabled on Apple platforms, where lld is not supported.
410cmake_dependent_option(IREE_ENABLE_LLD "Override the system's default linker to lld" OFF "NOT APPLE" OFF)
411
Scott Todd29d654e2020-06-11 15:24:17 -0700412include(iree_setup_toolchain)
413
414#-------------------------------------------------------------------------------
Stella Laurenzo29032b82021-10-14 15:21:44 -0700415# Python
416# If building features that require Python development, find them early in
417# one invocation (some CMake versions are sensitive to resolving out of order).
418# Otherwise, for features that just require the interpreter, find that alone.
Stella Laurenzoa3e97f12020-12-05 23:29:13 -0800419#-------------------------------------------------------------------------------
420
Stella Laurenzo29032b82021-10-14 15:21:44 -0700421if(IREE_BUILD_PYTHON_BINDINGS)
422 # After CMake 3.18, we are able to limit the scope of the search to just
423 # Development.Module. Searching for Development will fail in situations where
424 # the Python libraries are not available. When possible, limit to just
425 # Development.Module.
426 # See https://pybind11.readthedocs.io/en/stable/compiling.html#findpython-mode
Scott Todda24c8c52022-05-17 09:22:47 -0700427 #
428 # Configuring the Development.Module is flaky in multi-project setups.
429 # "Bootstrapping" by first looking for the optional Development component
430 # seems to be robust generally.
431 # See: https://reviews.llvm.org/D118148
432 find_package(Python3 COMPONENTS Interpreter Development)
433 find_package(Python3 COMPONENTS Interpreter Development.Module REQUIRED)
Stella Laurenzo3149b6d2021-10-24 18:45:17 -0700434elseif(IREE_BUILD_COMPILER OR IREE_BUILD_TESTS)
Stella Laurenzoa3e97f12020-12-05 23:29:13 -0800435 find_package(Python3 COMPONENTS Interpreter REQUIRED)
436endif()
437
Stella Laurenzo3149b6d2021-10-24 18:45:17 -0700438# Extended Python environment checks.
439if(Python3_FOUND)
440 iree_detect_pyyaml()
441endif()
442
443if(IREE_BUILD_TESTS AND NOT IREE_PYYAML_FOUND)
444 message(WARNING "IREE's regression test suite requires PyYAML to run all tests. It is not installed, so some tests will be disabled.")
445endif()
446
Stella Laurenzoa3e97f12020-12-05 23:29:13 -0800447#-------------------------------------------------------------------------------
Niloy Sikdar47238df2021-07-28 23:37:33 +0530448# Check if git submodules have been initialized.
449# This will only run if python3 is available.
450#-------------------------------------------------------------------------------
451
Marius Brehler776d7e62021-12-21 22:50:52 +0100452option(IREE_ERROR_ON_MISSING_SUBMODULES "Error if submodules have not been initialized." ON)
453
Niloy Sikdar47238df2021-07-28 23:37:33 +0530454find_package(Python3 COMPONENTS Interpreter QUIET)
Scott Todde5b269a2021-11-16 15:25:02 -0800455find_package(Git)
Marius Brehler776d7e62021-12-21 22:50:52 +0100456if(IREE_ERROR_ON_MISSING_SUBMODULES AND Python3_FOUND AND Git_FOUND)
Scott Todde5b269a2021-11-16 15:25:02 -0800457 # Only check submodule status when the git commit changes.
Niloy Sikdar47238df2021-07-28 23:37:33 +0530458 execute_process(
Scott Todde5b269a2021-11-16 15:25:02 -0800459 COMMAND git rev-parse --short HEAD
Niloy Sikdar47238df2021-07-28 23:37:33 +0530460 WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
Scott Todde5b269a2021-11-16 15:25:02 -0800461 RESULT_VARIABLE SHORT_HASH_RESULT
462 OUTPUT_VARIABLE SHORT_HASH)
463 string(REGEX REPLACE "\n$" "" SHORT_HASH "${SHORT_HASH}")
Scott Todd2a8cd3b2021-12-13 11:58:44 -0800464 if(SHORT_HASH_RESULT EQUAL "0" AND NOT "${IREE_GIT_SHORT_HASH}" STREQUAL "${SHORT_HASH}")
Scott Todde5b269a2021-11-16 15:25:02 -0800465 execute_process(
Stella Laurenzo41224d12022-04-21 18:20:06 -0700466 COMMAND ${Python3_EXECUTABLE} build_tools/scripts/git/check_submodule_init.py
Scott Todde5b269a2021-11-16 15:25:02 -0800467 WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
468 RESULT_VARIABLE SUBMODULE_INIT_RESULT
469 )
470 if(NOT SUBMODULE_INIT_RESULT EQUAL "0")
471 message(FATAL_ERROR "check_submodule_init.py failed, see the logs above")
472 else()
473 set(IREE_GIT_SHORT_HASH "${SHORT_HASH}" CACHE STRING "" FORCE)
474 endif()
Niloy Sikdar47238df2021-07-28 23:37:33 +0530475 endif()
476endif()
477
478#-------------------------------------------------------------------------------
Stella Laurenzo98388662022-02-03 15:37:30 -0800479# CUDA configuration for both the compiler and runtime.
480# We do this at the top level so that we can fail fast and make global
481# decisions that effect both compiler and runtime. It also helps with error
482# messaging to do this all in one place, since we can provide very targeted
483# advice.
484#-------------------------------------------------------------------------------
485
486set(IREE_CUDA_LIBDEVICE_PATH "" CACHE STRING "Absolute path to an appropriate libdevice.*.bc (needed to build the IREE cuda compiler target)")
487
488# If any CUDA features are being built, try to locate a CUDA SDK. We will fall
489# back to this as needed for specific features.
490if(IREE_TARGET_BACKEND_CUDA OR IREE_HAL_DRIVER_CUDA)
Stella Laurenzo5062ae32022-02-04 17:59:16 -0800491 find_package(CUDAToolkit)
Stella Laurenzo59439022022-04-12 21:04:26 -0700492
Kojo Acquah719856b2022-06-15 18:35:02 -0400493 if(NOT CUDAToolkit_FOUND)
494 if(DEFINED ENV{IREE_CUDA_DEPS_DIR})
495 # We define the magic IREE_CUDA_DEPS_DIR env var in our CI docker images if we
496 # have a stripped down CUDA toolkit suitable for compiling available. We
497 # trigger on this below as a fallback for locating headers and libdevice
498 # files.
499 set(CUDAToolkit_ROOT "$ENV{IREE_CUDA_DEPS_DIR}")
500 message(STATUS "CUDA SDK not found by CMake but using IREE_CUDA_DEPS = ${CUDAToolkit_ROOT}")
501 else()
502 # If we haven't found CUDA deps, download at least enough to build for CUDA.
503 # This will define IREE_CUDA_DOWNLOAD_LIBDEVICE_PATH & IREE_CUDA_DOWNLOAD_INCLUDE_PATH
504 # vars with the target deps.
505 message(STATUS "CUDA SDK not found by CMake but downloading dependencies")
506 add_subdirectory(build_tools/third_party/cuda EXCLUDE_FROM_ALL)
507 endif()
Stella Laurenzo59439022022-04-12 21:04:26 -0700508 endif()
Stella Laurenzo98388662022-02-03 15:37:30 -0800509endif()
510
511# If an explicit libdevice file was not specified, and the compiler backend
512# is being built, probe for one.
513if(IREE_TARGET_BACKEND_CUDA)
Stella Laurenzo9fd5b5d2022-02-14 17:07:28 -0800514 if(IREE_CUDA_LIBDEVICE_PATH)
515 # Explicitly provided: do nothing.
516 elseif(CUDAToolkit_FOUND AND CUDAToolkit_LIBRARY_ROOT)
Stella Laurenzo98388662022-02-03 15:37:30 -0800517 # Note that the variable CUDAToolkit_LIBRARY_ROOT keys off of the presence
518 # of version.txt, which was changed to version.json in recent releases
519 # and thwarts the search.
520 set(IREE_CUDA_LIBDEVICE_PATH "${CUDAToolkit_LIBRARY_ROOT}/nvvm/libdevice/libdevice.10.bc")
521 elseif(CUDAToolkit_FOUND AND CUDAToolkit_BIN_DIR)
522 # Back-track from the bin dir as a fallback.
523 set(IREE_CUDA_LIBDEVICE_PATH "${CUDAToolkit_BIN_DIR}/../nvvm/libdevice/libdevice.10.bc")
Stella Laurenzo5062ae32022-02-04 17:59:16 -0800524 elseif(CUDAToolkit_ROOT)
525 # Sometimes the CUDA toolkit doesn't detect... because, you know. Computers
526 # are hard and such. In this case, if the user went to the trouble to
527 # tell us where it is, we have enough information.
528 set(IREE_CUDA_LIBDEVICE_PATH "${CUDAToolkit_ROOT}/nvvm/libdevice/libdevice.10.bc")
Kojo Acquah719856b2022-06-15 18:35:02 -0400529 elseif(IREE_CUDA_DOWNLOAD_LIBDEVICE_PATH)
530 message(STATUS "Using downloaded CUDA libdevice")
531 set(IREE_CUDA_LIBDEVICE_PATH "${IREE_CUDA_DOWNLOAD_LIBDEVICE_PATH}")
Stella Laurenzo98388662022-02-03 15:37:30 -0800532 else()
533 message(FATAL_ERROR "Building with IREE_TARGET_BACKEND_CUDA requires either a CUDA SDK (consult CMake docs for your version: https://cmake.org/cmake/help/latest/module/FindCUDAToolkit.html) or an explicit path to libdevice (set with -DIREE_CUDA_LIBDEVICE_PATH=/path/to/libdevice.10.bc)")
534 endif()
535
536 if(EXISTS "${IREE_CUDA_LIBDEVICE_PATH}")
537 message(STATUS "Using CUDA libdevice: ${IREE_CUDA_LIBDEVICE_PATH}")
538 else()
539 message(SEND_ERROR "Cannot find CUDA libdevice file (${IREE_CUDA_LIBDEVICE_PATH}). Either configure your CUDA SDK such that it can be found or specify explicitly via -DIREE_CUDA_LIBDEVICE_PATH=/path/to/libdevice.10.bc")
540 endif()
541endif()
542
Stella Laurenzo5062ae32022-02-04 17:59:16 -0800543if(IREE_HAL_DRIVER_CUDA)
544 if(CUDAToolkit_FOUND)
545 message(STATUS "Using CUDA INCLUDE_DIRS from found SDK: ${CUDAToolkit_INCLUDE_DIRS}")
546 elseif(CUDAToolkit_ROOT)
547 # See note above about computers being hard.
548 # We make minimal use of CUDA for the runtime and really just need cuda.h
549 # presently. So let's make a guess at that.
550 set(CUDAToolkit_INCLUDE_DIRS "${CUDAToolkit_ROOT}/include")
551 if(EXISTS "${CUDAToolkit_INCLUDE_DIRS}/cuda.h")
552 message(STATUS "Using CUDA INCLUDE_DIRS from CUDAToolkit_ROOT: ${CUDAToolkit_INCLUDE_DIRS}")
553 else()
554 message(SEND_ERROR "Using explicitly specified CUDAToolkit_ROOT, could not find cuda.h at: ${CUDAToolkit_INCLUDE_DIRS}")
555 endif()
Kojo Acquah719856b2022-06-15 18:35:02 -0400556 elseif(IREE_CUDA_DOWNLOAD_INCLUDE_PATH)
557 message(STATUS "Using downloaded CUDA includes")
558 set(CUDAToolkit_INCLUDE_DIRS "${IREE_CUDA_DOWNLOAD_INCLUDE_PATH}")
Stella Laurenzo5062ae32022-02-04 17:59:16 -0800559 else()
560 message(SEND_ERROR "Cannot build IREE runtime CUDA components (-DIREE_HAL_DRIVER_CUDA=ON) because a CUDA SDK was not found. Consult CMake docs for your version: https://cmake.org/cmake/help/latest/module/FindCUDAToolkit.html")
561 endif()
Stella Laurenzo98388662022-02-03 15:37:30 -0800562endif()
563
564#-------------------------------------------------------------------------------
Stella Laurenzo382122d2020-06-11 16:18:09 -0700565# MLIR/LLVM Dependency
Stella Laurenzo382122d2020-06-11 16:18:09 -0700566#-------------------------------------------------------------------------------
567
Stella Laurenzo275215d2021-08-06 11:50:28 -0700568if(NOT IREE_BUILD_COMPILER)
569 message(STATUS "Not adding LLVM/MLIR because the configuration does not require it")
570elseif(TARGET LLVMSupport)
571 message(STATUS "Not adding IREE bundled LLVM because it has already been included")
572 if(NOT TARGET MLIRIR)
573 message(FATAL_ERROR "Detected externally provided LLVM project but could not find MLIR projects (is it enabled/installed?)")
Stella Laurenzo382122d2020-06-11 16:18:09 -0700574 endif()
Stella Laurenzo275215d2021-08-06 11:50:28 -0700575else()
576 message(STATUS "Adding bundled LLVM source dependency")
577 iree_set_llvm_cmake_options()
Stella Laurenzo382122d2020-06-11 16:18:09 -0700578
Stella Laurenzo688670f2021-09-24 18:16:25 -0700579 # Enable MLIR Python bindings if IREE Python bindings enabled.
580 if(IREE_BUILD_PYTHON_BINDINGS)
Stella Laurenzo74b04b72022-03-02 10:21:11 -0800581 set(MLIR_ENABLE_BINDINGS_PYTHON ON)
582 set(MHLO_ENABLE_BINDINGS_PYTHON ON)
Stella Laurenzo688670f2021-09-24 18:16:25 -0700583 endif()
584
Stella Laurenzo275215d2021-08-06 11:50:28 -0700585 # Disable LLVM's warnings.
Stella Laurenzo74b04b72022-03-02 10:21:11 -0800586 set(LLVM_ENABLE_WARNINGS OFF)
Stella Laurenzo275215d2021-08-06 11:50:28 -0700587
Ben Vanik89a77fa2020-10-07 17:19:31 -0700588 # Stash cmake build type in case LLVM messes with it.
589 set(_CMAKE_BUILD_TYPE "${CMAKE_BUILD_TYPE}")
590
Stella Laurenzo62fbef02021-08-09 20:52:48 -0700591 # Add default external projects.
Stella Laurenzo02230c12021-08-10 03:58:42 +0000592 iree_add_llvm_external_project(mlir-iree-dialects MLIR_IREE_DIALECTS ${CMAKE_CURRENT_SOURCE_DIR}/llvm-external-projects/iree-dialects)
Stella Laurenzo62fbef02021-08-09 20:52:48 -0700593 iree_add_llvm_external_project(mlir-hlo MLIR_HLO ${CMAKE_CURRENT_SOURCE_DIR}/third_party/mlir-hlo)
Scott Todde23d4a72022-07-27 14:16:39 -0700594 if(IREE_INPUT_TORCH)
Yi Zhangc35fee82022-04-06 14:35:28 -0400595 iree_add_llvm_external_project(torch-mlir-dialects TORCH_MLIR_DIALECTS ${CMAKE_CURRENT_SOURCE_DIR}/third_party/torch-mlir-dialects)
596 endif()
Stella Laurenzo62fbef02021-08-09 20:52:48 -0700597
Stella Laurenzo275215d2021-08-06 11:50:28 -0700598 add_subdirectory("third_party/llvm-project/llvm" EXCLUDE_FROM_ALL)
Stella Laurenzo382122d2020-06-11 16:18:09 -0700599
Ben Vanik89a77fa2020-10-07 17:19:31 -0700600 # Reset CMAKE_BUILD_TYPE to its previous setting.
Stella Laurenzo74b04b72022-03-02 10:21:11 -0800601 set(CMAKE_BUILD_TYPE "${_CMAKE_BUILD_TYPE}" )
Stella Laurenzo382122d2020-06-11 16:18:09 -0700602
Stella Laurenzo275215d2021-08-06 11:50:28 -0700603 # Extend module path to allow submodules to use LLVM and MLIR CMake modules.
604 list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_BINARY_DIR}/lib/cmake/mlir")
605 list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_BINARY_DIR}/third_party/llvm-project/llvm/lib/cmake/llvm/")
Marius Brehler71f76cb2020-11-10 20:56:55 +0100606
Stella Laurenzo275215d2021-08-06 11:50:28 -0700607 # Add the bundled include directories for cmake files looking for them.
608 list(APPEND LLVM_INCLUDE_DIRS
609 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/llvm-project/llvm/include
610 ${CMAKE_CURRENT_BINARY_DIR}/third_party/llvm-project/llvm/include
611 )
612 list(APPEND MLIR_INCLUDE_DIRS
613 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/llvm-project/mlir/include
614 ${CMAKE_CURRENT_BINARY_DIR}/third_party/llvm-project/llvm/tools/mlir/include
615 )
Marius Brehler71f76cb2020-11-10 20:56:55 +0100616
Stella Laurenzo60128592022-04-17 21:52:09 -0700617 # TODO: It should be possible to fix upstream targets so as to not require
618 # any of these. Remove as they become unnecessary.
Stella Laurenzo62fbef02021-08-09 20:52:48 -0700619 function(_hack_llvm_include_paths)
Scott Todd1a1aea62022-04-28 09:12:11 -0700620 set(_COMMON_INCLUDE_DIRS
Stella Laurenzo60128592022-04-17 21:52:09 -0700621 # LLVM
Stella Laurenzo62fbef02021-08-09 20:52:48 -0700622 $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/third_party/llvm-project/llvm/include>
623 $<BUILD_INTERFACE:${CMAKE_CURRENT_BINARY_DIR}/third_party/llvm-project/llvm/include>
Stella Laurenzo60128592022-04-17 21:52:09 -0700624
625 # MLIR
Stella Laurenzo62fbef02021-08-09 20:52:48 -0700626 $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/third_party/llvm-project/mlir/include>
627 $<BUILD_INTERFACE:${CMAKE_CURRENT_BINARY_DIR}/third_party/llvm-project/llvm/tools/mlir/include>
Stella Laurenzo60128592022-04-17 21:52:09 -0700628
629 # LLD
630 $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/third_party/llvm-project/lld/include>
631 $<BUILD_INTERFACE:${CMAKE_CURRENT_BINARY_DIR}/third_party/llvm-project/llvm/tools/lld/include>
632
Stella Laurenzo62fbef02021-08-09 20:52:48 -0700633 )
634 # Avoid globally modifying paths by instead adding the include paths to the
635 # rules that really should have them in the first place.
Scott Todd1a1aea62022-04-28 09:12:11 -0700636 target_include_directories(LLVMSupport PUBLIC ${_COMMON_INCLUDE_DIRS})
637 target_include_directories(MLIRSupport PUBLIC ${_COMMON_INCLUDE_DIRS})
Stella Laurenzo62fbef02021-08-09 20:52:48 -0700638 endfunction()
639 _hack_llvm_include_paths()
Stella Laurenzo382122d2020-06-11 16:18:09 -0700640endif()
641
Stella Laurenzo382122d2020-06-11 16:18:09 -0700642#-------------------------------------------------------------------------------
Scott Todd8b0b0cd2021-12-16 15:13:57 -0800643# Other dependencies
Stella Laurenzoa3e97f12020-12-05 23:29:13 -0800644#-------------------------------------------------------------------------------
645
Ben Vanik512d2d32019-09-20 13:22:34 -0700646include(external_cc_library)
Ben Vanik2d1808b2020-07-17 19:02:16 -0700647include(flatbuffer_c_library)
Ben Vanik512d2d32019-09-20 13:22:34 -0700648
Ben Vanika9036492021-06-25 09:39:53 -0700649add_subdirectory(build_tools/third_party/libyaml EXCLUDE_FROM_ALL)
Jerry Wuae05f302022-05-17 13:58:13 +0000650add_subdirectory(build_tools/third_party/llvm-project EXCLUDE_FROM_ALL)
Ben Vanika9036492021-06-25 09:39:53 -0700651add_subdirectory(build_tools/third_party/vulkan_memory_allocator EXCLUDE_FROM_ALL)
Ben Vanik512d2d32019-09-20 13:22:34 -0700652
Stella Laurenzo275215d2021-08-06 11:50:28 -0700653iree_set_googletest_cmake_options()
Marius Brehlerf5022e82019-12-13 15:20:25 -0800654add_subdirectory(third_party/googletest EXCLUDE_FROM_ALL)
Stella Laurenzo275215d2021-08-06 11:50:28 -0700655
656if(IREE_ENABLE_THREADING)
657 iree_set_benchmark_cmake_options()
Cindy Liu331946c2021-06-01 12:20:30 -0700658 add_subdirectory(third_party/benchmark EXCLUDE_FROM_ALL)
Ben Vanik4aae0032022-04-19 15:49:26 -0700659 if(IREE_ENABLE_CPUINFO)
660 iree_set_cpuinfo_cmake_options()
661 add_subdirectory(third_party/cpuinfo EXCLUDE_FROM_ALL)
662 endif()
Cindy Liu331946c2021-06-01 12:20:30 -0700663endif()
Stella Laurenzo275215d2021-08-06 11:50:28 -0700664
Stella Laurenzo275215d2021-08-06 11:50:28 -0700665add_subdirectory(build_tools/third_party/flatcc EXCLUDE_FROM_ALL)
Stella Laurenzo275215d2021-08-06 11:50:28 -0700666
Marius Brehler9b86ad52022-06-08 17:09:02 +0200667if(IREE_HAL_DRIVER_VULKAN)
668 add_subdirectory(third_party/vulkan_headers EXCLUDE_FROM_ALL)
669endif()
Ben Vanik185d30c2019-09-19 14:24:11 -0700670
Scott Todd4e1a69b2021-01-25 15:29:49 -0800671# TODO(scotttodd): Iterate some more and find a better place for this.
Scott Todd1a1aea62022-04-28 09:12:11 -0700672if(NOT CMAKE_CROSSCOMPILING)
Ben Vanik68747192021-10-26 20:38:45 -0700673 install(
674 TARGETS iree-flatcc-cli
675 COMPONENT iree-flatcc-cli
676 RUNTIME DESTINATION bin
677 )
Lei Zhang0d281b72020-06-01 20:00:23 -0400678endif()
679
Stella Laurenzo275215d2021-08-06 11:50:28 -0700680if(IREE_BUILD_COMPILER)
Marius Brehler3eaf4442021-01-13 18:22:08 +0100681 add_subdirectory(build_tools/third_party/mlir-hlo EXCLUDE_FROM_ALL)
Ben Vanikcc2aff92019-09-24 10:23:55 -0700682endif()
683
Stella Laurenzo275215d2021-08-06 11:50:28 -0700684if(IREE_BUILD_TESTS)
Geoffrey Martin-Noble10f18222022-06-09 16:00:13 -0700685 include(iree_configure_testing)
Marius Brehler29676502019-12-27 17:07:10 -0800686endif()
687
MaheshRavishankar1547ac22021-09-23 15:22:46 -0700688if(IREE_BUILD_PYTHON_BINDINGS)
Stella Laurenzo95ad84c2021-09-24 14:56:01 -0700689 if(NOT TARGET pybind11::module)
690 message(STATUS "Using bundled pybind11")
691 add_subdirectory(third_party/pybind11 EXCLUDE_FROM_ALL)
692 else()
693 message(STATUS "Not including bundled pybind11 (already configured)")
694 endif()
Marius Brehlerf3d73c92020-01-16 16:11:52 -0800695endif()
696
Scott Toddd1620f02021-12-22 14:55:38 -0800697if(IREE_TARGET_BACKEND_METAL_SPIRV)
Stella Laurenzo275215d2021-08-06 11:50:28 -0700698 iree_set_spirv_cross_cmake_options()
Lei Zhang3cbb28e2020-09-22 15:30:27 -0400699 # SPIRV-Cross is needed to cross compile SPIR-V into MSL source code.
700 add_subdirectory(third_party/spirv_cross EXCLUDE_FROM_ALL)
701endif()
702
Scott Toddf8519ca2021-12-16 16:01:49 -0800703if(IREE_TARGET_BACKEND_WEBGPU)
704 # Tint is needed to compile SPIR-V into WGSL source code.
705 # Tint also requires SPIRV-Tools, which requires SPIRV-Headers.
706 iree_set_spirv_headers_cmake_options()
707 add_subdirectory(third_party/spirv_headers EXCLUDE_FROM_ALL)
708 add_subdirectory(build_tools/third_party/spirv-tools EXCLUDE_FROM_ALL)
709 add_subdirectory(build_tools/third_party/tint EXCLUDE_FROM_ALL)
710endif()
711
Ben Vanik185d30c2019-09-19 14:24:11 -0700712#-------------------------------------------------------------------------------
Lei Zhang22f0e242020-03-30 12:09:20 -0700713# IREE top-level targets
714#-------------------------------------------------------------------------------
715
Jerry Wu5263dde2022-09-21 11:30:35 -0700716if(IREE_BUILD_BENCHMARKS OR IREE_BUILD_EXPERIMENTAL_PYTHON_GENERATED_BENCHMARKS)
Scott Todd9ca75632022-04-13 10:47:11 -0700717 # Add top-level custom targets to drive generating benchmark suites.
718
719 # iree-benchmark-import-models imports benchmark models from their source
720 # formats, such as .tflite flatbuffers, to IREE-compatible .mlir files.
721 add_custom_target(iree-benchmark-import-models)
722
723 # iree-benchmark-suites fully prepares benchmark models for benchmarking:
724 # * importing from source formats to IREE-compatible .mlir files
725 # * compiling from .mlir files to benchmark-ready .vmfb files
726 # * generating flagfiles for executing the benchmark .vmfb files
Lei Zhangfe4403e2021-06-01 15:09:43 -0400727 add_custom_target(iree-benchmark-suites)
728endif()
729
Scott Todd1a1aea62022-04-28 09:12:11 -0700730if(IREE_BUILD_MICROBENCHMARKS)
Han-Chung Wanga6fbb762022-04-15 14:25:04 -0700731 # Add top-level custom targets to drive generating microbenchmark suites.
732 add_custom_target(iree-microbenchmark-suites)
733endif()
734
Scott Todd1a1aea62022-04-28 09:12:11 -0700735if(IREE_BUILD_DOCS)
Lei Zhang22f0e242020-03-30 12:09:20 -0700736 # Add a top-level custom target to drive generating all documentation.
737 # Register it to the default target given that IREE_BUILD_DOCS is explicitly
738 # requested.
739 add_custom_target(iree-doc ALL)
740endif()
741
Stella Laurenzo74b04b72022-03-02 10:21:11 -0800742# Testing rules that require generation will add dependencies to this target.
743# This allows them to be EXCLUDE_FROM_ALL but still invokable.
744add_custom_target(iree-test-deps COMMENT "Building IREE test deps")
745
Lei Zhang22f0e242020-03-30 12:09:20 -0700746#-------------------------------------------------------------------------------
Ben Vanik185d30c2019-09-19 14:24:11 -0700747# IREE top-level libraries
748#-------------------------------------------------------------------------------
749
Rob Sudermand42e0022022-06-08 16:38:45 -0700750if(IREE_ENABLE_CLANG_TIDY)
751 set(CMAKE_CXX_CLANG_TIDY clang-tidy -warnings-as-errors=*)
752endif()
753
Marius Brehlerf5022e82019-12-13 15:20:25 -0800754add_subdirectory(build_tools/embed_data/)
755
Stella Laurenzo74b04b72022-03-02 10:21:11 -0800756# Note: Test deps are not built as part of all (use the iree-test-deps target).
Scott Todd748bcd22022-05-25 12:18:40 -0700757add_subdirectory(tests EXCLUDE_FROM_ALL)
Lei Zhangff38a682021-06-08 21:12:24 -0400758
Jerry Wu5263dde2022-09-21 11:30:35 -0700759if(IREE_BUILD_BENCHMARKS OR IREE_BUILD_EXPERIMENTAL_PYTHON_GENERATED_BENCHMARKS)
Stella Laurenzoa6bf65c2022-01-11 20:47:51 -0800760 find_program(IREE_IMPORT_TFLITE_PATH iree-import-tflite)
761 if(IREE_IMPORT_TFLITE_PATH)
762 message(STATUS "Found ${IREE_IMPORT_TFLITE_PATH} to generate benchmark artifacts")
763 else()
764 message(STATUS "iree-import-tflite not found. Some benchmarks may not configure")
765 endif()
Jerry Wu60798ca2022-06-21 23:36:40 +0000766 find_program(IREE_IMPORT_TF_PATH iree-import-tf)
767 if(IREE_IMPORT_TF_PATH)
768 message(STATUS "Found ${IREE_IMPORT_TF_PATH} to generate benchmark artifacts")
769 else()
770 message(STATUS "iree-import-tf not found. Some benchmarks may not configure")
771 endif()
Lei Zhang08cea042021-07-20 12:44:01 -0400772 add_subdirectory(benchmarks)
Lei Zhangff38a682021-06-08 21:12:24 -0400773endif()
774
Scott Todd1a1aea62022-04-28 09:12:11 -0700775if(IREE_BUILD_COMPILER)
Stella Laurenzo41a2ceb2022-04-29 12:49:36 -0700776 add_subdirectory(compiler)
Ben Vanikcc2aff92019-09-24 10:23:55 -0700777endif()
Ben Vanik6b112ef2019-10-03 10:45:14 -0700778
Scott Todd4f16b992022-05-17 10:33:53 -0700779add_subdirectory(runtime)
780
Scott Todd4c022df2022-05-10 16:55:18 -0700781# tools/ can depend on compiler/ and runtime/
Scott Toddf57ab752022-05-23 10:36:44 -0700782add_subdirectory(tools)
Ben Vanik6b112ef2019-10-03 10:45:14 -0700783
Rob Sudermand42e0022022-06-08 16:38:45 -0700784
785if(IREE_ENABLE_CLANG_TIDY)
786 set(CMAKE_CXX_CLANG_TIDY "")
787endif()
788
Stella Laurenzod3770ff2021-10-18 22:54:18 -0700789if(IREE_BUILD_TRACY)
Stella Laurenzo3149b6d2021-10-24 18:45:17 -0700790 if(NOT CMAKE_SYSTEM_NAME MATCHES "Linux")
Stella Laurenzod3770ff2021-10-18 22:54:18 -0700791 message(WARNING "Building Tracy (IREE_BUILD_TRACY) on non-Linux is unsupported and may fail below.")
792 endif()
793 add_subdirectory(build_tools/third_party/tracy ${CMAKE_CURRENT_BINARY_DIR}/tracy)
794 if(NOT TARGET IREETracyCaptureServer)
795 message(SEND_ERROR "Could not build Tracy. Either unset IREE_BUILD_TRACY or look for missing dependencies above and install them.")
796 endif()
797endif()
798
Scott Toddf57ab752022-05-23 10:36:44 -0700799# Order constraint: The python bindings install tools targets from tools/
Stella Laurenzod3770ff2021-10-18 22:54:18 -0700800# and tracy, and must come after it.
Stella Laurenzo3b44a0a2022-04-18 19:57:57 -0700801if(IREE_BUILD_PYTHON_BINDINGS)
Stella Laurenzo60128592022-04-17 21:52:09 -0700802 # Write out a .env file to make IDEs and developers happy.
803 # Yes, we are writing this to the source dir. It is only for IDEs and if
804 # it gets clobbered, it is fine.
Stella Laurenzo41a2ceb2022-04-29 12:49:36 -0700805 set(_PYTHONPATH_ENV "PYTHONPATH=$<SHELL_PATH:${CMAKE_CURRENT_BINARY_DIR}/compiler/bindings/python;${CMAKE_CURRENT_BINARY_DIR}/runtime/bindings/python>\n")
Stella Laurenzo60128592022-04-17 21:52:09 -0700806 file(GENERATE OUTPUT "${CMAKE_CURRENT_SOURCE_DIR}/.env"
Scott Todd1a1aea62022-04-28 09:12:11 -0700807 CONTENT "${_PYTHONPATH_ENV}"
Stella Laurenzo60128592022-04-17 21:52:09 -0700808 )
809 file(GENERATE OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/.env"
Scott Todd1a1aea62022-04-28 09:12:11 -0700810 CONTENT "${_PYTHONPATH_ENV}"
Stella Laurenzo60128592022-04-17 21:52:09 -0700811 )
Stella Laurenzo77a63cd2021-01-04 17:29:54 -0800812endif()
813
Scott Todd1a1aea62022-04-28 09:12:11 -0700814if(IREE_BUILD_BINDINGS_TFLITE)
Scott Toddada25e62022-05-03 16:16:15 -0700815 add_subdirectory(runtime/bindings/tflite)
Ben Vanikcd1132f2021-01-29 15:58:17 -0800816endif()
817
Scott Todd1a1aea62022-04-28 09:12:11 -0700818if(IREE_BUILD_EXPERIMENTAL_REMOTING)
Stella Laurenzo0f005e52020-12-27 11:54:33 -0800819 # NOTE: Currently liburing is only used by the experimental remoting
820 # support, so keeping it scoped here. If this broadens, then include along
821 # with other dependencies as normal.
822 if(${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
823 message(STATUS "Enabling liburing")
824 add_subdirectory(build_tools/third_party/liburing EXCLUDE_FROM_ALL)
825 endif()
826 add_subdirectory(experimental/remoting)
Ben Vanikb64e9182020-01-30 15:19:37 -0800827endif()
Scott Toddee30e1b2020-02-03 16:44:15 -0800828
Scott Todd1a1aea62022-04-28 09:12:11 -0700829if(IREE_BUILD_EXPERIMENTAL_WEB_SAMPLES)
Scott Todd15fce0a2022-02-14 12:43:23 -0800830 add_subdirectory(experimental/web)
Scott Toddf237b5e2022-01-28 11:02:25 -0800831endif()
832
Stella Laurenzo03e48db2020-06-11 18:35:13 -0700833set(IREE_PUBLIC_INCLUDE_DIRS "${IREE_COMMON_INCLUDE_DIRS}"
834 CACHE INTERNAL "IREE: Include Directories" FORCE)
Stella Laurenzo688670f2021-09-24 18:16:25 -0700835
Jerry Wu623d1742022-03-31 18:16:02 +0000836#-------------------------------------------------------------------------------
837# IREE benchmark tools
838#-------------------------------------------------------------------------------
839
840add_subdirectory(build_tools/benchmarks)
Stella Laurenzo3b44a0a2022-04-18 19:57:57 -0700841
842#-------------------------------------------------------------------------------
Jerry Wu71562cc2022-09-20 18:56:41 -0700843# IREE build tools python modules
844#-------------------------------------------------------------------------------
845
846add_subdirectory(build_tools/python)
847
848#-------------------------------------------------------------------------------
Scott Todd4f16b992022-05-17 10:33:53 -0700849# Samples
Stella Laurenzo3b44a0a2022-04-18 19:57:57 -0700850#-------------------------------------------------------------------------------
851
Scott Todd4c022df2022-05-10 16:55:18 -0700852# samples/ can depend on anything, so we include it last
Stella Laurenzo1e8d1fa2022-04-22 09:50:43 -0700853if(IREE_BUILD_SAMPLES)
854 add_subdirectory(samples)
855endif()
Geoffrey Martin-Noble10f18222022-06-09 16:00:13 -0700856
857if(IREE_BUILD_TESTS)
858 iree_create_ctest_customization()
859endif()