summaryrefslogtreecommitdiffstats
path: root/recipes-devtools/clang/libcxx_git.bb
diff options
context:
space:
mode:
authorKhem Raj <raj.khem@gmail.com>2019-10-09 00:28:42 -0700
committerKhem Raj <raj.khem@gmail.com>2019-10-09 11:58:54 -0700
commitd87c406c0f54e0e1ad4fb6aa2d0ecba93136139d (patch)
tree69b56ea8193edd1392779522332d5edc87f09479 /recipes-devtools/clang/libcxx_git.bb
parent33f857903bdf667148ffd1ff2abafcea1ad423d6 (diff)
downloadmeta-clang-d87c406c0f54e0e1ad4fb6aa2d0ecba93136139d.tar.gz
clang: Merge libunwind back into libcxx
Do not export libunwind to other recipes besides libcxx itself, we use non-gnu libunwind on linux in general and its not a drop in replacement as of yet Signed-off-by: Khem Raj <raj.khem@gmail.com>
Diffstat (limited to 'recipes-devtools/clang/libcxx_git.bb')
-rw-r--r--recipes-devtools/clang/libcxx_git.bb15
1 files changed, 13 insertions, 2 deletions
diff --git a/recipes-devtools/clang/libcxx_git.bb b/recipes-devtools/clang/libcxx_git.bb
index 425ecda..2d530c5 100644
--- a/recipes-devtools/clang/libcxx_git.bb
+++ b/recipes-devtools/clang/libcxx_git.bb
@@ -15,7 +15,7 @@ PACKAGECONFIG_riscv32 = "exceptions"
15PACKAGECONFIG_riscv64 = "exceptions" 15PACKAGECONFIG_riscv64 = "exceptions"
16PACKAGECONFIG_append_armv5 = " no-atomics" 16PACKAGECONFIG_append_armv5 = " no-atomics"
17 17
18PACKAGECONFIG[unwind] = "-DLIBCXXABI_USE_LLVM_UNWINDER=ON,-DLIBCXXABI_USE_LLVM_UNWINDER=OFF,llvm-libunwind" 18PACKAGECONFIG[unwind] = "-DLIBCXXABI_USE_LLVM_UNWINDER=ON -DLIBCXXABI_ENABLE_STATIC_UNWINDER=ON -DLIBCXXABI_STATICALLY_LINK_UNWINDER_IN_SHARED_LIBRARY=ON -DLIBCXXABI_STATICALLY_LINK_UNWINDER_IN_STATIC_LIBRARY=ON,-DLIBCXXABI_USE_LLVM_UNWINDER=OFF,,"
19PACKAGECONFIG[exceptions] = "-DLIBCXXABI_ENABLE_EXCEPTIONS=ON -DDLIBCXX_ENABLE_EXCEPTIONS=ON,-DLIBCXXABI_ENABLE_EXCEPTIONS=OFF -DLIBCXX_ENABLE_EXCEPTIONS=OFF -DCMAKE_REQUIRED_FLAGS='-fno-exceptions'," 19PACKAGECONFIG[exceptions] = "-DLIBCXXABI_ENABLE_EXCEPTIONS=ON -DDLIBCXX_ENABLE_EXCEPTIONS=ON,-DLIBCXXABI_ENABLE_EXCEPTIONS=OFF -DLIBCXX_ENABLE_EXCEPTIONS=OFF -DCMAKE_REQUIRED_FLAGS='-fno-exceptions',"
20PACKAGECONFIG[no-atomics] = "-D_LIBCXXABI_HAS_ATOMIC_BUILTINS=OFF -DCMAKE_SHARED_LINKER_FLAGS='-latomic',," 20PACKAGECONFIG[no-atomics] = "-D_LIBCXXABI_HAS_ATOMIC_BUILTINS=OFF -DCMAKE_SHARED_LINKER_FLAGS='-latomic',,"
21PACKAGECONFIG[compiler-rt] = "-DLIBCXXABI_USE_COMPILER_RT=ON -DLIBCXX_USE_COMPILER_RT=ON,-DLIBCXXABI_USE_COMPILER_RT=OFF -DLIBCXX_USE_COMPILER_RT=OFF,compiler-rt" 21PACKAGECONFIG[compiler-rt] = "-DLIBCXXABI_USE_COMPILER_RT=ON -DLIBCXX_USE_COMPILER_RT=ON,-DLIBCXXABI_USE_COMPILER_RT=OFF -DLIBCXX_USE_COMPILER_RT=OFF,compiler-rt"
@@ -29,11 +29,16 @@ INHIBIT_DEFAULT_DEPS = "1"
29 29
30LIC_FILES_CHKSUM = "file://libcxx/LICENSE.TXT;md5=55d89dd7eec8d3b4204b680e27da3953 \ 30LIC_FILES_CHKSUM = "file://libcxx/LICENSE.TXT;md5=55d89dd7eec8d3b4204b680e27da3953 \
31 file://libcxxabi/LICENSE.TXT;md5=7b9334635b542c56868400a46b272b1e \ 31 file://libcxxabi/LICENSE.TXT;md5=7b9334635b542c56868400a46b272b1e \
32 file://libunwind/LICENSE.TXT;md5=f66970035d12f196030658b11725e1a1 \
32" 33"
33 34
34EXTRA_OECMAKE += "\ 35EXTRA_OECMAKE += "\
35 -DCMAKE_CROSSCOMPILING=ON \ 36 -DCMAKE_CROSSCOMPILING=ON \
36 -DLLVM_TEMPORARILY_ALLOW_OLD_TOOLCHAIN=ON \ 37 -DLLVM_TEMPORARILY_ALLOW_OLD_TOOLCHAIN=ON \
38 -DLIBUNWIND_ENABLE_SHARED=OFF \
39 -DLIBUNWIND_ENABLE_THREADS=OFF \
40 -DLIBUNWIND_WEAK_PTHREAD_LIB=ON \
41 -DLIBUNWIND_ENABLE_CROSS_UNWINDING=ON \
37 -DLIBCXXABI_INCLUDE_TESTS=OFF \ 42 -DLIBCXXABI_INCLUDE_TESTS=OFF \
38 -DLIBCXXABI_ENABLE_SHARED=ON \ 43 -DLIBCXXABI_ENABLE_SHARED=ON \
39 -DLIBCXXABI_USE_COMPILER_RT=ON \ 44 -DLIBCXXABI_USE_COMPILER_RT=ON \
@@ -45,7 +50,7 @@ EXTRA_OECMAKE += "\
45 -DCMAKE_AR=${STAGING_BINDIR_TOOLCHAIN}/${AR} \ 50 -DCMAKE_AR=${STAGING_BINDIR_TOOLCHAIN}/${AR} \
46 -DCMAKE_NM=${STAGING_BINDIR_TOOLCHAIN}/${NM} \ 51 -DCMAKE_NM=${STAGING_BINDIR_TOOLCHAIN}/${NM} \
47 -DCMAKE_RANLIB=${STAGING_BINDIR_TOOLCHAIN}/${RANLIB} \ 52 -DCMAKE_RANLIB=${STAGING_BINDIR_TOOLCHAIN}/${RANLIB} \
48 -DLLVM_ENABLE_PROJECTS='libcxx;libcxxabi' \ 53 -DLLVM_ENABLE_PROJECTS='libcxx;libcxxabi;libunwind' \
49 -DLLVM_LIBDIR_SUFFIX=${@d.getVar('baselib').replace('lib', '')} \ 54 -DLLVM_LIBDIR_SUFFIX=${@d.getVar('baselib').replace('lib', '')} \
50 -G Ninja \ 55 -G Ninja \
51 ${S}/llvm \ 56 ${S}/llvm \
@@ -60,11 +65,17 @@ EXTRA_OECMAKE_append_libc-musl = " -DLIBCXX_HAS_MUSL_LIBC=ON "
60CXXFLAGS_append_armv5 = " -mfpu=vfp2" 65CXXFLAGS_append_armv5 = " -mfpu=vfp2"
61 66
62do_compile() { 67do_compile() {
68 if [ -n "${@bb.utils.filter('PACKAGECONFIG', 'unwind', d)}" ]; then
69 ninja -v ${PARALLEL_MAKE} unwind
70 fi
63 ninja -v ${PARALLEL_MAKE} cxxabi 71 ninja -v ${PARALLEL_MAKE} cxxabi
64 ninja -v ${PARALLEL_MAKE} cxx 72 ninja -v ${PARALLEL_MAKE} cxx
65} 73}
66 74
67do_install() { 75do_install() {
76 #DESTDIR=${D} ninja ${PARALLEL_MAKE} install-unwind
77 #install -d ${D}${includedir}
78 #install -m 644 ${S}/libunwind/include/*.h ${D}${includedir}
68 DESTDIR=${D} ninja ${PARALLEL_MAKE} install-cxx install-cxxabi 79 DESTDIR=${D} ninja ${PARALLEL_MAKE} install-cxx install-cxxabi
69} 80}
70 81