2015-07-21 04:36:06 +08:00
|
|
|
# This file will recurse into all subdirectories that contain CMakeLists.txt
|
|
|
|
# Setting variables that match the pattern LLVM_TOOL_{NAME}_BUILD to Off will
|
|
|
|
# prevent traversing into a directory.
|
|
|
|
#
|
|
|
|
# The only tools that need to be explicitly added are ones that have explicit
|
|
|
|
# ordering requirements.
|
|
|
|
|
|
|
|
# Iterates all the subdirectories to create CMake options to enable/disable
|
|
|
|
# traversing each directory.
|
|
|
|
create_llvm_tool_options()
|
2010-09-14 07:59:48 +08:00
|
|
|
|
2014-03-14 12:04:14 +08:00
|
|
|
# Build polly before the tools: the tools link against polly when
|
|
|
|
# LINK_POLLY_INTO_TOOLS is set.
|
|
|
|
if(WITH_POLLY)
|
|
|
|
add_llvm_external_project(polly)
|
2014-11-10 23:03:02 +08:00
|
|
|
else()
|
2015-07-21 04:36:06 +08:00
|
|
|
set(LLVM_TOOL_POLLY_BUILD Off)
|
2014-11-10 23:03:02 +08:00
|
|
|
endif()
|
|
|
|
|
[RFC] Build LLVM-C.dll on MSVC that exports only the C API
Summary:
Hello!
This commit adds a LLVM-C target that is always built on MSVC. A big fat warning, this is my first cmake code ever so there is a fair bit of I-have-no-idea-what-I'm-doing going on here. Which is also why I placed it outside of llvm-shlib as I was afraid of breaking things of other people. Secondly llvm-shlib builds a LLVM.so which exports all symbols and then does a thin library that points to it, but on Windows we do not build a LLVM.dll so that would have complicated the code more.
The patch includes a python script that calls dumpbin.exe to get all of the symbols from the built libraries. It then grabs all the symbols starting with LLVM and generates the export file from those. The export file is then used to create the library just like the LLVM-C that is built on darwin.
Improvements that I need help with, to follow up this review.
- Get cmake to make sure that dumpbin.exe is on the path and wire the full path to the script.
- Use LLVM-C.dll when building llvm-c-test so we can verify that the symbols are exported.
- Bundle the LLVM-C.dll with the windows installer.
Why do this? I'm building a language frontend which is self-hosting, and on windows because of various tooling issues we have a problem of consuming the LLVM*.lib directly on windows. Me and the users of my projects using LLVM would be greatly helped by having LLVM-C.dll built and shipped by the Windows installer. Not only does LLVM takes forever to build, you have to run a extra python script in order to get the final DLL.
Any comments, thoughts or help is greatly appreciated.
Cheers, Jakob.
Patch by: Wallbraker (Jakob Bornecrantz)
Reviewers: compnerd, beanz, hans, smeenai
Reviewed By: beanz
Subscribers: xbolva00, bhelyer, Memnarch, rnk, fedor.sergeev, chapuni, smeenai, john.brawn, deadalnix, llvm-commits, mgorny
Differential Revision: https://reviews.llvm.org/D35077
llvm-svn: 339151
2018-08-07 23:54:50 +08:00
|
|
|
if(NOT LLVM_BUILD_LLVM_DYLIB AND NOT LLVM_BUILD_LLVM_C_DYLIB)
|
2015-07-21 04:36:06 +08:00
|
|
|
set(LLVM_TOOL_LLVM_SHLIB_BUILD Off)
|
2015-07-14 04:23:15 +08:00
|
|
|
endif()
|
2015-07-08 10:35:43 +08:00
|
|
|
|
2015-07-21 04:36:06 +08:00
|
|
|
if(NOT LLVM_USE_INTEL_JITEVENTS )
|
|
|
|
set(LLVM_TOOL_LLVM_JITLISTENER_BUILD Off)
|
|
|
|
endif()
|
2015-07-14 04:30:58 +08:00
|
|
|
|
2016-02-13 03:02:39 +08:00
|
|
|
if(CYGWIN OR NOT LLVM_ENABLE_PIC)
|
2015-07-21 04:36:06 +08:00
|
|
|
set(LLVM_TOOL_LTO_BUILD Off)
|
|
|
|
endif()
|
2015-07-14 04:30:58 +08:00
|
|
|
|
2015-12-17 02:30:36 +08:00
|
|
|
# Add LTO, llvm-ar, llvm-config, and llvm-profdata before clang, ExternalProject
|
|
|
|
# requires targets specified in DEPENDS to exist before the call to
|
|
|
|
# ExternalProject_Add.
|
2015-09-11 02:22:33 +08:00
|
|
|
add_llvm_tool_subdirectory(lto)
|
2016-02-27 05:07:04 +08:00
|
|
|
add_llvm_tool_subdirectory(gold)
|
2015-09-15 02:36:40 +08:00
|
|
|
add_llvm_tool_subdirectory(llvm-ar)
|
2015-10-03 06:28:48 +08:00
|
|
|
add_llvm_tool_subdirectory(llvm-config)
|
2016-06-03 04:39:24 +08:00
|
|
|
add_llvm_tool_subdirectory(llvm-lto)
|
2015-12-17 02:30:36 +08:00
|
|
|
add_llvm_tool_subdirectory(llvm-profdata)
|
2015-09-11 02:22:33 +08:00
|
|
|
|
2015-07-21 23:53:09 +08:00
|
|
|
# Projects supported via LLVM_EXTERNAL_*_SOURCE_DIR need to be explicitly
|
|
|
|
# specified.
|
|
|
|
add_llvm_external_project(clang)
|
|
|
|
add_llvm_external_project(llgo)
|
|
|
|
add_llvm_external_project(lld)
|
|
|
|
add_llvm_external_project(lldb)
|
2019-12-24 15:23:51 +08:00
|
|
|
add_llvm_external_project(mlir)
|
2015-07-21 23:53:09 +08:00
|
|
|
|
2015-06-23 05:58:02 +08:00
|
|
|
# Automatically add remaining sub-directories containing a 'CMakeLists.txt'
|
|
|
|
# file as external projects.
|
2015-07-21 04:36:06 +08:00
|
|
|
add_llvm_implicit_projects()
|
2010-09-14 07:59:48 +08:00
|
|
|
|
2016-06-02 07:00:45 +08:00
|
|
|
# Add subprojects specified using LLVM_EXTERNAL_PROJECTS
|
|
|
|
foreach(p ${LLVM_EXTERNAL_PROJECTS})
|
|
|
|
add_llvm_external_project(${p})
|
|
|
|
endforeach(p)
|
|
|
|
|
2010-09-14 07:59:48 +08:00
|
|
|
set(LLVM_COMMON_DEPENDS ${LLVM_COMMON_DEPENDS} PARENT_SCOPE)
|