diff options
author | Martin Storsjö <martin@martin.st> | 2023-10-02 13:22:23 +0300 |
---|---|---|
committer | Tobias Hieta <tobias@hieta.se> | 2023-10-02 18:12:44 +0200 |
commit | 0a2d7dae6ef233367ecd53d751b0630c84811430 (patch) | |
tree | 16fc979e695aa87f24af637f03dc286e61b97149 | |
parent | [MemCpyOpt] Merge alias metadatas when replacing arguments (#67539) (diff) | |
download | llvm-project-0a2d7dae6ef233367ecd53d751b0630c84811430.tar.gz llvm-project-0a2d7dae6ef233367ecd53d751b0630c84811430.tar.bz2 llvm-project-0a2d7dae6ef233367ecd53d751b0630c84811430.zip |
[compiler-rt] Reinstate removal of CRT choice flags from CMAKE_*_FLAGS* (#67935)
This reverts one part of commit
9f4dfcb795bb0ecf9944553f49371164801cd83f, with a modified comment added
about the code.
Ideally, this would only be reinstated temporarily - but given the
situation in vcpkg, it looks likely that they would keep passing the
duplicate options for quite some time. The conflicting CRT choice
usually are benign but only would cause warnings about one option
overriding the other, if passing e.g. "/MDd /MT".
However when vcpkg currently sets these options in CMAKE_*_FLAGS_DEBUG,
it passes the redundant option /D_DEBUG; thus the compiler finally ends
up with e.g. "/D_DEBUG /MDd /MT", which has the effect of defining
_DEBUG while using a release mode CRT, which allegedly breaks the build.
There's a PR up for removing this redundant /D_DEBUG option in vcpkg in
https://github.com/microsoft/vcpkg/pull/34123. With that in place, this
change wouldn't be strictly needed.
(cherry picked from commit 7bc09a471fbc274d8632d1379d4134bec63fecc4)
-rw-r--r-- | compiler-rt/CMakeLists.txt | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/compiler-rt/CMakeLists.txt b/compiler-rt/CMakeLists.txt index 1545340aa8a8..cfa97023d281 100644 --- a/compiler-rt/CMakeLists.txt +++ b/compiler-rt/CMakeLists.txt @@ -389,6 +389,25 @@ endif() if(MSVC) # FIXME: In fact, sanitizers should support both /MT and /MD, see PR20214. set(CMAKE_MSVC_RUNTIME_LIBRARY MultiThreaded) + + # Remove any /M[DT][d] flags, and strip any definitions of _DEBUG. + # Since we're using CMAKE_MSVC_RUNTIME_LIBRARY (CMP0091 set to NEW), + # these options shouldn't be included in these flags variables. However, + # package managers that don't know which mechanism is used for passing + # CRT choice flags might be passing them both ways - which leads to + # duplicate CRT choice options. Thus make sure to strip out these flags + # from these variables, when we're forcing a CRT choice other than what + # the user requested here. + foreach(flag_var + CMAKE_C_FLAGS CMAKE_C_FLAGS_DEBUG CMAKE_C_FLAGS_RELEASE + CMAKE_C_FLAGS_MINSIZEREL CMAKE_C_FLAGS_RELWITHDEBINFO + CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_DEBUG CMAKE_CXX_FLAGS_RELEASE + CMAKE_CXX_FLAGS_MINSIZEREL CMAKE_CXX_FLAGS_RELWITHDEBINFO) + string(REGEX REPLACE "[/-]M[DT]d" "" ${flag_var} "${${flag_var}}") + string(REGEX REPLACE "[/-]MD" "" ${flag_var} "${${flag_var}}") + string(REGEX REPLACE "[/-]D_DEBUG" "" ${flag_var} "${${flag_var}}") + endforeach() + append_list_if(COMPILER_RT_HAS_Oy_FLAG /Oy- SANITIZER_COMMON_CFLAGS) append_list_if(COMPILER_RT_HAS_GS_FLAG /GS- SANITIZER_COMMON_CFLAGS) |