[llvm] r298653 - [CMake] Provide an option to disable runtimes build
Petr Hosek via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 23 15:40:11 PDT 2017
Author: phosek
Date: Thu Mar 23 17:40:10 2017
New Revision: 298653
URL: http://llvm.org/viewvc/llvm-project?rev=298653&view=rev
Log:
[CMake] Provide an option to disable runtimes build
This could be used to either disable the runtimes build altogether
or avoid building them but still generate the build targets.
Differential Revision: https://reviews.llvm.org/D31060
Modified:
llvm/trunk/CMakeLists.txt
llvm/trunk/runtimes/CMakeLists.txt
Modified: llvm/trunk/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/CMakeLists.txt?rev=298653&r1=298652&r2=298653&view=diff
==============================================================================
--- llvm/trunk/CMakeLists.txt (original)
+++ llvm/trunk/CMakeLists.txt Thu Mar 23 17:40:10 2017
@@ -483,6 +483,10 @@ option(LLVM_INCLUDE_UTILS "Generate buil
option(LLVM_BUILD_UTILS
"Build LLVM utility binaries. If OFF, just generate build targets." ON)
+option(LLVM_INCLUDE_RUNTIMES "Generate build targets for the LLVM runtimes." ON)
+option(LLVM_BUILD_RUNTIMES
+ "Build the LLVM runtimes. If OFF, just generate build targets." ON)
+
option(LLVM_BUILD_RUNTIME
"Build the LLVM runtime libraries." ON)
option(LLVM_BUILD_EXAMPLES
@@ -862,7 +866,9 @@ if( LLVM_INCLUDE_TOOLS )
add_subdirectory(tools)
endif()
-add_subdirectory(runtimes)
+if( LLVM_INCLUDE_RUNTIMES )
+ add_subdirectory(runtimes)
+endif()
if( LLVM_INCLUDE_EXAMPLES )
add_subdirectory(examples)
Modified: llvm/trunk/runtimes/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/runtimes/CMakeLists.txt?rev=298653&r1=298652&r2=298653&view=diff
==============================================================================
--- llvm/trunk/runtimes/CMakeLists.txt (original)
+++ llvm/trunk/runtimes/CMakeLists.txt Thu Mar 23 17:40:10 2017
@@ -145,6 +145,10 @@ else() # if this is included from LLVM's
set_property(DIRECTORY APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS ${LLVM_BINARY_DIR}/runtimes/Components.cmake)
include(LLVMExternalProjectUtils)
+ if(NOT LLVM_BUILD_RUNTIMES)
+ set(EXTRA_ARGS EXCLUDE_FROM_ALL)
+ endif()
+
# If compiler-rt is present we need to build the builtin libraries first. This
# is required because the other runtimes need the builtin libraries present
# before the just-built compiler can pass the configuration tests.
@@ -157,7 +161,8 @@ else() # if this is included from LLVM's
-DCMAKE_C_COMPILER_TARGET=${TARGET_TRIPLE}
-DCMAKE_ASM_COMPILER_TARGET=${TARGET_TRIPLE}
PASSTHROUGH_PREFIXES COMPILER_RT
- USE_TOOLCHAIN)
+ USE_TOOLCHAIN
+ ${EXTRA_ARGS})
else()
get_cmake_property(variableNames VARIABLES)
add_custom_target(builtins)
@@ -179,7 +184,8 @@ else() # if this is included from LLVM's
-DCOMPILER_RT_DEFAULT_TARGET_ONLY=On
${${target}_extra_args}
PASSTHROUGH_PREFIXES COMPILER_RT
- USE_TOOLCHAIN)
+ USE_TOOLCHAIN
+ ${EXTRA_ARGS})
add_dependencies(builtins builtins-${target})
endforeach()
endif()
@@ -238,7 +244,8 @@ else() # if this is included from LLVM's
${SUB_COMPONENTS}
${SUB_COMPONENT_CHECK_TARGETS}
${SUB_INSTALL_TARGETS}
- USE_TOOLCHAIN)
+ USE_TOOLCHAIN
+ ${EXTRA_ARGS})
# TODO: This is a hack needed because the libcxx headers are copied into the
# build directory during configuration. Without that step the clang in the
More information about the llvm-commits
mailing list