Skip to content
  • Valentin Churavy's avatar
    7c64f6bf
    [MLIR] Add support for libMLIR.so · 7c64f6bf
    Valentin Churavy authored
    Putting this up mainly for discussion on
    how this should be done. I am interested in MLIR from
    the Julia side and we currently have a strong preference
    to dynamically linking against the LLVM shared library,
    and would like to have a MLIR shared library.
    
    This patch adds a new cmake function add_mlir_library()
    which accumulates a list of targets to be compiled into
    libMLIR.so.  Note that not all libraries make sense to
    be compiled into libMLIR.so.  In particular, we want
    to avoid libraries which primarily exist to support
    certain tools (such as mlir-opt and mlir-cpu-runner).
    
    Note that the resulting libMLIR.so depends on LLVM, but
    does not contain any LLVM components.  As a result, it
    is necessary to link with libLLVM.so to avoid linkage
    errors. So, libMLIR.so requires LLVM_BUILD_LLVM_DYLIB=on
    
    FYI, Currently it appears that LLVM_LINK_LLVM_DYLIB is broken
    because mlir-tblgen is linked against libLLVM.so and
    and independent LLVM components.
    
    Previous version of this patch broke depencies on TableGen
    targets.  This appears to be because it compiled all
    libraries to OBJECT libraries (probably because cmake
    is generating different target names).  Avoiding object
    libraries results in correct dependencies.
    
    (updated by Stephen Neuendorffer)
    
    Differential Revision: https://reviews.llvm.org/D73130
    7c64f6bf
    [MLIR] Add support for libMLIR.so
    Valentin Churavy authored
    Putting this up mainly for discussion on
    how this should be done. I am interested in MLIR from
    the Julia side and we currently have a strong preference
    to dynamically linking against the LLVM shared library,
    and would like to have a MLIR shared library.
    
    This patch adds a new cmake function add_mlir_library()
    which accumulates a list of targets to be compiled into
    libMLIR.so.  Note that not all libraries make sense to
    be compiled into libMLIR.so.  In particular, we want
    to avoid libraries which primarily exist to support
    certain tools (such as mlir-opt and mlir-cpu-runner).
    
    Note that the resulting libMLIR.so depends on LLVM, but
    does not contain any LLVM components.  As a result, it
    is necessary to link with libLLVM.so to avoid linkage
    errors. So, libMLIR.so requires LLVM_BUILD_LLVM_DYLIB=on
    
    FYI, Currently it appears that LLVM_LINK_LLVM_DYLIB is broken
    because mlir-tblgen is linked against libLLVM.so and
    and independent LLVM components.
    
    Previous version of this patch broke depencies on TableGen
    targets.  This appears to be because it compiled all
    libraries to OBJECT libraries (probably because cmake
    is generating different target names).  Avoiding object
    libraries results in correct dependencies.
    
    (updated by Stephen Neuendorffer)
    
    Differential Revision: https://reviews.llvm.org/D73130
Loading