If Clang is set up to link directly against libunwind (via the --unwindlib option, or the corresponding builtin default option), configuring libunwind will fail while bootstrapping (before the initial libunwind is built), because every cmake test will fail due to -lunwind not being found, and linking the shared library will fail similarly. Check if --unwindlib=none is supported, and add it in that case. Using check_c_compiler_flag on its own doesn't work, because that only adds the tested flag to the compilation command, and if -lunwind is missing, the linking step would still fail - instead try adding it to CMAKE_REQUIRED_FLAGS and restore the variable if it doesn't work. This avoids having to pass --unwindlib=none while building libunwind. Differential Revision: https://reviews.llvm.org/D112126
18 lines
688 B
CMake
18 lines
688 B
CMake
include(CMakePushCheckState)
|
|
include(CheckCCompilerFlag)
|
|
|
|
function(llvm_check_linker_flag flag dest)
|
|
# If testing a flag with check_c_compiler_flag, it gets added to the compile
|
|
# command only, but not to the linker command in that test. If the flag
|
|
# is vital for linking to succeed, the test would fail even if it would
|
|
# have succeeded if it was included on both commands.
|
|
#
|
|
# Therefore, try adding the flag to CMAKE_REQUIRED_FLAGS, which gets
|
|
# added to both compiling and linking commands in the tests.
|
|
|
|
cmake_push_check_state()
|
|
set(CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} ${flag}")
|
|
check_c_compiler_flag("" ${dest})
|
|
cmake_pop_check_state()
|
|
endfunction()
|