summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKhem Raj <raj.khem@gmail.com>2019-09-18 23:50:38 -0700
committerKhem Raj <raj.khem@gmail.com>2019-09-19 12:03:13 -0700
commit9143de53c558a06984f9b2b71aa5e835874b951b (patch)
tree9a4d4486add31b10f6d5ee2ca6c14a0c29779414
parent597feb4fe9b66a918fad36159a9e24b0fa13c9aa (diff)
downloadmeta-clang-9143de53c558a06984f9b2b71aa5e835874b951b.tar.gz
llvm-libunwind: New reecipe for llvm unwinder split from libcxx
Its easier to provide it as replacement for nongnu libunwind bundled into libcxx was getting harder when it came to replacement Signed-off-by: Khem Raj <raj.khem@gmail.com>
-rw-r--r--classes/clang.bbclass2
-rw-r--r--recipes-devtools/clang/libcxx_git.bb51
-rw-r--r--recipes-devtools/clang/llvm-libunwind.bb84
3 files changed, 103 insertions, 34 deletions
diff --git a/classes/clang.bbclass b/classes/clang.bbclass
index 99b80a4..58fe6b6 100644
--- a/classes/clang.bbclass
+++ b/classes/clang.bbclass
@@ -77,7 +77,7 @@ def clang_dep_prepend(d):
77 77
78BASE_DEFAULT_DEPS_toolchain-clang_class-target = "${@clang_dep_prepend(d)}" 78BASE_DEFAULT_DEPS_toolchain-clang_class-target = "${@clang_dep_prepend(d)}"
79 79
80PREFERRED_PROVIDER_libunwind_toolchain-clang = "libcxx" 80PREFERRED_PROVIDER_libunwind_toolchain-clang = "llvm-libunwind"
81PREFERRED_PROVIDER_libunwind ?= "libunwind" 81PREFERRED_PROVIDER_libunwind ?= "libunwind"
82PREFERRED_PROVIDER_libunwind_powerpc = "libunwind" 82PREFERRED_PROVIDER_libunwind_powerpc = "libunwind"
83PREFERRED_PROVIDER_libunwind_riscv32 = "libunwind" 83PREFERRED_PROVIDER_libunwind_riscv32 = "libunwind"
diff --git a/recipes-devtools/clang/libcxx_git.bb b/recipes-devtools/clang/libcxx_git.bb
index c88d868..c12831a 100644
--- a/recipes-devtools/clang/libcxx_git.bb
+++ b/recipes-devtools/clang/libcxx_git.bb
@@ -10,26 +10,20 @@ require common-source.inc
10 10
11inherit cmake pythonnative 11inherit cmake pythonnative
12 12
13DEPENDS += "ninja-native" 13DEPENDS += "ninja-native llvm-libunwind"
14
15DEPENDS_remove_powerpc = "llvm-libunwind"
16DEPENDS_remove_riscv32 = "llvm-libunwind"
17DEPENDS_remove_riscv64 = "llvm-libunwind"
18
14BASEDEPENDS_remove_toolchain-clang = "libcxx" 19BASEDEPENDS_remove_toolchain-clang = "libcxx"
15DEPENDS_append_toolchain-clang = " virtual/${TARGET_PREFIX}compilerlibs" 20DEPENDS_append_toolchain-clang = " virtual/${TARGET_PREFIX}compilerlibs"
16 21
17TARGET_CXXFLAGS_remove_toolchain-clang = "--stdlib=libc++" 22TARGET_CXXFLAGS_remove_toolchain-clang = "--stdlib=libc++"
18TUNE_CCARGS_remove_toolchain-clang = "--unwindlib=libunwind --stdlib=libc++" 23TUNE_CCARGS_remove_toolchain-clang = "--stdlib=libc++"
19
20PACKAGECONFIG ??= "${@bb.utils.contains('PREFERRED_PROVIDER_libunwind', 'libcxx', 'unwind', '', d)}"
21PACKAGECONFIG_powerpc = ""
22PACKAGECONFIG_riscv64 = ""
23PACKAGECONFIG_riscv32 = ""
24
25PACKAGECONFIG[unwind] = "-DLIBCXXABI_USE_LLVM_UNWINDER=ON -DLIBUNWIND_ENABLE_SHARED=ON -DLIBCXXABI_ENABLE_STATIC_UNWINDER=ON -DLIBCXXABI_STATICALLY_LINK_UNWINDER_IN_SHARED_LIBRARY=OFF -DLIBCXXABI_LIBUNWIND_INCLUDES=${S}/projects/libunwind/include, -DLIBCXXABI_USE_LLVM_UNWINDER=OFF -DCMAKE_SHARED_LINKER_FLAGS='-lgcc_s',"
26
27PROVIDES += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'libunwind', '', d)}"
28LIBUNWIND = "${@bb.utils.contains('PACKAGECONFIG', 'unwind', ';libunwind', '', d)}"
29 24
30LIC_FILES_CHKSUM = "file://libcxx/LICENSE.TXT;md5=55d89dd7eec8d3b4204b680e27da3953 \ 25LIC_FILES_CHKSUM = "file://libcxx/LICENSE.TXT;md5=55d89dd7eec8d3b4204b680e27da3953 \
31 file://libcxxabi/LICENSE.TXT;md5=7b9334635b542c56868400a46b272b1e \ 26 file://libcxxabi/LICENSE.TXT;md5=7b9334635b542c56868400a46b272b1e \
32 file://libunwind/LICENSE.TXT;md5=f66970035d12f196030658b11725e1a1 \
33" 27"
34THUMB_TUNE_CCARGS = "" 28THUMB_TUNE_CCARGS = ""
35#TUNE_CCARGS += "-nostdlib" 29#TUNE_CCARGS += "-nostdlib"
@@ -45,14 +39,21 @@ EXTRA_OECMAKE += "\
45 -DLIBCXXABI_LIBCXX_INCLUDES=${S}/libcxx/include \ 39 -DLIBCXXABI_LIBCXX_INCLUDES=${S}/libcxx/include \
46 -DLIBCXX_CXX_ABI_INCLUDE_PATHS=${S}/libcxxabi/include \ 40 -DLIBCXX_CXX_ABI_INCLUDE_PATHS=${S}/libcxxabi/include \
47 -DLIBCXX_CXX_ABI_LIBRARY_PATH=${B}/${baselib} \ 41 -DLIBCXX_CXX_ABI_LIBRARY_PATH=${B}/${baselib} \
42 -DCMAKE_SHARED_LINKER_FLAGS='${SHAREDFLAGS}' \
48 -DCMAKE_AR=${STAGING_BINDIR_TOOLCHAIN}/${AR} \ 43 -DCMAKE_AR=${STAGING_BINDIR_TOOLCHAIN}/${AR} \
49 -DCMAKE_NM=${STAGING_BINDIR_TOOLCHAIN}/${NM} \ 44 -DCMAKE_NM=${STAGING_BINDIR_TOOLCHAIN}/${NM} \
50 -DCMAKE_RANLIB=${STAGING_BINDIR_TOOLCHAIN}/${RANLIB} \ 45 -DCMAKE_RANLIB=${STAGING_BINDIR_TOOLCHAIN}/${RANLIB} \
51 -DLLVM_ENABLE_PROJECTS='libcxx;libcxxabi${LIBUNWIND}' \ 46 -DLLVM_ENABLE_PROJECTS='libcxx;libcxxabi' \
52 -DLLVM_LIBDIR_SUFFIX=${@d.getVar('baselib').replace('lib', '')} \ 47 -DLLVM_LIBDIR_SUFFIX=${@d.getVar('baselib').replace('lib', '')} \
53 -G Ninja \ 48 -G Ninja \
54 ${S}/llvm \ 49 ${S}/llvm \
55" 50"
51SHAREDFLAGS ?= "-lunwind"
52SHAREDFLAGS_riscv32 = "-lgcc_s -latomic"
53SHAREDFLAGS_riscv64 = "-lgcc_s -latomic"
54SHAREDFLAGS_powerpc = "-lgcc_s -latomic"
55SHAREDFLAGS_append_arm = " -latomic"
56SHAREDFLAGS_append_armeb = " -latomic"
56 57
57EXTRA_OECMAKE_append_class-native = " -DLIBCXX_ENABLE_ABI_LINKER_SCRIPT=OFF" 58EXTRA_OECMAKE_append_class-native = " -DLIBCXX_ENABLE_ABI_LINKER_SCRIPT=OFF"
58EXTRA_OECMAKE_append_class-nativesdk = " -DLIBCXX_ENABLE_ABI_LINKER_SCRIPT=OFF" 59EXTRA_OECMAKE_append_class-nativesdk = " -DLIBCXX_ENABLE_ABI_LINKER_SCRIPT=OFF"
@@ -60,7 +61,7 @@ EXTRA_OECMAKE_append_libc-musl = " -DLIBCXX_HAS_MUSL_LIBC=ON "
60EXTRA_OECMAKE_append_riscv64 = " -DLIBCXXABI_ENABLE_EXCEPTIONS=ON \ 61EXTRA_OECMAKE_append_riscv64 = " -DLIBCXXABI_ENABLE_EXCEPTIONS=ON \
61 -DLIBCXX_ENABLE_EXCEPTIONS=ON \ 62 -DLIBCXX_ENABLE_EXCEPTIONS=ON \
62 -DLIBOMP_LIBFLAGS='-latomic' \ 63 -DLIBOMP_LIBFLAGS='-latomic' \
63 -DCMAKE_SHARED_LINKER_FLAGS='-lgcc_s -latomic' \ 64 -DLIBCXX_HAS_GCC_S_LIB=ON \
64 " 65 "
65 66
66EXTRA_OECMAKE_append_armv5 = " -D_LIBCXXABI_HAS_ATOMIC_BUILTINS=OFF" 67EXTRA_OECMAKE_append_armv5 = " -D_LIBCXXABI_HAS_ATOMIC_BUILTINS=OFF"
@@ -70,40 +71,24 @@ EXTRA_OECMAKE_append_arm = " -DCMAKE_REQUIRED_FLAGS='-fno-exceptions'"
70EXTRA_OECMAKE_append_riscv32 = " -DLIBCXXABI_ENABLE_EXCEPTIONS=ON \ 71EXTRA_OECMAKE_append_riscv32 = " -DLIBCXXABI_ENABLE_EXCEPTIONS=ON \
71 -DLIBCXX_ENABLE_EXCEPTIONS=ON \ 72 -DLIBCXX_ENABLE_EXCEPTIONS=ON \
72 -DLIBOMP_LIBFLAGS='-latomic' \ 73 -DLIBOMP_LIBFLAGS='-latomic' \
73 -DCMAKE_SHARED_LINKER_FLAGS='-lgcc_s -latomic' \ 74 -DLIBCXX_HAS_GCC_S_LIB=ON \
74 " 75 "
75EXTRA_OECMAKE_append_powerpc = " -DLIBCXXABI_ENABLE_EXCEPTIONS=ON \ 76EXTRA_OECMAKE_append_powerpc = " -DLIBCXXABI_ENABLE_EXCEPTIONS=ON \
76 -DLIBCXX_ENABLE_EXCEPTIONS=ON \ 77 -DLIBCXX_ENABLE_EXCEPTIONS=ON \
77 -DLIBOMP_LIBFLAGS='-latomic' \ 78 -DLIBOMP_LIBFLAGS='-latomic' \
78 -DCMAKE_SHARED_LINKER_FLAGS='-lgcc_s -latomic' \ 79 -DLIBCXX_HAS_GCC_S_LIB=ON \
79 " 80 "
80do_compile() { 81do_compile() {
81 if ${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'true', 'false', d)}; then
82 ninja -v ${PARALLEL_MAKE} unwind
83 fi
84 ninja -v ${PARALLEL_MAKE} cxxabi 82 ninja -v ${PARALLEL_MAKE} cxxabi
85 ninja -v ${PARALLEL_MAKE} cxx 83 ninja -v ${PARALLEL_MAKE} cxx
86} 84}
87 85
88do_install() { 86do_install() {
89 if ${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'true', 'false', d)}; then
90 DESTDIR=${D} ninja ${PARALLEL_MAKE} install-unwind
91 fi
92 DESTDIR=${D} ninja ${PARALLEL_MAKE} install-cxx install-cxxabi 87 DESTDIR=${D} ninja ${PARALLEL_MAKE} install-cxx install-cxxabi
93} 88}
94 89
95ALLOW_EMPTY_${PN} = "1" 90ALLOW_EMPTY_${PN} = "1"
96 91
97RPROVIDES_${PN} += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'libunwind', '', d)}"
98RPROVIDES_${PN}-dbg += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'libunwind-dbg', '', d)}"
99RPROVIDES_${PN}-dev += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'libunwind-dev', '', d)}"
100RPROVIDES_${PN}-doc += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'libunwind-doc', '', d)}"
101RPROVIDES_${PN}-staticdev += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'libunwind-staticdev', '', d)}"
102RPROVIDES_${PN}-locale += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'libunwind-locale', '', d)}"
103RPROVIDES_${PN}-src += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', 'libunwind-src', '', d)}"
104
105PACKAGES_DYNAMIC += "${@bb.utils.contains('PACKAGECONFIG', 'unwind', '^libunwind-locale-.*', '', d)}"
106
107BBCLASSEXTEND = "native nativesdk" 92BBCLASSEXTEND = "native nativesdk"
108TOOLCHAIN = "clang" 93TOOLCHAIN = "clang"
109 94
diff --git a/recipes-devtools/clang/llvm-libunwind.bb b/recipes-devtools/clang/llvm-libunwind.bb
new file mode 100644
index 0000000..83bd92a
--- /dev/null
+++ b/recipes-devtools/clang/llvm-libunwind.bb
@@ -0,0 +1,84 @@
1# Copyright (C) 2015 Khem Raj <raj.khem@gmail.com>
2# Released under the MIT license (see COPYING.MIT for the terms)
3
4DESCRIPTION = "C++ runtime stack unwinder from LLVM"
5HOMEPAGE = "https://github.com/llvm-mirror/libunwind"
6SECTION = "base"
7
8require clang.inc
9require common-source.inc
10
11inherit cmake pythonnative
12
13DEPENDS += "ninja-native"
14BASEDEPENDS_remove_toolchain-clang = "libcxx"
15DEPENDS_append_toolchain-clang = " virtual/${TARGET_PREFIX}compilerlibs"
16
17TARGET_CXXFLAGS_remove_toolchain-clang = "--stdlib=libc++"
18TUNE_CCARGS_remove_toolchain-clang = "--unwindlib=libunwind --stdlib=libc++"
19
20COMPATIBLE_HOST_powerpc = "null"
21COMPATIBLE_HOST_riscv32 = "null"
22COMPATIBLE_HOST_riscv64 = "null"
23
24LIC_FILES_CHKSUM = "file://libunwind/LICENSE.TXT;md5=f66970035d12f196030658b11725e1a1 \
25"
26THUMB_TUNE_CCARGS = ""
27#TUNE_CCARGS += "-nostdlib"
28
29EXTRA_OECMAKE += "\
30 -DCMAKE_CROSSCOMPILING=ON \
31 -DLIBCXXABI_USE_LLVM_UNWINDER=ON \
32 -DLIBUNWIND_ENABLE_SHARED=ON \
33 -DLIBCXXABI_ENABLE_STATIC_UNWINDER=ON \
34 -DLIBCXXABI_STATICALLY_LINK_UNWINDER_IN_SHARED_LIBRARY=OFF \
35 -DLIBCXXABI_LIBUNWIND_INCLUDES=${S}/projects/libunwind/include \
36 -DLIBUNWIND_ENABLE_THREADS=OFF \
37 -DLIBUNWIND_ENABLE_CROSS_UNWINDING=ON \
38 -DLLVM_ENABLE_LIBCXX=ON \
39 -DLIBCXX_CXX_ABI_INCLUDE_PATHS=${S}/libcxxabi/include \
40 -DLIBCXX_CXX_ABI_LIBRARY_PATH=${B}/${baselib} \
41 -DCMAKE_AR=${STAGING_BINDIR_TOOLCHAIN}/${AR} \
42 -DCMAKE_NM=${STAGING_BINDIR_TOOLCHAIN}/${NM} \
43 -DCMAKE_RANLIB=${STAGING_BINDIR_TOOLCHAIN}/${RANLIB} \
44 -DLLVM_ENABLE_PROJECTS='libunwind' \
45 -DLLVM_LIBDIR_SUFFIX=${@d.getVar('baselib').replace('lib', '')} \
46 -G Ninja \
47 ${S}/llvm \
48"
49
50EXTRA_OECMAKE_append_libc-musl = " -DLIBCXX_HAS_MUSL_LIBC=ON "
51EXTRA_OECMAKE_append_riscv64 = " -DCMAKE_SHARED_LINKER_FLAGS='-lgcc_s -latomic' \
52 "
53
54EXTRA_OECMAKE_append_arm = " -DCMAKE_REQUIRED_FLAGS='-fno-exceptions'"
55
56EXTRA_OECMAKE_append_riscv32 = " -DCMAKE_SHARED_LINKER_FLAGS='-lgcc_s -latomic' \
57 "
58EXTRA_OECMAKE_append_powerpc = " -DCMAKE_SHARED_LINKER_FLAGS='-lgcc_s -latomic' \
59 "
60do_compile() {
61 ninja -v ${PARALLEL_MAKE} unwind
62}
63
64do_install() {
65 DESTDIR=${D} ninja ${PARALLEL_MAKE} install-unwind
66 install -d ${D}${includedir}
67 install -m 644 ${S}/libunwind/include/*.h ${D}${includedir}
68}
69
70ALLOW_EMPTY_${PN} = "1"
71
72RPROVIDES_${PN} += "libunwind"
73RPROVIDES_${PN}-dbg += "libunwind-dbg"
74RPROVIDES_${PN}-dev += "libunwind-dev"
75RPROVIDES_${PN}-doc += "libunwind-doc"
76RPROVIDES_${PN}-staticdev += "libunwind-staticdev"
77RPROVIDES_${PN}-locale += "libunwind-locale"
78RPROVIDES_${PN}-src += "libunwind-src"
79
80PACKAGES_DYNAMIC += "^libunwind-locale-.*"
81
82BBCLASSEXTEND = "native nativesdk"
83TOOLCHAIN = "clang"
84