[llvm-commits] [llvm] r59379 - in /llvm/trunk: CMakeLists.txt cmake/modules/LLVMConfig.cmake
Oscar Fuentes
ofv at wanadoo.es
Sat Nov 15 14:51:04 PST 2008
Author: ofv
Date: Sat Nov 15 16:51:03 2008
New Revision: 59379
URL: http://llvm.org/viewvc/llvm-project?rev=59379&view=rev
Log:
CMake: Forces linking of the rest of architecture targets and its
respective asm printers on MSVC.
Based on a patch by Scott Graham.
Modified:
llvm/trunk/CMakeLists.txt
llvm/trunk/cmake/modules/LLVMConfig.cmake
Modified: llvm/trunk/CMakeLists.txt
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/CMakeLists.txt?rev=59379&r1=59378&r2=59379&view=diff
==============================================================================
--- llvm/trunk/CMakeLists.txt (original)
+++ llvm/trunk/CMakeLists.txt Sat Nov 15 16:51:03 2008
@@ -38,6 +38,10 @@
XCore
)
+# List of targets whose asmprinters need to be forced to link
+# into executables on some platforms (i.e. Windows):
+set(LLVM_ASMPRINTERS_FORCE_LINK X86 PowerPC)
+
if( MSVC )
set(LLVM_TARGETS_TO_BUILD X86
CACHE STRING "Semicolon-separated list of targets to build, or \"all\".")
Modified: llvm/trunk/cmake/modules/LLVMConfig.cmake
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/cmake/modules/LLVMConfig.cmake?rev=59379&r1=59378&r2=59379&view=diff
==============================================================================
--- llvm/trunk/cmake/modules/LLVMConfig.cmake (original)
+++ llvm/trunk/cmake/modules/LLVMConfig.cmake Sat Nov 15 16:51:03 2008
@@ -10,19 +10,40 @@
function(msvc_llvm_config executable link_components)
foreach(c ${link_components})
if( c STREQUAL "jit" )
- set_target_properties(${executable}
- PROPERTIES
- LINK_FLAGS "/INCLUDE:_X86TargetMachineModule")
+ set(lfgs "${lfgs} /INCLUDE:_X86TargetMachineModule")
endif( c STREQUAL "jit" )
+ list(FIND LLVM_TARGETS_TO_BUILD ${c} idx)
+ if( NOT idx LESS 0 )
+ set(lfgs "${lfgs} /INCLUDE:_${c}TargetMachineModule")
+ list(FIND LLVM_ASMPRINTERS_FORCE_LINK ${c} idx)
+ if( NOT idx LESS 0 )
+ set(lfgs "${lfgs} /INCLUDE:_${c}AsmPrinterForceLink")
+ endif()
+ endif()
endforeach(c)
+
msvc_map_components_to_libraries(${link_components} LIBRARIES)
target_link_libraries(${executable} ${LIBRARIES})
+
+ if( lfgs )
+ set_target_properties(${executable}
+ PROPERTIES
+ LINK_FLAGS ${lfgs})
+ endif()
endfunction(msvc_llvm_config executable link_components)
function(msvc_map_components_to_libraries link_components out_libs)
foreach(c ${link_components})
- if( c STREQUAL "native" )
+ # add codegen/asmprinter
+ list(FIND LLVM_TARGETS_TO_BUILD ${c} idx)
+ if( NOT idx LESS 0 )
+ list(APPEND expanded_components "LLVM${c}CodeGen")
+ list(FIND llvm_libs "LLVM${c}AsmPrinter" asmidx)
+ if( NOT asmidx LESS 0 )
+ list(APPEND expanded_components "LLVM${c}AsmPrinter")
+ endif()
+ elseif( c STREQUAL "native" )
# TODO: we assume ARCH is X86. In this case, we must use nativecodegen
# component instead. Do nothing, as in llvm-config script.
elseif( c STREQUAL "nativecodegen" )
@@ -33,15 +54,11 @@
elseif( c STREQUAL "engine" )
# TODO: as we assume we are on X86, this is `jit'.
list(APPEND expanded_components "LLVMJIT")
- elseif( c STREQUAL "X86" )
- # TODO: we assume we are on X86.
- list(APPEND expanded_components "LLVMX86CodeGen")
- list(APPEND expanded_components "LLVMX86AsmPrinter")
elseif( c STREQUAL "all" )
list(APPEND expanded_components ${llvm_libs})
- else( c STREQUAL "native" )
+ else( NOT idx LESS 0 )
list(APPEND expanded_components LLVM${c})
- endif( c STREQUAL "native" )
+ endif( NOT idx LESS 0 )
endforeach(c)
# We must match capitalization.
string(TOUPPER "${llvm_libs}" capitalized_libs)
More information about the llvm-commits
mailing list