mirror of
https://git.yoctoproject.org/poky
synced 2026-04-26 09:32:14 +02:00
compiler-rt: Fix install location for native builds
Currently, clang when used for native builds and uses --rtlib=compiler-rt does not find the LLVM runtime because its installed in different directory than where compiler expects it to be. As a result, build fails for packages using clang in both capacity ( native and cross ) e.g. qtwebengine Make the build work across native sanitizers as well. (From OE-Core rev: 4d55698330ce6720cab5dfe9b4e00efeb40ba6e6) Signed-off-by: Khem Raj <raj.khem@gmail.com> Signed-off-by: Mathieu Dubois-Briand <mathieu.dubois-briand@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
@@ -55,8 +55,11 @@ CXXFLAGS:append:libc-musl = " -D_LARGEFILE64_SOURCE"
|
||||
OECMAKE_TARGET_COMPILE = "compiler-rt"
|
||||
OECMAKE_TARGET_INSTALL = "install-compiler-rt install-compiler-rt-headers"
|
||||
OECMAKE_SOURCEPATH = "${S}/llvm"
|
||||
|
||||
INSTALL_VER ?= "${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}"
|
||||
INSTALL_VER:class-native = "${@oe.utils.trim_version("${PV}", 1)}"
|
||||
|
||||
EXTRA_OECMAKE += "-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
||||
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=OFF \
|
||||
-DCOMPILER_RT_STANDALONE_BUILD=ON \
|
||||
-DCOMPILER_RT_USE_BUILTINS_LIBRARY=ON \
|
||||
-DCOMPILER_RT_BUILD_BUILTINS=OFF \
|
||||
@@ -71,11 +74,13 @@ EXTRA_OECMAKE += "-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
||||
-DLLVM_ENABLE_RUNTIMES='compiler-rt' \
|
||||
-DLLVM_LIBDIR_SUFFIX=${LLVM_LIBDIR_SUFFIX} \
|
||||
-DLLVM_APPEND_VC_REV=OFF \
|
||||
-DCOMPILER_RT_INSTALL_PATH=${nonarch_libdir}/clang/${INSTALL_VER} \
|
||||
-S ${S}/runtimes \
|
||||
"
|
||||
|
||||
EXTRA_OECMAKE:append:class-native = "\
|
||||
-DCOMPILER_RT_USE_BUILTINS_LIBRARY=OFF \
|
||||
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=ON \
|
||||
"
|
||||
|
||||
EXTRA_OECMAKE:append:class-target = "\
|
||||
@@ -85,6 +90,7 @@ EXTRA_OECMAKE:append:class-target = "\
|
||||
-DCMAKE_C_COMPILER_TARGET=${HOST_SYS} \
|
||||
-DCOMPILER_RT_DEFAULT_TARGET_ONLY=ON \
|
||||
-DCMAKE_POSITION_INDEPENDENT_CODE=ON \
|
||||
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=OFF \
|
||||
"
|
||||
|
||||
EXTRA_OECMAKE:append:class-nativesdk = "\
|
||||
@@ -95,24 +101,23 @@ EXTRA_OECMAKE:append:class-nativesdk = "\
|
||||
-DCLANG_TABLEGEN=${STAGING_BINDIR_NATIVE}/clang-tblgen \
|
||||
-DCMAKE_C_COMPILER_TARGET=${HOST_SYS} \
|
||||
-DCOMPILER_RT_DEFAULT_TARGET_ONLY=ON \
|
||||
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=OFF \
|
||||
"
|
||||
|
||||
EXTRA_OECMAKE:append:libc-musl = " -DLIBCXX_HAS_MUSL_LIBC=ON "
|
||||
|
||||
do_install:append () {
|
||||
mkdir -p ${D}${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib
|
||||
mv ${D}${nonarch_libdir}/linux ${D}${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib
|
||||
# Already shipped with compile-rt Orc support
|
||||
rm -rf ${D}${nonarch_libdir}/clang/${MAJOR_VER}/lib/linux/liborc_rt-*.a
|
||||
rm -rf ${D}${nonarch_libdir}/clang/${MAJOR_VER}/include/orc/
|
||||
}
|
||||
|
||||
FILES_SOLIBSDEV = ""
|
||||
FILES:${PN} += "${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER} \
|
||||
FILES:${PN} += "${nonarch_libdir}/clang/${INSTALL_VER} \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}/lib/linux/lib*${SOLIBSDEV} \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}/*.txt \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}/share/*.txt"
|
||||
FILES:${PN}-staticdev += "${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/*.a"
|
||||
FILES:${PN}-staticdev += "${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/*.a"
|
||||
FILES:${PN}-dev += "${datadir} ${nonarch_libdir}/clang/${MAJOR_VER}/lib/linux/*.syms \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}/include \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}/lib/linux/clang_rt.crt*.o \
|
||||
|
||||
@@ -71,8 +71,11 @@ def get_compiler_rt_arch(bb, d):
|
||||
OECMAKE_TARGET_COMPILE = "compiler-rt"
|
||||
OECMAKE_TARGET_INSTALL = "install-compiler-rt install-compiler-rt-headers"
|
||||
OECMAKE_SOURCEPATH = "${S}/llvm"
|
||||
|
||||
INSTALL_VER ?= "${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}"
|
||||
INSTALL_VER:class-native = "${@oe.utils.trim_version("${PV}", 1)}"
|
||||
|
||||
EXTRA_OECMAKE += "-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
||||
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=OFF \
|
||||
-DCOMPILER_RT_STANDALONE_BUILD=ON \
|
||||
-DCOMPILER_RT_INCLUDE_TESTS=OFF \
|
||||
-DCOMPILER_RT_BUILD_XRAY=OFF \
|
||||
@@ -83,9 +86,12 @@ EXTRA_OECMAKE += "-DCMAKE_BUILD_TYPE=RelWithDebInfo \
|
||||
-DLLVM_ENABLE_RUNTIMES='compiler-rt' \
|
||||
-DLLVM_LIBDIR_SUFFIX=${LLVM_LIBDIR_SUFFIX} \
|
||||
-DLLVM_APPEND_VC_REV=OFF \
|
||||
-DCOMPILER_RT_INSTALL_PATH=${nonarch_libdir}/clang/${INSTALL_VER} \
|
||||
-S ${S}/runtimes \
|
||||
"
|
||||
|
||||
EXTRA_OECMAKE:append:class-native = "\
|
||||
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=ON \
|
||||
"
|
||||
EXTRA_OECMAKE:append:class-target = "\
|
||||
-DCMAKE_RANLIB=${STAGING_BINDIR_TOOLCHAIN}/${TARGET_PREFIX}llvm-ranlib \
|
||||
-DCMAKE_AR=${STAGING_BINDIR_TOOLCHAIN}/${TARGET_PREFIX}llvm-ar \
|
||||
@@ -93,6 +99,7 @@ EXTRA_OECMAKE:append:class-target = "\
|
||||
-DCMAKE_C_COMPILER_TARGET=${HOST_SYS} \
|
||||
-DCOMPILER_RT_DEFAULT_TARGET_ONLY=ON \
|
||||
-DCMAKE_POSITION_INDEPENDENT_CODE=ON \
|
||||
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=OFF \
|
||||
"
|
||||
|
||||
EXTRA_OECMAKE:append:class-nativesdk = "\
|
||||
@@ -103,29 +110,28 @@ EXTRA_OECMAKE:append:class-nativesdk = "\
|
||||
-DCLANG_TABLEGEN=${STAGING_BINDIR_NATIVE}/clang-tblgen \
|
||||
-DCMAKE_C_COMPILER_TARGET=${HOST_SYS} \
|
||||
-DCOMPILER_RT_DEFAULT_TARGET_ONLY=ON \
|
||||
-DLLVM_ENABLE_PER_TARGET_RUNTIME_DIR=OFF \
|
||||
"
|
||||
|
||||
do_install:append () {
|
||||
mkdir -p ${D}${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib
|
||||
mv ${D}${nonarch_libdir}/linux ${D}${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib
|
||||
if [ "${HF}" = "hf" ]; then
|
||||
mv -f ${D}${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/libclang_rt.builtins-arm.a \
|
||||
${D}${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/libclang_rt.builtins-armhf.a
|
||||
mv -f ${D}${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/liborc_rt-arm.a \
|
||||
${D}${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/liborc_rt-armhf.a
|
||||
mv -f ${D}${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/libclang_rt.builtins-arm.a \
|
||||
${D}${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/libclang_rt.builtins-armhf.a
|
||||
mv -f ${D}${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/liborc_rt-arm.a \
|
||||
${D}${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/liborc_rt-armhf.a
|
||||
fi
|
||||
}
|
||||
|
||||
FILES_SOLIBSDEV = ""
|
||||
|
||||
FILES:${PN} += "${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/lib*${SOLIBSDEV} \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/*.txt \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/share/*.txt"
|
||||
FILES:${PN}-staticdev += "${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/*.a"
|
||||
FILES:${PN}-dev += "${datadir} ${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/*.syms \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/include \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/clang_rt.crt*.o \
|
||||
${nonarch_libdir}/clang/${MAJOR_VER}.${MINOR_VER}.${PATCH_VER}/lib/linux/libclang_rt.asan-preinit*.a"
|
||||
FILES:${PN} += "${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/lib*${SOLIBSDEV} \
|
||||
${nonarch_libdir}/clang/${INSTALL_VER}/*.txt \
|
||||
${nonarch_libdir}/clang/${INSTALL_VER}/share/*.txt"
|
||||
FILES:${PN}-staticdev += "${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/*.a"
|
||||
FILES:${PN}-dev += "${datadir} ${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/*.syms \
|
||||
${nonarch_libdir}/clang/${INSTALL_VER}/include \
|
||||
${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/clang_rt.crt*.o \
|
||||
${nonarch_libdir}/clang/${INSTALL_VER}/lib/linux/libclang_rt.asan-preinit*.a"
|
||||
|
||||
INSANE_SKIP:${PN} = "dev-so libdir"
|
||||
INSANE_SKIP:${PN}-dbg = "libdir"
|
||||
|
||||
Reference in New Issue
Block a user