diff options
| author | Chris Bieneman <beanz@apple.com> | 2016-11-01 20:19:33 +0000 |
|---|---|---|
| committer | Chris Bieneman <beanz@apple.com> | 2016-11-01 20:19:33 +0000 |
| commit | 3603e6123832631d28f4c07fbf55910742367950 (patch) | |
| tree | 92c2048c673e98f518544bb636e4d55c386b3720 | |
| parent | f60216733f1041c0b0badd991ee8e8f940d9d826 (diff) | |
| download | bcm5719-llvm-3603e6123832631d28f4c07fbf55910742367950.tar.gz bcm5719-llvm-3603e6123832631d28f4c07fbf55910742367950.zip | |
Fix llvm-shlib cmake build
Summary:
This fixes a few things that used to work with a Makefile build, but were broken in cmake.
1. Treat MINGW like a Linux system.
2. The shlib should never contain other shared libraries.
Patch By: Valentin Churavy
Reviewers: axw, beanz
Subscribers: modocache, beanz, mgorny
Differential Revision: https://reviews.llvm.org/D25865
llvm-svn: 285737
| -rw-r--r-- | llvm/tools/llvm-shlib/CMakeLists.txt | 42 |
1 files changed, 20 insertions, 22 deletions
diff --git a/llvm/tools/llvm-shlib/CMakeLists.txt b/llvm/tools/llvm-shlib/CMakeLists.txt index 3fe672d679a..edadb82c3b4 100644 --- a/llvm/tools/llvm-shlib/CMakeLists.txt +++ b/llvm/tools/llvm-shlib/CMakeLists.txt @@ -8,29 +8,27 @@ set(SOURCES llvm_map_components_to_libnames(LIB_NAMES ${LLVM_DYLIB_COMPONENTS}) -if(LLVM_LINK_LLVM_DYLIB) - if(LLVM_DYLIB_EXPORTED_SYMBOL_FILE) - message(WARNING "Using LLVM_LINK_LLVM_DYLIB with LLVM_DYLIB_EXPORTED_SYMBOL_FILE may not work. Use at your own risk.") - endif() - - # libLLVM.so should not have any dependencies on any other LLVM - # shared libraries. When using the "all" pseudo-component, - # LLVM_AVAILABLE_LIBS is added to the dependencies, which may - # contain shared libraries (e.g. libLTO). - # - # Also exclude libLLVMTableGen for the following reasons: - # - it is only used by internal *-tblgen utilities; - # - it pollutes the global options space. - foreach(lib ${LIB_NAMES}) - get_target_property(t ${lib} TYPE) - if("${lib}" STREQUAL "LLVMTableGen") - elseif("x${t}" STREQUAL "xSTATIC_LIBRARY") - list(APPEND FILTERED_LIB_NAMES ${lib}) - endif() - endforeach() - set(LIB_NAMES ${FILTERED_LIB_NAMES}) +if(LLVM_LINK_LLVM_DYLIB AND LLVM_DYLIB_EXPORTED_SYMBOL_FILE) + message(WARNING "Using LLVM_LINK_LLVM_DYLIB with LLVM_DYLIB_EXPORTED_SYMBOL_FILE may not work. Use at your own risk.") endif() +# libLLVM.so should not have any dependencies on any other LLVM +# shared libraries. When using the "all" pseudo-component, +# LLVM_AVAILABLE_LIBS is added to the dependencies, which may +# contain shared libraries (e.g. libLTO). +# +# Also exclude libLLVMTableGen for the following reasons: +# - it is only used by internal *-tblgen utilities; +# - it pollutes the global options space. +foreach(lib ${LIB_NAMES}) + get_target_property(t ${lib} TYPE) + if("${lib}" STREQUAL "LLVMTableGen") + elseif("x${t}" STREQUAL "xSTATIC_LIBRARY") + list(APPEND FILTERED_LIB_NAMES ${lib}) + endif() +endforeach() +set(LIB_NAMES ${FILTERED_LIB_NAMES}) + if(LLVM_DYLIB_EXPORTED_SYMBOL_FILE) set(LLVM_EXPORTED_SYMBOL_FILE ${LLVM_DYLIB_EXPORTED_SYMBOL_FILE}) add_custom_target(libLLVMExports DEPENDS ${LLVM_EXPORTED_SYMBOL_FILE}) @@ -39,7 +37,7 @@ endif() add_llvm_library(LLVM SHARED DISABLE_LLVM_LINK_LLVM_DYLIB SONAME ${SOURCES}) list(REMOVE_DUPLICATES LIB_NAMES) -if("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux") # FIXME: It should be "GNU ld for elf" +if("${CMAKE_SYSTEM_NAME}" STREQUAL "Linux" OR MINGW) # FIXME: It should be "GNU ld for elf" # GNU ld doesn't resolve symbols in the version script. set(LIB_NAMES -Wl,--whole-archive ${LIB_NAMES} -Wl,--no-whole-archive) elseif("${CMAKE_SYSTEM_NAME}" STREQUAL "Darwin") |

