Skip to content

Commit ed155f3

Browse files
authored
[runtimes] Correctly apply libdir subdir for multilib (#93354)
We weren't applying the libdir subdir to header directories but this is necessary for correctness when building e.g. ASan variant. This change also updates path construction logic accross all runtimes and ensures they're consistent.
1 parent 435e5c1 commit ed155f3

File tree

4 files changed

+30
-26
lines changed

4 files changed

+30
-26
lines changed

libcxx/CMakeLists.txt

+9-8
Original file line numberDiff line numberDiff line change
@@ -433,18 +433,19 @@ set(LIBCXX_SHARED_OUTPUT_NAME "c++" CACHE STRING "Output name for the shared lib
433433
set(LIBCXX_STATIC_OUTPUT_NAME "c++" CACHE STRING "Output name for the static libc++ runtime library.")
434434

435435
if(LLVM_ENABLE_PER_TARGET_RUNTIME_DIR AND NOT APPLE)
436-
set(LIBCXX_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/${LLVM_DEFAULT_TARGET_TRIPLE})
436+
set(LIBCXX_TARGET_SUBDIR ${LLVM_DEFAULT_TARGET_TRIPLE})
437+
if(LIBCXX_LIBDIR_SUBDIR)
438+
string(APPEND LIBCXX_TARGET_SUBDIR /${LIBCXX_LIBDIR_SUBDIR})
439+
endif()
440+
set(LIBCXX_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/${LIBCXX_TARGET_SUBDIR})
437441
set(LIBCXX_GENERATED_INCLUDE_DIR "${LLVM_BINARY_DIR}/include/c++/v1")
438442
set(LIBCXX_GENERATED_MODULE_DIR "${LLVM_BINARY_DIR}/modules/c++/v1")
439-
set(LIBCXX_GENERATED_INCLUDE_TARGET_DIR "${LLVM_BINARY_DIR}/include/${LLVM_DEFAULT_TARGET_TRIPLE}/c++/v1")
440-
set(LIBCXX_INSTALL_LIBRARY_DIR lib${LLVM_LIBDIR_SUFFIX}/${LLVM_DEFAULT_TARGET_TRIPLE} CACHE STRING
443+
set(LIBCXX_GENERATED_INCLUDE_TARGET_DIR "${LLVM_BINARY_DIR}/include/${LIBCXX_TARGET_SUBDIR}/c++/v1")
444+
set(LIBCXX_INSTALL_LIBRARY_DIR lib${LLVM_LIBDIR_SUFFIX}/${LIBCXX_TARGET_SUBDIR} CACHE STRING
441445
"Path where built libc++ libraries should be installed.")
442-
set(LIBCXX_INSTALL_INCLUDE_TARGET_DIR "${CMAKE_INSTALL_INCLUDEDIR}/${LLVM_DEFAULT_TARGET_TRIPLE}/c++/v1" CACHE STRING
446+
set(LIBCXX_INSTALL_INCLUDE_TARGET_DIR "${CMAKE_INSTALL_INCLUDEDIR}/${LIBCXX_TARGET_SUBDIR}/c++/v1" CACHE STRING
443447
"Path where target-specific libc++ headers should be installed.")
444-
if(LIBCXX_LIBDIR_SUBDIR)
445-
string(APPEND LIBCXX_LIBRARY_DIR /${LIBCXX_LIBDIR_SUBDIR})
446-
string(APPEND LIBCXX_INSTALL_LIBRARY_DIR /${LIBCXX_LIBDIR_SUBDIR})
447-
endif()
448+
unset(LIBCXX_TARGET_SUBDIR)
448449
else()
449450
if(LLVM_LIBRARY_OUTPUT_INTDIR)
450451
set(LIBCXX_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR})

libcxxabi/CMakeLists.txt

+7-6
Original file line numberDiff line numberDiff line change
@@ -183,14 +183,15 @@ set(LIBCXXABI_INSTALL_RUNTIME_DIR "${CMAKE_INSTALL_BINDIR}" CACHE STRING
183183
"Path where built libc++abi runtime libraries should be installed.")
184184

185185
if(LLVM_ENABLE_PER_TARGET_RUNTIME_DIR AND NOT APPLE)
186+
set(LIBCXXABI_TARGET_SUBDIR ${LLVM_DEFAULT_TARGET_TRIPLE})
187+
if(LIBCXXABI_LIBDIR_SUBDIR)
188+
string(APPEND LIBCXXABI_TARGET_SUBDIR /${LIBCXXABI_LIBDIR_SUBDIR})
189+
endif()
186190
set(LIBCXXABI_HEADER_DIR ${LLVM_BINARY_DIR})
187-
set(LIBCXXABI_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/${LLVM_DEFAULT_TARGET_TRIPLE})
188-
set(LIBCXXABI_INSTALL_LIBRARY_DIR lib${LLVM_LIBDIR_SUFFIX}/${LLVM_DEFAULT_TARGET_TRIPLE} CACHE STRING
191+
set(LIBCXXABI_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/${LIBCXXABI_TARGET_SUBDIR})
192+
set(LIBCXXABI_INSTALL_LIBRARY_DIR lib${LLVM_LIBDIR_SUFFIX}/${LIBCXXABI_TARGET_SUBDIR} CACHE STRING
189193
"Path where built libc++abi libraries should be installed.")
190-
if(LIBCXX_LIBDIR_SUBDIR)
191-
string(APPEND LIBCXXABI_LIBRARY_DIR /${LIBCXXABI_LIBDIR_SUBDIR})
192-
string(APPEND LIBCXXABI_INSTALL_LIBRARY_DIR /${LIBCXXABI_LIBDIR_SUBDIR})
193-
endif()
194+
unset(LIBCXXABI_TARGET_SUBDIR)
194195
else()
195196
if(LLVM_LIBRARY_OUTPUT_INTDIR)
196197
set(LIBCXXABI_HEADER_DIR ${LLVM_BINARY_DIR})

libunwind/CMakeLists.txt

+7-6
Original file line numberDiff line numberDiff line change
@@ -130,13 +130,14 @@ set(LIBUNWIND_SHARED_OUTPUT_NAME "unwind" CACHE STRING "Output name for the shar
130130
set(LIBUNWIND_STATIC_OUTPUT_NAME "unwind" CACHE STRING "Output name for the static libunwind runtime library.")
131131

132132
if(LLVM_ENABLE_PER_TARGET_RUNTIME_DIR AND NOT APPLE)
133-
set(LIBUNWIND_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/${LLVM_DEFAULT_TARGET_TRIPLE})
134-
set(LIBUNWIND_INSTALL_LIBRARY_DIR lib${LLVM_LIBDIR_SUFFIX}/${LLVM_DEFAULT_TARGET_TRIPLE} CACHE STRING
135-
"Path where built libunwind libraries should be installed.")
136-
if(LIBCXX_LIBDIR_SUBDIR)
137-
string(APPEND LIBUNWIND_LIBRARY_DIR /${LIBUNWIND_LIBDIR_SUBDIR})
138-
string(APPEND LIBUNWIND_INSTALL_LIBRARY_DIR /${LIBUNWIND_LIBDIR_SUBDIR})
133+
set(LIBUNWIND_TARGET_SUBDIR ${LLVM_DEFAULT_TARGET_TRIPLE})
134+
if(LIBUNWIND_LIBDIR_SUBDIR)
135+
string(APPEND LIBUNWIND_TARGET_SUBDIR /${LIBUNWIND_LIBDIR_SUBDIR})
139136
endif()
137+
set(LIBUNWIND_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/${LIBUNWIND_TARGET_SUBDIR})
138+
set(LIBUNWIND_INSTALL_LIBRARY_DIR lib${LLVM_LIBDIR_SUFFIX}/${LIBUNWIND_TARGET_SUBDIR} CACHE STRING
139+
"Path where built libunwind libraries should be installed.")
140+
unset(LIBUNWIND_TARGET_SUBDIR)
140141
else()
141142
if(LLVM_LIBRARY_OUTPUT_INTDIR)
142143
set(LIBUNWIND_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR})

llvm-libgcc/CMakeLists.txt

+7-6
Original file line numberDiff line numberDiff line change
@@ -62,13 +62,14 @@ endif()
6262
#===============================================================================
6363

6464
if(LLVM_ENABLE_PER_TARGET_RUNTIME_DIR AND NOT APPLE)
65-
set(LLVM_LIBGCC_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/${LLVM_DEFAULT_TARGET_TRIPLE})
66-
set(LLVM_LIBGCC_INSTALL_LIBRARY_DIR lib${LLVM_LIBDIR_SUFFIX}/${LLVM_DEFAULT_TARGET_TRIPLE} CACHE PATH
67-
"Path where built llvm-libgcc libraries should be installed.")
68-
if(LIBCXX_LIBDIR_SUBDIR)
69-
string(APPEND LLVM_LIBGCC_LIBRARY_DIR /${LLVM_LIBGCC_LIBDIR_SUBDIR})
70-
string(APPEND LLVM_LIBGCC_INSTALL_LIBRARY_DIR /${LLVM_LIBGCC_LIBDIR_SUBDIR})
65+
set(TARGET_SUBDIR ${LLVM_DEFAULT_TARGET_TRIPLE})
66+
if(LLVM_LIBGCC_LIBDIR_SUBDIR)
67+
string(APPEND TARGET_SUBDIR /${LLVM_LIBGCC_LIBDIR_SUBDIR})
7168
endif()
69+
set(LLVM_LIBGCC_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/${TARGET_SUBDIR})
70+
set(LLVM_LIBGCC_INSTALL_LIBRARY_DIR lib${LLVM_LIBDIR_SUFFIX}/${TARGET_SUBDIR} CACHE PATH
71+
"Path where built llvm-libgcc libraries should be installed.")
72+
unset(TARGET_SUBDIR)
7273
else()
7374
if(LLVM_LIBRARY_OUTPUT_INTDIR)
7475
set(LLVM_LIBGCC_LIBRARY_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR})

0 commit comments

Comments
 (0)