CMake build system: support for parallel builds.
authorOscar Fuentes <ofv@wanadoo.es>
Mon, 22 Sep 2008 18:21:51 +0000 (18:21 +0000)
committerOscar Fuentes <ofv@wanadoo.es>
Mon, 22 Sep 2008 18:21:51 +0000 (18:21 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56453 91177308-0d34-0410-b5e6-96231b3b80d8

CMakeLists.txt
cmake/modules/AddLLVM.cmake
cmake/modules/AddPartiallyLinkedObject.cmake
lib/Target/X86/AsmPrinter/CMakeLists.txt
lib/Target/X86/CMakeLists.txt
tools/llvm-config/CMakeLists.txt

index f6803d989bea541103cb1754094bd8bd4c101915..31f754a953db0625fa8bf9e6536f6f016b507511 100644 (file)
@@ -97,6 +97,10 @@ include(AddPartiallyLinkedObject)
 
 add_subdirectory(lib/Support)
 add_subdirectory(lib/System)
+
+# Everything else depends on Support and System:
+set(LLVM_COMMON_DEPENDS ${LLVM_COMMON_DEPENDS} ${LLVM_LIBS} )
+
 add_subdirectory(utils/TableGen)
 
 add_custom_command(OUTPUT ${llvm_builded_incs_dir}/Intrinsics.gen
@@ -107,6 +111,8 @@ add_custom_command(OUTPUT ${llvm_builded_incs_dir}/Intrinsics.gen
 add_custom_target(intrinsics_gen ALL
   DEPENDS ${llvm_builded_incs_dir}/Intrinsics.gen)
 
+set(LLVM_COMMON_DEPENDS ${LLVM_COMMON_DEPENDS} intrinsics_gen )
+
 add_subdirectory(lib/VMCore)
 add_subdirectory(lib/CodeGen)
 add_subdirectory(lib/CodeGen/SelectionDAG)
index c3641eacd22d2b71c5dff9cb489f82f7cfa6b42b..fc917d324a3e3a9c094ef69107148aa19df8a54a 100755 (executable)
@@ -3,6 +3,10 @@ include(LLVMConfig)
 macro(add_llvm_library name)
   add_library( ${name} ${ARGN} )
   set( llvm_libs ${llvm_libs} ${name} PARENT_SCOPE)
+  set( llvm_lib_targets ${llvm_lib_targets} ${name} PARENT_SCOPE )
+  if( LLVM_COMMON_DEPENDS )
+    add_dependencies( ${name} ${LLVM_COMMON_DEPENDS} )
+  endif( LLVM_COMMON_DEPENDS )
 endmacro(add_llvm_library name)
 
 
index a8a3d999e4f820106bfe8d48a2b6da734b0996de..6968857db8db0f94007fc73cc9455fe87695f3f8 100755 (executable)
@@ -1,4 +1,13 @@
 
+macro(target_name_of_partially_linked_object lib var)
+  if( MSVC )
+    set(${var} ${lib})
+  else( MSVC )
+    set(${var} ${lib}_pll)
+  endif( MSVC )
+endmacro(target_name_of_partially_linked_object lib var)
+
+
 macro(add_partially_linked_object lib)
   if( MSVC )
     add_llvm_library( ${lib} ${ARGN})
@@ -7,6 +16,9 @@ macro(add_partially_linked_object lib)
     set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/temp_lib)
     set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/temp_lib)
     add_library( ${lib} STATIC ${ARGN})
+    if( LLVM_COMMON_DEPENDS )
+      add_dependencies( ${lib} ${LLVM_COMMON_DEPENDS} )
+    endif( LLVM_COMMON_DEPENDS )
     add_custom_command(OUTPUT ${pll}
       COMMENT "Building ${lib}.o..."
       DEPENDS ${lib}
@@ -15,7 +27,9 @@ macro(add_partially_linked_object lib)
       COMMAND ld -r *${CMAKE_CXX_OUTPUT_EXTENSION} -o ${pll}
       COMMAND rm -f *${CMAKE_CXX_OUTPUT_EXTENSION}
       )
-    add_custom_target(${lib}_pll ALL DEPENDS ${pll})
+    target_name_of_partially_linked_object(${lib} tnplo)
+    add_custom_target(${tnplo} ALL DEPENDS ${pll})
     set( llvm_libs ${llvm_libs} ${pll} PARENT_SCOPE)
+    set( llvm_lib_targets ${llvm_lib_targets} ${tnplo} PARENT_SCOPE )
   endif( MSVC )
 endmacro(add_partially_linked_object lib)
index ca4acb23c6610024fbbeb250bdec6d561ca1eaf3..19d9edfac7705239c1cc0b51fc91e3261310149a 100644 (file)
@@ -5,3 +5,7 @@ add_llvm_library(LLVMX86AsmPrinter
   X86AsmPrinter.cpp
   X86IntelAsmPrinter.cpp
   )
+
+target_name_of_partially_linked_object(LLVMX86CodeGen n)
+
+add_dependencies(LLVMX86AsmPrinter ${n})
index de8ff2cd5d7d37b2c076cda882d7809512f34115..5b7900334dbd7df09aa6fbc6fb7fb8edd0ecb357 100644 (file)
@@ -20,7 +20,6 @@ x86tgen(X86GenSubtarget.inc -gen-subtarget)
 
 add_custom_target(X86Table_gen echo Tablegenning
   DEPENDS
-  ${llvm_builded_incs_dir}/Intrinsics.gen
   ${CMAKE_CURRENT_BINARY_DIR}/X86GenRegisterInfo.h.inc
   ${CMAKE_CURRENT_BINARY_DIR}/X86GenRegisterNames.inc
   ${CMAKE_CURRENT_BINARY_DIR}/X86GenRegisterInfo.inc
@@ -34,6 +33,8 @@ add_custom_target(X86Table_gen echo Tablegenning
   ${CMAKE_CURRENT_BINARY_DIR}/X86GenSubtarget.inc
   )
 
+add_dependencies(X86Table_gen ${LLVM_COMMON_DEPENDS})
+
 include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR})
 
 add_partially_linked_object(LLVMX86CodeGen
index 2d6898c2db210803198d0229221370fa7a88788d..bf8debb47a0bc2153287b9c65164de1563199117 100644 (file)
@@ -69,7 +69,6 @@ set(LLVM_CONFIG_IN ${CMAKE_CURRENT_BINARY_DIR}/llvm-config.in)
 
 add_custom_command(OUTPUT ${LIBDEPS_TMP}
   COMMAND ${PERL_EXECUTABLE} ${LLVM_MAIN_SRC_DIR}/utils/GenLibDeps.pl -flat ${CMAKE_ARCHIVE_OUTPUT_DIRECTORY} > ${LIBDEPS_TMP}
-  DEPENDS ${llvm_libs}
   COMMENT "Regenerating ${LIBDEPS_TMP}")
 
 add_custom_command(OUTPUT ${LIBDEPS}
@@ -99,4 +98,6 @@ add_custom_command(OUTPUT ${LLVM_CONFIG}
   )
 
 add_custom_target(llvm-config.target ALL
-  DEPENDS ${LLVM_CONFIG})
\ No newline at end of file
+  DEPENDS ${LLVM_CONFIG})
+
+add_dependencies(llvm-config.target ${llvm_lib_targets})