annotate mlir/CMakeLists.txt @ 201:a96fbbdf2d0f

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 04 Jun 2021 21:07:06 +0900
parents 0572611fdcc8
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 # MLIR project.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
2 set(MLIR_MAIN_SRC_DIR ${CMAKE_CURRENT_SOURCE_DIR} )
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
3 set(MLIR_MAIN_INCLUDE_DIR ${MLIR_MAIN_SRC_DIR}/include )
150
anatofuz
parents:
diff changeset
4
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
5 set(MLIR_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
6 set(MLIR_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR})
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
7 set(MLIR_INCLUDE_DIR ${CMAKE_CURRENT_BINARY_DIR}/include)
150
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake/modules")
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 include(AddMLIR)
anatofuz
parents:
diff changeset
12
anatofuz
parents:
diff changeset
13 # Installing the headers and docs needs to depend on generating any public
anatofuz
parents:
diff changeset
14 # tablegen'd targets.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
15 # mlir-generic-headers are dialect-independent.
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
16 add_custom_target(mlir-generic-headers)
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
17 set_target_properties(mlir-generic-headers PROPERTIES FOLDER "Misc")
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
18 # mlir-headers may be dialect-dependent.
150
anatofuz
parents:
diff changeset
19 add_custom_target(mlir-headers)
anatofuz
parents:
diff changeset
20 set_target_properties(mlir-headers PROPERTIES FOLDER "Misc")
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
21 add_dependencies(mlir-headers mlir-generic-headers)
150
anatofuz
parents:
diff changeset
22 add_custom_target(mlir-doc)
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 # Build the CUDA conversions and run according tests if the NVPTX backend
anatofuz
parents:
diff changeset
25 # is available
anatofuz
parents:
diff changeset
26 if ("NVPTX" IN_LIST LLVM_TARGETS_TO_BUILD)
anatofuz
parents:
diff changeset
27 set(MLIR_CUDA_CONVERSIONS_ENABLED 1)
anatofuz
parents:
diff changeset
28 else()
anatofuz
parents:
diff changeset
29 set(MLIR_CUDA_CONVERSIONS_ENABLED 0)
anatofuz
parents:
diff changeset
30 endif()
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
31 # TODO: we should use a config.h file like LLVM does
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
32 add_definitions(-DMLIR_CUDA_CONVERSIONS_ENABLED=${MLIR_CUDA_CONVERSIONS_ENABLED})
150
anatofuz
parents:
diff changeset
33
anatofuz
parents:
diff changeset
34 set(MLIR_CUDA_RUNNER_ENABLED 0 CACHE BOOL "Enable building the mlir CUDA runner")
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
35 set(MLIR_VULKAN_RUNNER_ENABLED 0 CACHE BOOL "Enable building the mlir Vulkan runner")
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
36
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
37 option(MLIR_INCLUDE_TESTS
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
38 "Generate build targets for the MLIR unit tests."
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
39 ${LLVM_INCLUDE_TESTS})
150
anatofuz
parents:
diff changeset
40
anatofuz
parents:
diff changeset
41 include_directories( "include")
anatofuz
parents:
diff changeset
42 include_directories( ${MLIR_INCLUDE_DIR})
anatofuz
parents:
diff changeset
43
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
44 # Adding tools/mlir-tblgen here as calling add_tablegen sets some variables like
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
45 # MLIR_TABLEGEN_EXE in PARENT_SCOPE which gets lost if that folder is included
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
46 # from another directory like tools
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
47 add_subdirectory(tools/mlir-tblgen)
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
48
150
anatofuz
parents:
diff changeset
49 add_subdirectory(include/mlir)
anatofuz
parents:
diff changeset
50 add_subdirectory(lib)
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
51 if (MLIR_INCLUDE_TESTS)
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
52 add_definitions(-DMLIR_INCLUDE_TESTS)
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
53 add_subdirectory(unittests)
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
54 add_subdirectory(test)
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
55 endif()
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
56 # Tools needs to come late to ensure that MLIR_ALL_LIBS is populated.
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
57 # Generally things after this point may depend on MLIR_ALL_LIBS or libMLIR.so.
150
anatofuz
parents:
diff changeset
58 add_subdirectory(tools)
anatofuz
parents:
diff changeset
59
anatofuz
parents:
diff changeset
60 if( LLVM_INCLUDE_EXAMPLES )
anatofuz
parents:
diff changeset
61 add_subdirectory(examples)
anatofuz
parents:
diff changeset
62 endif()
anatofuz
parents:
diff changeset
63
anatofuz
parents:
diff changeset
64 option(MLIR_INCLUDE_DOCS "Generate build targets for the MLIR docs."
anatofuz
parents:
diff changeset
65 ${LLVM_INCLUDE_DOCS})
anatofuz
parents:
diff changeset
66 if (MLIR_INCLUDE_DOCS)
anatofuz
parents:
diff changeset
67 add_subdirectory(docs)
anatofuz
parents:
diff changeset
68 endif()
anatofuz
parents:
diff changeset
69
anatofuz
parents:
diff changeset
70 if (NOT LLVM_INSTALL_TOOLCHAIN_ONLY)
anatofuz
parents:
diff changeset
71 install(DIRECTORY include/mlir include/mlir-c
anatofuz
parents:
diff changeset
72 DESTINATION include
anatofuz
parents:
diff changeset
73 COMPONENT mlir-headers
anatofuz
parents:
diff changeset
74 FILES_MATCHING
anatofuz
parents:
diff changeset
75 PATTERN "*.def"
anatofuz
parents:
diff changeset
76 PATTERN "*.h"
anatofuz
parents:
diff changeset
77 PATTERN "*.inc"
anatofuz
parents:
diff changeset
78 PATTERN "*.td"
anatofuz
parents:
diff changeset
79 PATTERN "LICENSE.TXT"
anatofuz
parents:
diff changeset
80 )
anatofuz
parents:
diff changeset
81
anatofuz
parents:
diff changeset
82 install(DIRECTORY ${MLIR_INCLUDE_DIR}/mlir ${MLIR_INCLUDE_DIR}/mlir-c
anatofuz
parents:
diff changeset
83 DESTINATION include
anatofuz
parents:
diff changeset
84 COMPONENT mlir-headers
anatofuz
parents:
diff changeset
85 FILES_MATCHING
anatofuz
parents:
diff changeset
86 PATTERN "*.def"
anatofuz
parents:
diff changeset
87 PATTERN "*.h"
anatofuz
parents:
diff changeset
88 PATTERN "*.gen"
anatofuz
parents:
diff changeset
89 PATTERN "*.inc"
anatofuz
parents:
diff changeset
90 PATTERN "*.td"
anatofuz
parents:
diff changeset
91 PATTERN "CMakeFiles" EXCLUDE
anatofuz
parents:
diff changeset
92 PATTERN "config.h" EXCLUDE
anatofuz
parents:
diff changeset
93 )
anatofuz
parents:
diff changeset
94
anatofuz
parents:
diff changeset
95 if (NOT LLVM_ENABLE_IDE)
anatofuz
parents:
diff changeset
96 add_llvm_install_targets(install-mlir-headers
anatofuz
parents:
diff changeset
97 DEPENDS mlir-headers
anatofuz
parents:
diff changeset
98 COMPONENT mlir-headers)
anatofuz
parents:
diff changeset
99 endif()
anatofuz
parents:
diff changeset
100 endif()
anatofuz
parents:
diff changeset
101
anatofuz
parents:
diff changeset
102 add_subdirectory(cmake/modules)