Skip to content
  • Stephen Neuendorffer's avatar
    e9b87f43
    [RFC] Factor out repetitive cmake patterns for llvm-style projects · e9b87f43
    Stephen Neuendorffer authored
    New projects (particularly out of tree) have a tendency to hijack the existing
    llvm configuration options and build targets (add_llvm_library,
    add_llvm_tool).  This can lead to some confusion.
    
    1) When querying a configuration variable, do we care about how LLVM was
    configured, or how these options were configured for the out of tree project?
    2) LLVM has lots of defaults, which are easy to miss
    (e.g. LLVM_BUILD_TOOLS=ON).  These options all need to be duplicated in the
    CMakeLists.txt for the project.
    
    In addition, with LLVM Incubators coming online, we need better ways for these
    incubators to do things the "LLVM way" without alot of futzing.  Ideally, this
    would happen in a way that eases importing into the LLVM monorepo when
    projects mature.
    
    This patch creates some generic infrastructure in llvm/cmake/modules and
    refactors MLIR to use this infrastructure.  This should expand to include
    add_xxx_library, which is by far the most complicated bit of building a
    project correctly, since it has to deal with lots of shared library
    configuration bits.  (MLIR currently hijacks the LLVM infrastructure for
    building libMLIR.so, so this needs to get refactored anyway.)
    
    Differential Revision: https://reviews.llvm.org/D85140
    e9b87f43
    [RFC] Factor out repetitive cmake patterns for llvm-style projects
    Stephen Neuendorffer authored
    New projects (particularly out of tree) have a tendency to hijack the existing
    llvm configuration options and build targets (add_llvm_library,
    add_llvm_tool).  This can lead to some confusion.
    
    1) When querying a configuration variable, do we care about how LLVM was
    configured, or how these options were configured for the out of tree project?
    2) LLVM has lots of defaults, which are easy to miss
    (e.g. LLVM_BUILD_TOOLS=ON).  These options all need to be duplicated in the
    CMakeLists.txt for the project.
    
    In addition, with LLVM Incubators coming online, we need better ways for these
    incubators to do things the "LLVM way" without alot of futzing.  Ideally, this
    would happen in a way that eases importing into the LLVM monorepo when
    projects mature.
    
    This patch creates some generic infrastructure in llvm/cmake/modules and
    refactors MLIR to use this infrastructure.  This should expand to include
    add_xxx_library, which is by far the most complicated bit of building a
    project correctly, since it has to deal with lots of shared library
    configuration bits.  (MLIR currently hijacks the LLVM infrastructure for
    building libMLIR.so, so this needs to get refactored anyway.)
    
    Differential Revision: https://reviews.llvm.org/D85140
Loading