Skip to content

Commit 1f90a88

Browse files
[libcxx] Remove clang-18 workaround in picolib build (#133254)
clang-19 changed how Arm triples were normalised and so while we supported 18 and 19, we could not hard code the path here. Now that Linaro's bots are running clang-19, and libcxx is going to drop clang-18 support (#130142) I have simplified it by hard coding the path again. I also looked into why this exists in the first place. It was added in https://reviews.llvm.org/D154246 but not questioned at the time. It is due to the way we build compiler-rt, which is due to the final layout we need in the install: 1. The builtins library must be called libclang_rt.builtins.a for clang to find it. There must not be an architecture name in the filename. 2. That builtins library must be directly in lib/, next to picolib's installed files. To achieve number 1 we must set LLVM_ENABLE_PER_TARGET_RUNTIME_DIR=ON. However, that causes the file to be installed in a per-target dir which breaks number 2. So to fix that, we move the builtins library up one level into lib/. The alternative is to turn off per-target dirs, which results in a builtin file with an arch in the name, then rename and move that file (since it gets installed into lib/generic/). So in the end, it's the same amount of hacks. I think it's best to keep the one that uses LLVM_ENABLE_PER_TARGET_RUNTIME_DIR=ON, as this is the recommended way to built these days.
1 parent 48b7530 commit 1f90a88

File tree

1 file changed

+9
-7
lines changed

1 file changed

+9
-7
lines changed

libcxx/utils/ci/run-buildbot

+9-7
Original file line numberDiff line numberDiff line change
@@ -204,6 +204,13 @@ function test-armv7m-picolibc() {
204204

205205
step "Generating CMake for compiler-rt"
206206
flags="--sysroot=${INSTALL_DIR}"
207+
# LLVM_ENABLE_PER_TARGET_RUNTIME_DIR=ON means that we produce a file
208+
# libclang_rt.builtins.a that will be installed to
209+
# ${INSTALL_DIR}/lib/armv7m-unknown-none-eabi/.
210+
# With LLVM_ENABLE_PER_TARGET_RUNTIME_DIR=OFF, the filename includes the
211+
# architecture name, which is not what Clang's driver expects to find.
212+
# The install location will however be wrong with
213+
# LLVM_ENABLE_PER_TARGET_RUNTIME_DIR=ON, so we correct that below.
207214
${CMAKE} \
208215
-S "${MONOREPO_ROOT}/compiler-rt" \
209216
-B "${BUILD_DIR}/compiler-rt" \
@@ -226,13 +233,8 @@ function test-armv7m-picolibc() {
226233

227234
step "Installing compiler-rt"
228235
${NINJA} -vC "${BUILD_DIR}/compiler-rt" install
229-
230-
# Prior to clang 19, armv7m-none-eabi normalised to armv7m-none-unknown-eabi.
231-
# clang 19 changed this to armv7m-unknown-none-eabi. So for as long as 18.x
232-
# is supported, we have to ask clang what the triple will be.
233-
NORMALISED_TARGET_TRIPLE=$(${CC-cc} --target=armv7m-none-eabi -print-target-triple)
234-
# Without this step linking fails later in the build.
235-
mv "${BUILD_DIR}/install/lib/${NORMALISED_TARGET_TRIPLE}"/* "${BUILD_DIR}/install/lib"
236+
# Move compiler-rt libs into the same directory as all the picolib objects.
237+
mv "${INSTALL_DIR}/lib/armv7m-unknown-none-eabi"/* "${INSTALL_DIR}/lib"
236238

237239
check-runtimes
238240
}

0 commit comments

Comments
 (0)