[PATCH] D140534: Properly support LLVM_ENABLE_LLD on Windows
serge via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Dec 22 02:00:24 PST 2022
serge-sans-paille created this revision.
serge-sans-paille added reviewers: glandium, tstellar.
Herald added a project: All.
serge-sans-paille requested review of this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.
Currently, setting -DLLVM_ENABLE_LLD=ON on windows also requires setting
-DCMAKE_LINKER=lld-link.exe. This is both misleading and redundant.
Fix this by trying to find llvm-link.exe when -DLLVM_ENABLE_LLD=ON is
set and CMAKE_LINKER is not, and aborting otherwise.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D140534
Files:
llvm/cmake/modules/HandleLLVMOptions.cmake
Index: llvm/cmake/modules/HandleLLVMOptions.cmake
===================================================================
--- llvm/cmake/modules/HandleLLVMOptions.cmake
+++ llvm/cmake/modules/HandleLLVMOptions.cmake
@@ -293,10 +293,23 @@
if ( LLVM_USE_LINKER )
message(FATAL_ERROR "LLVM_ENABLE_LLD and LLVM_USE_LINKER can't be set at the same time")
endif()
+
# In case of MSVC cmake always invokes the linker directly, so the linker
# should be specified by CMAKE_LINKER cmake variable instead of by -fuse-ld
# compiler option.
- if ( NOT MSVC )
+ if ( MSVC )
+ if(NOT CMAKE_LINKER MATCHES "lld-link")
+ get_filename_component(CXX_COMPILER_DIR ${CMAKE_CXX_COMPILER} DIRECTORY)
+ get_filename_component(C_COMPILER_DIR ${CMAKE_C_COMPILER} DIRECTORY)
+ find_program(LLD_LINK NAMES "lld-link" "lld-link.exe" HINTS ${CXX_COMPILER_DIR} ${C_COMPILER_DIR} DOC "lld linker")
+ if(NOT LLD_LINK)
+ message(FATAL_ERROR
+ "Using LLD as linker required, but cannot find lld-link. "
+ "Consider setting CMAKE_LINKER to lld-link path.")
+ endif()
+ set(CMAKE_LINKER ${LLD_LINK})
+ endif()
+ else()
set(LLVM_USE_LINKER "lld")
endif()
endif()
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D140534.484770.patch
Type: text/x-patch
Size: 1243 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20221222/867f379a/attachment.bin>
More information about the llvm-commits
mailing list