Eliminate object-relinking support from CMake. Fixes PR 4429 and
authorDouglas Gregor <dgregor@apple.com>
Tue, 23 Jun 2009 17:57:35 +0000 (17:57 +0000)
committerDouglas Gregor <dgregor@apple.com>
Tue, 23 Jun 2009 17:57:35 +0000 (17:57 +0000)
cleans up the CMake-based build system a bit. Started by a patch from
Xerxes RĂ„nby.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@73969 91177308-0d34-0410-b5e6-96231b3b80d8

14 files changed:
CMakeLists.txt
cmake/modules/AddLLVM.cmake
cmake/modules/AddPartiallyLinkedObject.cmake [deleted file]
lib/ExecutionEngine/CMakeLists.txt
lib/ExecutionEngine/Interpreter/CMakeLists.txt
lib/ExecutionEngine/JIT/CMakeLists.txt
lib/Target/ARM/AsmPrinter/CMakeLists.txt
lib/Target/Alpha/AsmPrinter/CMakeLists.txt
lib/Target/CellSPU/AsmPrinter/CMakeLists.txt
lib/Target/IA64/AsmPrinter/CMakeLists.txt
lib/Target/Mips/AsmPrinter/CMakeLists.txt
lib/Target/PowerPC/AsmPrinter/CMakeLists.txt
lib/Target/Sparc/AsmPrinter/CMakeLists.txt
lib/Target/X86/AsmPrinter/CMakeLists.txt

index 543ee7f8807984ccde65a3e9445980c6e9a865fd..2ee79a568d3468e928d3d24fda5d406fd8d5c1f3 100644 (file)
@@ -180,9 +180,6 @@ set( CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${LLVM_BINARY_DIR}/lib )
 add_llvm_definitions( -D__STDC_LIMIT_MACROS )
 add_llvm_definitions( -D__STDC_CONSTANT_MACROS )
 
-set(LLVM_PLO_FLAGS "" CACHE
-  STRING "Flags for creating partially linked objects.")
-
 if( CMAKE_SIZEOF_VOID_P EQUAL 8 AND NOT WIN32 )
   # TODO: support other platforms and toolchains.
   option(LLVM_BUILD_32_BITS "Build 32 bits executables and libraries." OFF)
@@ -221,7 +218,6 @@ endif( MSVC )
 include_directories( ${LLVM_BINARY_DIR}/include ${LLVM_MAIN_INCLUDE_DIR})
 
 include(AddLLVM)
-include(AddPartiallyLinkedObject)
 include(TableGen)
 
 add_subdirectory(lib/Support)
index e5256746bcc6452d3a4a725451cf23265628a5f4..2b9b649da2dbc2384fb2ae2fb779d1dd61c70427 100755 (executable)
@@ -61,8 +61,10 @@ macro(add_llvm_target target_name)
     add_dependencies(${target_name}Table_gen ${LLVM_COMMON_DEPENDS})
   endif( TABLEGEN_OUTPUT )
   include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR})
-  add_partially_linked_object(LLVM${target_name} ${ARGN})
+  add_llvm_library(LLVM${target_name} ${ARGN} ${TABLEGEN_OUTPUT})
+  if (FALSE)
   if( TABLEGEN_OUTPUT )
     add_dependencies(LLVM${target_name} ${target_name}Table_gen)
   endif( TABLEGEN_OUTPUT )
+  endif ()
 endmacro(add_llvm_target)
diff --git a/cmake/modules/AddPartiallyLinkedObject.cmake b/cmake/modules/AddPartiallyLinkedObject.cmake
deleted file mode 100755 (executable)
index 0f92455..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-include(LLVMProcessSources)
-
-macro(target_name_of_partially_linked_object lib var)
-  if( USE_EXPLICIT_DEPENDENCIES )
-    set(${var} ${lib})
-  else( )
-    set(${var} ${lib}_pll)
-  endif( )
-endmacro(target_name_of_partially_linked_object lib var)
-
-
-macro(add_partially_linked_object lib)
-  if( USE_EXPLICIT_DEPENDENCIES )
-    add_llvm_library( ${lib} ${ARGN})
-  else( )
-    set(pll ${CMAKE_ARCHIVE_OUTPUT_DIRECTORY}/${CMAKE_CFG_INTDIR}/${lib}.o)
-    set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/temp_lib)
-    set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/temp_lib)
-    llvm_process_sources( ALL_FILES ${ARGN} )
-    if( BUILD_SHARED_LIBS AND SUPPORTS_FPIC_FLAG )
-      add_definitions(-fPIC)
-    endif()
-    add_library( ${lib} STATIC ${ALL_FILES})
-    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}
-      WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/temp_lib/${CMAKE_CFG_INTDIR}
-      COMMAND ar x ${CMAKE_STATIC_LIBRARY_PREFIX}${lib}${CMAKE_STATIC_LIBRARY_SUFFIX}
-      COMMAND ${CMAKE_LINKER} "${LLVM_PLO_FLAGS}" -r "*${CMAKE_CXX_OUTPUT_EXTENSION}" -o ${pll}
-      COMMAND ${CMAKE_COMMAND} -E remove -f *${CMAKE_CXX_OUTPUT_EXTENSION}
-      )
-    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( )
-  install(FILES ${pll}
-    DESTINATION lib${LLVM_LIBDIR_SUFFIX})
-endmacro(add_partially_linked_object lib)
index e26b98fb9d436d74af03234f49e17e6784c0bc67..0e118ccd904f4628ddcd8c008145d4708edee69a 100644 (file)
@@ -1,4 +1,4 @@
-add_partially_linked_object(LLVMExecutionEngine
+add_llvm_library(LLVMExecutionEngine
   ExecutionEngine.cpp
   ExecutionEngineBindings.cpp
   )
index 626e804e78e68ef0b3f665e32e8f6c40b3bd65e4..dff97fa26e8f57338bebef20621f802daa0f8e2f 100644 (file)
@@ -1,4 +1,4 @@
-add_partially_linked_object(LLVMInterpreter
+add_llvm_library(LLVMInterpreter
   Execution.cpp
   ExternalFunctions.cpp
   Interpreter.cpp
index d7980d077282a446d672d7598f4feb3410fae7ca..e0c13a10f0b30214485466b0ef651cfeb2ab23ad 100644 (file)
@@ -1,7 +1,7 @@
 # TODO: Support other architectures. See Makefile.
 add_definitions(-DENABLE_X86_JIT)
 
-add_partially_linked_object(LLVMJIT
+add_llvm_library(LLVMJIT
   Intercept.cpp
   JIT.cpp
   JITDwarfEmitter.cpp
index 524a748665bee12b4245a4a10a4d1a495fc42eb2..c22964f6c879b140d997c9878b3c8c0efaf85069 100644 (file)
@@ -1,9 +1,5 @@
 include_directories( ${CMAKE_CURRENT_BINARY_DIR}/.. ${CMAKE_CURRENT_SOURCE_DIR}/.. )
 
-add_partially_linked_object(LLVMARMAsmPrinter
+add_llvm_library(LLVMARMAsmPrinter
   ARMAsmPrinter.cpp
   )
-
-target_name_of_partially_linked_object(LLVMARMCodeGen n)
-
-add_dependencies(LLVMARMAsmPrinter ${n})
index b62a7f6835689a3f04613779feb1da2285f03114..bf047625bac41175cf7c375fc479874cbea4ec57 100644 (file)
@@ -1,9 +1,5 @@
 include_directories( ${CMAKE_CURRENT_BINARY_DIR}/.. ${CMAKE_CURRENT_SOURCE_DIR}/.. )
 
-add_partially_linked_object(LLVMAlphaAsmPrinter
+add_llvm_library(LLVMAlphaAsmPrinter
   AlphaAsmPrinter.cpp
   )
-
-target_name_of_partially_linked_object(LLVMAlphaCodeGen n)
-
-add_dependencies(LLVMAlphaAsmPrinter ${n})
index 4336b057a3468765cd14b8734c97a57f5dd27eeb..0dad08340414eb8c7d65499bb6f46ee3f049ae08 100644 (file)
@@ -3,10 +3,6 @@ include_directories(
   ${CMAKE_CURRENT_SOURCE_DIR}/..\r
   )\r
 \r
-add_partially_linked_object(LLVMCellSPUAsmPrinter\r
+add_llvm_library(LLVMCellSPUAsmPrinter\r
   SPUAsmPrinter.cpp\r
   )\r
-\r
-target_name_of_partially_linked_object(LLVMCellSPUCodeGen n)\r
-\r
-add_dependencies(LLVMCellSPUAsmPrinter ${n})\r
index 1d552bd5551c7e966c1fe9e147c64e4d2ce474a1..b81ed4a8d0d19ba30bf16f59ea04560842080851 100644 (file)
@@ -3,10 +3,6 @@ include_directories(
   ${CMAKE_CURRENT_SOURCE_DIR}/..\r
   )\r
 \r
-add_partially_linked_object(LLVMIA64AsmPrinter\r
+add_llvm_library(LLVMIA64AsmPrinter\r
   IA64AsmPrinter.cpp\r
   )\r
-\r
-target_name_of_partially_linked_object(LLVMIA64CodeGen n)\r
-\r
-add_dependencies(LLVMIA64AsmPrinter ${n})\r
index 6a868c2fc78c2504af5126d56e3c2a576ed4c400..942548dfc4773db6216acb161b42e1cf4116b8fc 100644 (file)
@@ -3,10 +3,6 @@ include_directories(
   ${CMAKE_CURRENT_SOURCE_DIR}/..\r
   )\r
 \r
-add_partially_linked_object(LLVMMipsAsmPrinter\r
+add_llvm_library(LLVMMipsAsmPrinter\r
   MipsAsmPrinter.cpp\r
   )\r
-\r
-target_name_of_partially_linked_object(LLVMMipsCodeGen n)\r
-\r
-add_dependencies(LLVMMipsAsmPrinter ${n})\r
index 1ed483ab21e9989b713a3c6c56b8a90b5702a43a..1f80b17a3843cbdf7e55177d11416c18701aeaa1 100644 (file)
@@ -1,9 +1,5 @@
 include_directories( ${CMAKE_CURRENT_BINARY_DIR}/.. ${CMAKE_CURRENT_SOURCE_DIR}/.. )
 
-add_partially_linked_object(LLVMPowerPCAsmPrinter
+add_llvm_library(LLVMPowerPCAsmPrinter
   PPCAsmPrinter.cpp
   )
-
-target_name_of_partially_linked_object(LLVMPowerPCCodeGen n)
-
-add_dependencies(LLVMPowerPCAsmPrinter ${n})
index 394b4cd40e762b4cecfba3de2e47033cb15bdc54..de905a92128ab9e9cf5172822eed847097a6f680 100644 (file)
@@ -1,9 +1,5 @@
 include_directories( ${CMAKE_CURRENT_BINARY_DIR}/.. ${CMAKE_CURRENT_SOURCE_DIR}/.. )
 
-add_partially_linked_object(LLVMSparcAsmPrinter
+add_llvm_library(LLVMSparcAsmPrinter
   SparcAsmPrinter.cpp
   )
-
-target_name_of_partially_linked_object(LLVMSparcCodeGen n)
-
-add_dependencies(LLVMSparcAsmPrinter ${n})
index 368bcaa5ce340565df69a09befc659d0d8878534..2079a9fd271be30ef033493ff6dc81d006e70215 100644 (file)
@@ -1,12 +1,8 @@
 include_directories( ${CMAKE_CURRENT_BINARY_DIR}/.. ${CMAKE_CURRENT_SOURCE_DIR}/.. )
 
-add_partially_linked_object(LLVMX86AsmPrinter
+add_llvm_library(LLVMX86AsmPrinter
   X86ATTAsmPrinter.cpp
   X86ATTInstPrinter.cpp
   X86AsmPrinter.cpp
   X86IntelAsmPrinter.cpp
   )
-
-target_name_of_partially_linked_object(LLVMX86CodeGen n)
-
-add_dependencies(LLVMX86AsmPrinter ${n})