diff --git a/mlir/cmake/modules/AddMLIR.cmake b/mlir/cmake/modules/AddMLIR.cmake --- a/mlir/cmake/modules/AddMLIR.cmake +++ b/mlir/cmake/modules/AddMLIR.cmake @@ -27,6 +27,19 @@ set_target_properties(${target} PROPERTIES LINK_FLAGS ${link_flags}) endfunction(whole_archive_link) +add_custom_target(mlir-copy-file) +# Copy the .td file to the build tree so that out-of-tree users can +# depend on them. +function(mlir_copy_file filename) + add_custom_target(${filename} ALL DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${filename}) + add_custom_command(TARGET ${filename} POST_BUILD + COMMAND ${CMAKE_COMMAND} -E copy_if_different + ${CMAKE_CURRENT_SOURCE_DIR}/${filename} + ${CMAKE_CURRENT_BINARY_DIR}/${filename} + ) + add_dependencies(mlir-copy-file ${filename}) +endfunction(mlir_copy_file) + # Declare a dialect in the include directory function(add_mlir_dialect dialect dialect_doc_filename) set(LLVM_TARGET_DEFINITIONS ${dialect}.td) @@ -35,6 +48,10 @@ add_public_tablegen_target(MLIR${dialect}IncGen) add_dependencies(mlir-headers MLIR${dialect}IncGen) + mlir_copy_file(${dialect}.td) + if (NOT LLVM_INSTALL_TOOLCHAIN_ONLY) + endif() + # Generate Dialect Documentation set(LLVM_TARGET_DEFINITIONS ${dialect_doc_filename}.td) tablegen(MLIR ${dialect_doc_filename}.md -gen-op-doc "-I${MLIR_MAIN_SRC_DIR}" "-I${MLIR_INCLUDE_DIR}") diff --git a/mlir/cmake/modules/CMakeLists.txt b/mlir/cmake/modules/CMakeLists.txt --- a/mlir/cmake/modules/CMakeLists.txt +++ b/mlir/cmake/modules/CMakeLists.txt @@ -1,7 +1,7 @@ # Generate a list of CMake library targets so that other CMake projects can # link against them. LLVM calls its version of this file LLVMExports.cmake, but # the usual CMake convention seems to be ${Project}Targets.cmake. -set(MLIR_INSTALL_PACKAGE_DIR lib${LLVM_LIBDIR_SUFFIX}/cmake/llvm) +set(MLIR_INSTALL_PACKAGE_DIR lib${LLVM_LIBDIR_SUFFIX}/cmake/mlir) set(mlir_cmake_builddir "${CMAKE_BINARY_DIR}/${MLIR_INSTALL_PACKAGE_DIR}") # Keep this in sync with llvm/cmake/CMakeLists.txt! @@ -9,23 +9,41 @@ set(llvm_cmake_builddir "${LLVM_BINARY_DIR}/${LLVM_INSTALL_PACKAGE_DIR}") get_property(MLIR_EXPORTS GLOBAL PROPERTY MLIR_EXPORTS) -export(TARGETS ${MLIR_EXPORTS} FILE ${mlir_cmake_builddir}/MlirTargets.cmake) +export(TARGETS ${MLIR_EXPORTS} FILE ${mlir_cmake_builddir}/MLIRTargets.cmake) + +get_property(MLIR_ALL_LIBS GLOBAL PROPERTY MLIR_ALL_LIBS) +get_property(MLIR_DIALECT_LIBS GLOBAL PROPERTY MLIR_DIALECT_LIBS) +get_property(MLIR_CONVERSION_LIBS GLOBAL PROPERTY MLIR_CONVERSION_LIBS) # Generate MlirConfig.cmake for the build tree. set(MLIR_CONFIG_CMAKE_DIR "${mlir_cmake_builddir}") set(MLIR_CONFIG_LLVM_CMAKE_DIR "${llvm_cmake_builddir}") -set(MLIR_CONFIG_EXPORTS_FILE "${mlir_cmake_builddir}/MlirTargets.cmake") +set(MLIR_CONFIG_EXPORTS_FILE "${mlir_cmake_builddir}/MLIRTargets.cmake") set(MLIR_CONFIG_INCLUDE_DIRS "${MLIR_SOURCE_DIR}/include" "${MLIR_BINARY_DIR}/include" ) +configure_file( + ${CMAKE_CURRENT_SOURCE_DIR}/MLIRConfig.cmake.in + ${mlir_cmake_builddir}/MLIRConfig.cmake + @ONLY) set(MLIR_CONFIG_CMAKE_DIR) set(MLIR_CONFIG_LLVM_CMAKE_DIR) set(MLIR_CONFIG_EXPORTS_FILE) -# Generate MlirConfig.cmake for the install tree. +# For compatibility with projects that include(MLIRConfig) +# via CMAKE_MODULE_PATH, place API modules next to it. +# This should be removed in the future. +file(COPY . + DESTINATION ${mlir_cmake_builddir} + FILES_MATCHING PATTERN *.cmake + PATTERN .svn EXCLUDE + PATTERN CMakeFiles EXCLUDE + ) + +# Generate MLIRConfig.cmake for the install tree. set(MLIR_CONFIG_CODE " -# Compute the installation prefix from this LLVMConfig.cmake file location. +# Compute the installation prefix from this MLIRConfig.cmake file location. get_filename_component(MLIR_INSTALL_PREFIX \"\${CMAKE_CURRENT_LIST_FILE}\" PATH)") # Construct the proper number of get_filename_component(... PATH) # calls to compute the installation prefix. @@ -36,10 +54,14 @@ endforeach(p) set(MLIR_CONFIG_CMAKE_DIR "\${MLIR_INSTALL_PREFIX}/${MLIR_INSTALL_PACKAGE_DIR}") set(MLIR_CONFIG_LLVM_CMAKE_DIR "\${MLIR_INSTALL_PREFIX}/${LLVM_INSTALL_PACKAGE_DIR}") -set(MLIR_CONFIG_EXPORTS_FILE "\${MLIR_CMAKE_DIR}/MlirTargets.cmake") +set(MLIR_CONFIG_EXPORTS_FILE "\${MLIR_CMAKE_DIR}/MLIRTargets.cmake") set(MLIR_CONFIG_INCLUDE_DIRS "\${MLIR_INSTALL_PREFIX}/include" ) +configure_file( + ${CMAKE_CURRENT_SOURCE_DIR}/MLIRConfig.cmake.in + ${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/MLIRConfig.cmake + @ONLY) set(MLIR_CONFIG_CODE) set(MLIR_CONFIG_CMAKE_DIR) set(MLIR_CONFIG_EXPORTS_FILE) @@ -49,11 +71,12 @@ # Include the cmake files so other tools can use mlir-tblgen, etc. get_property(mlir_has_exports GLOBAL PROPERTY MLIR_HAS_EXPORTS) if(mlir_has_exports) - install(EXPORT MlirTargets DESTINATION ${MLIR_INSTALL_PACKAGE_DIR} + install(EXPORT MLIRTargets DESTINATION ${MLIR_INSTALL_PACKAGE_DIR} COMPONENT mlir-cmake-exports) endif() - install(FILES #${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/MlirConfig.cmake + install(FILES + ${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/MLIRConfig.cmake ${CMAKE_CURRENT_SOURCE_DIR}/AddMLIR.cmake DESTINATION ${MLIR_INSTALL_PACKAGE_DIR} COMPONENT mlir-cmake-exports) diff --git a/mlir/cmake/modules/MLIRConfig.cmake.in b/mlir/cmake/modules/MLIRConfig.cmake.in new file mode 100644 --- /dev/null +++ b/mlir/cmake/modules/MLIRConfig.cmake.in @@ -0,0 +1,35 @@ +# This file allows users to call find_package(MLIR) and pick up our targets. + +@MLIR_CONFIG_CODE@ + +find_package(LLVM REQUIRED CONFIG + HINTS "@MLIR_CONFIG_LLVM_CMAKE_DIR@") + +set(MLIR_EXPORTED_TARGETS "@MLIR_EXPORTS@") +set(MLIR_CMAKE_DIR "@MLIR_CONFIG_CMAKE_DIR@") +set(MLIR_INCLUDE_DIRS "@MLIR_CONFIG_INCLUDE_DIRS@") +set(MLIR_TABLEGEN_EXE "@MLIR_TABLEGEN_EXE@") + +# For mlir_tablegen() +set(MLIR_INCLUDE_DIR "@MLIR_INCLUDE_DIR@") +set(MLIR_MAIN_SRC_DIR "@MLIR_MAIN_SRC_DIR@") + +set_property(GLOBAL PROPERTY MLIR_ALL_LIBS "@MLIR_ALL_LIBS@") +set_property(GLOBAL PROPERTY MLIR_DIALECT_LIBS "@MLIR_DIALECT_LIBS@") +set_property(GLOBAL PROPERTY MLIR_CONVERSION_LIBS "@MLIR_CONVERSION_LIBS@") + +# Provide all our library targets to users. +include("@MLIR_CONFIG_EXPORTS_FILE@") + +# By creating these targets here, subprojects that depend on MLIR's +# tablegen-generated headers can always depend on these targets whether building +# in-tree with MLIR or not. +if(NOT TARGET mlir-tablegen-targets) + add_custom_target(mlir-tablegen-targets) +endif() +if(NOT TARGET mlir-headers) + add_custom_target(mlir-headers) +endif() +if(NOT TARGET mlir-doc) + add_custom_target(mlir-doc) +endif() diff --git a/mlir/include/mlir/IR/CMakeLists.txt b/mlir/include/mlir/IR/CMakeLists.txt --- a/mlir/include/mlir/IR/CMakeLists.txt +++ b/mlir/include/mlir/IR/CMakeLists.txt @@ -2,3 +2,6 @@ mlir_tablegen(OpAsmInterface.h.inc -gen-op-interface-decls) mlir_tablegen(OpAsmInterface.cpp.inc -gen-op-interface-defs) add_public_tablegen_target(MLIROpAsmInterfacesIncGen) + +mlir_copy_file(OpAsmInterface.td) +mlir_copy_file(OpBase.td)