Skip to content

Commit

Permalink
Bump mlir-aie and llvm (Xilinx#859)
Browse files Browse the repository at this point in the history
  • Loading branch information
erwei-xilinx authored Jan 16, 2025
1 parent 06249fd commit a148645
Show file tree
Hide file tree
Showing 3 changed files with 6 additions and 117 deletions.
119 changes: 4 additions & 115 deletions python/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -98,121 +98,11 @@ add_mlir_python_common_capi_library(AirAggregateCAPI
AirPythonExtensions
)

################################################################################
# MLIR has switched to using nanobind 2.4 which enforces a check on the domain,
# but MLIR's add_mlir_python_extension and add_mlir_python_modules methods are
# fixing the NB_DOMAIN as mlir, leading to domain conflict between air and aie.
# Below is a workaround which re-implements the above methods by exposing the
# NB_DOMAIN for customization.
# TODO: Remove these when upstream LLVM fixes this issue.
function(add_mlir_python_extension_domain libname extname)
cmake_parse_arguments(ARG
""
"INSTALL_COMPONENT;INSTALL_DIR;OUTPUT_DIRECTORY;PYTHON_BINDINGS_LIBRARY"
"SOURCES;LINK_LIBS;NB_DOMAIN"
${ARGN})
set(eh_rtti_enable)
if (MSVC)
set(eh_rtti_enable /EHsc /GR)
elseif(LLVM_COMPILER_IS_GCC_COMPATIBLE OR CLANG_CL)
set(eh_rtti_enable -frtti -fexceptions)
endif ()
nanobind_add_module(${libname}
NB_DOMAIN ${ARG_NB_DOMAIN}
${ARG_SOURCES}
)
if (LLVM_COMPILER_IS_GCC_COMPATIBLE OR CLANG_CL)
target_compile_options(nanobind-static
PRIVATE
-Wno-cast-qual
-Wno-zero-length-array
-Wno-nested-anon-types
-Wno-c++98-compat-extra-semi
-Wno-covered-switch-default
${eh_rtti_enable}
)
endif()
target_compile_options(${libname} PRIVATE ${eh_rtti_enable})
set_target_properties(
${libname} PROPERTIES
LIBRARY_OUTPUT_DIRECTORY ${ARG_OUTPUT_DIRECTORY}
OUTPUT_NAME "${extname}"
NO_SONAME ON
)
target_link_libraries(${libname}
PRIVATE
${ARG_LINK_LIBS}
)
target_link_options(${libname}
PRIVATE
$<$<PLATFORM_ID:Linux>:LINKER:--exclude-libs,ALL>
)
if(ARG_INSTALL_DIR)
install(TARGETS ${libname}
COMPONENT ${ARG_INSTALL_COMPONENT}
LIBRARY DESTINATION ${ARG_INSTALL_DIR}
ARCHIVE DESTINATION ${ARG_INSTALL_DIR}
RUNTIME DESTINATION ${ARG_INSTALL_DIR}
)
endif()
endfunction()

function(add_mlir_python_modules_domain name)
cmake_parse_arguments(ARG
""
"ROOT_PREFIX;INSTALL_PREFIX"
"COMMON_CAPI_LINK_LIBS;DECLARED_SOURCES;NB_DOMAIN"
${ARGN})
function(_process_target modules_target sources_target)
get_target_property(_source_type ${sources_target} mlir_python_SOURCES_TYPE)
if(_source_type STREQUAL "pure")
# Pure python sources to link into the tree.
set(_pure_sources_target "${modules_target}.sources.${sources_target}")
add_mlir_python_sources_target(${_pure_sources_target}
INSTALL_COMPONENT ${modules_target}
INSTALL_DIR ${ARG_INSTALL_PREFIX}
OUTPUT_DIRECTORY ${ARG_ROOT_PREFIX}
SOURCES_TARGETS ${sources_target}
)
add_dependencies(${modules_target} ${_pure_sources_target})
elseif(_source_type STREQUAL "extension")
get_target_property(_module_name ${sources_target} mlir_python_EXTENSION_MODULE_NAME)
get_target_property(_bindings_library ${sources_target} mlir_python_BINDINGS_LIBRARY)
set(_extension_target "${modules_target}.extension.${_module_name}.dso")
add_mlir_python_extension_domain(${_extension_target} "${_module_name}"
INSTALL_COMPONENT ${modules_target}
INSTALL_DIR "${ARG_INSTALL_PREFIX}/_mlir_libs"
OUTPUT_DIRECTORY "${ARG_ROOT_PREFIX}/_mlir_libs"
PYTHON_BINDINGS_LIBRARY ${_bindings_library}
NB_DOMAIN ${ARG_NB_DOMAIN}
LINK_LIBS PRIVATE
${sources_target}
${ARG_COMMON_CAPI_LINK_LIBS}
)
add_dependencies(${modules_target} ${_extension_target})
mlir_python_setup_extension_rpath(${_extension_target})
endif()
endfunction()

add_custom_target(${name} ALL)
_flatten_mlir_python_targets(_flat_targets ${ARG_DECLARED_SOURCES})
foreach(sources_target ${_flat_targets})
_process_target(${name} ${sources_target})
endforeach()

if(NOT LLVM_ENABLE_IDE)
add_llvm_install_targets(
install-${name}
DEPENDS ${name}
COMPONENT ${name})
endif()
endfunction()
################################################################################

add_mlir_python_modules_domain(AirMLIRPythonModules
# Set NB_DOMAIN for nanobind, to avoid domain conflict with other llvm projects.
set(MLIR_BINDINGS_PYTHON_NB_DOMAIN "_air")
add_mlir_python_modules(AirMLIRPythonModules
ROOT_PREFIX "${AIR_PYTHON_PACKAGES_DIR}/air"
INSTALL_PREFIX "python/air"
NB_DOMAIN "_air"
DECLARED_SOURCES
MLIRPythonSources
MLIRPythonExtension.Core
Expand All @@ -223,10 +113,9 @@ add_mlir_python_modules_domain(AirMLIRPythonModules
AirAggregateCAPI
)

add_mlir_python_modules_domain(AirPythonModules
add_mlir_python_modules(AirPythonModules
ROOT_PREFIX "${AIR_PYTHON_PACKAGES_DIR}/air"
INSTALL_PREFIX "python/air"
NB_DOMAIN "_air"
DECLARED_SOURCES
AirPythonSources
COMMON_CAPI_LINK_LIBS
Expand Down
2 changes: 1 addition & 1 deletion utils/clone-llvm.sh
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
#
##===----------------------------------------------------------------------===##

export commithash=f926bcf9068c808b643a56322b7ef6910eb36599
export commithash=4b06b01e62ab0cfd059f47dceeb6cd0fb96304c9
target_dir=llvm

# clone llvm if it is not there already
Expand Down
2 changes: 1 addition & 1 deletion utils/clone-mlir-aie.sh
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
#
##===----------------------------------------------------------------------===##

export HASH=1b059e4996656d00499598c8c1ce8da6baa71262
export HASH=0d03400dca76782df37ef9f945ce9820904d887f
target_dir=mlir-aie

if [[ ! -d $target_dir ]]; then
Expand Down

0 comments on commit a148645

Please sign in to comment.