diff options
Diffstat (limited to 'sys-libs/libunwind')
-rw-r--r-- | sys-libs/libunwind/Manifest | 1 | ||||
-rw-r--r-- | sys-libs/libunwind/libunwind-1.2.1-r3.ebuild | 105 |
2 files changed, 106 insertions, 0 deletions
diff --git a/sys-libs/libunwind/Manifest b/sys-libs/libunwind/Manifest index 66ee75c9d119..97a4c129fab9 100644 --- a/sys-libs/libunwind/Manifest +++ b/sys-libs/libunwind/Manifest @@ -13,4 +13,5 @@ DIST libunwind-1.2.1.tar.gz 780774 BLAKE2B a5be4142e1e4932231023bdec2ab3ecd6b707 EBUILD libunwind-1.1-r1.ebuild 2451 BLAKE2B 65ee170114b63d5405fb81ff6287cd9486d519c56bc5a5e05bdaea40036168f85093f057d2c22de54813c6d08a7b4269331be313df2a88b5d071ccdf1e35be72 SHA512 692315630f4bf8c422cd0ebc46b91a6dbaae1cee4e464c4d2c7d24842c906b426fe0511bb7220b65f2f248921a91aaa8a1eca00de77c625d16cc2443246528ac EBUILD libunwind-1.2.1-r1.ebuild 3185 BLAKE2B 0ab1544607e8d04dea1e24ec4396599bf81209891e100e8776fe0c5bdc816802ccf1df90cb535db42bdab46b5939ab1274d7888c6e844cfdbde02a548523251d SHA512 b590b26028a727e329e1558430d2b978e5a6db811cb1ddb1b7e6fe1110b108b36e39f651ced071d641bba45158610fd45e36c78f6084344aef47ce837b065292 EBUILD libunwind-1.2.1-r2.ebuild 3246 BLAKE2B 5017270dade9c6c7a4ad6649253eecccef430979eb90b761a78ff8b476d03ed5e3e2415be7693072f0dc0631971e439a1017c01ac48a16bd6a26beee97b98601 SHA512 3e16f8ee57a886d02f4eac63247191f232ed3cdac9d2f40e6824db806dbed4127386c79c0b9642f63435b5cd6c3f4bef5599df24b92b45c86c8fe5575bc7678a +EBUILD libunwind-1.2.1-r3.ebuild 3283 BLAKE2B 695098794bedf6b577c9f97c0395f460323b0ed4a14d5f3388773b84517a8c80a024013bd24bda07e2b70254db32ccf77429e91ba6c0baa20beb7fba507b476c SHA512 a5976f45f296a171772da9fbd2295f695e5d06ce9c361d0dc25d5db3b22007aef66ad56acc653f6055928099b1b512716ac9f660d4b7f95dcb8e67d2e4820056 MISC metadata.xml 489 BLAKE2B c0a884e7161b62e8548fdf3c8c1d34b24936c71a99fef37713b7c36e0ef3423563e5c98eae8e9748db059645ce85cf972448e0584b1ed92e51c228794e5ed10d SHA512 d7586420e24a7b841cb090ce8dc7bb1c1260a3e2afbc6606d0a974243ca20c0586b4aa3e770b5b98787f8d34b8255846d87550c16f68da6e9d3f55f8b57bde40 diff --git a/sys-libs/libunwind/libunwind-1.2.1-r3.ebuild b/sys-libs/libunwind/libunwind-1.2.1-r3.ebuild new file mode 100644 index 000000000000..27084d43a5b9 --- /dev/null +++ b/sys-libs/libunwind/libunwind-1.2.1-r3.ebuild @@ -0,0 +1,105 @@ +# Copyright 1999-2019 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=6 + +MY_PV=${PV/_/-} +MY_P=${PN}-${MY_PV} +inherit autotools eutils libtool multilib-minimal + +DESCRIPTION="Portable and efficient API to determine the call-chain of a program" +HOMEPAGE="https://savannah.nongnu.org/projects/libunwind" +SRC_URI="mirror://nongnu/libunwind/${MY_P}.tar.gz" + +LICENSE="MIT" +SLOT="7" +KEYWORDS="~amd64 ~arm ~arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 -sparc ~x86 ~amd64-fbsd ~x86-fbsd ~amd64-linux ~x86-linux" +IUSE="debug debug-frame doc libatomic lzma +static-libs" + +RESTRICT="test" # half of tests are broken (toolchain version dependent) + +# We just use the header from libatomic. +RDEPEND="lzma? ( app-arch/xz-utils[${MULTILIB_USEDEP}] )" +DEPEND="${RDEPEND} + libatomic? ( dev-libs/libatomic_ops[${MULTILIB_USEDEP}] )" + +S="${WORKDIR}/${MY_P}" + +MULTILIB_WRAPPED_HEADERS=( + /usr/include/libunwind.h + + # see libunwind.h for the full list of arch-specific headers + /usr/include/libunwind-aarch64.h + /usr/include/libunwind-arm.h + /usr/include/libunwind-hppa.h + /usr/include/libunwind-ia64.h + /usr/include/libunwind-mips.h + /usr/include/libunwind-ppc32.h + /usr/include/libunwind-ppc64.h + /usr/include/libunwind-sh.h + /usr/include/libunwind-tilegx.h + /usr/include/libunwind-x86.h + /usr/include/libunwind-x86_64.h +) + +PATCHES=( + "${FILESDIR}"/${PN}-1.2-coredump-regs.patch #586092 + "${FILESDIR}"/${PN}-1.2-ia64-undwarf.patch + "${FILESDIR}"/${PN}-1.2-ia64-ptrace-coredump.patch + "${FILESDIR}"/${PN}-1.2-ia64-missing.patch + "${FILESDIR}"/${PN}-1.2.1-fix_version_macros.patch + "${FILESDIR}"/${PN}-1.2.1-only-include-execinfo_h-if-avaliable.patch + "${FILESDIR}"/${PN}-1.2.1-no-PROTECTED.patch #659732 + "${FILESDIR}"/${PN}-1.2.1-arm-__asm__.patch #635674 +) + +src_prepare() { + default + chmod +x src/ia64/mk_cursor_i || die + # Since we have tests disabled via RESTRICT, disable building in the subdir + # entirely. This worksaround some build errors too. #484846 + sed -i -e '/^SUBDIRS/s:tests::' Makefile.in || die + + elibtoolize + eautoreconf +} + +multilib_src_configure() { + # --enable-cxx-exceptions: always enable it, headers provide the interface + # and on some archs it is disabled by default causing a mismatch between the + # API and the ABI, bug #418253 + # conservative-checks: validate memory addresses before use; as of 1.0.1, + # only x86_64 supports this, yet may be useful for debugging, couple it with + # debug useflag. + ECONF_SOURCE="${S}" \ + ac_cv_header_atomic_ops_h=$(usex libatomic) \ + econf \ + --enable-cxx-exceptions \ + --enable-coredump \ + --enable-ptrace \ + --enable-setjmp \ + $(use_enable debug-frame) \ + $(use_enable doc documentation) \ + $(use_enable lzma minidebuginfo) \ + $(use_enable static-libs static) \ + $(use_enable debug conservative_checks) \ + $(use_enable debug) +} + +multilib_src_compile() { + # Bug 586208 + CCACHE_NODIRECT=1 default +} + +multilib_src_test() { + # Explicitly allow parallel build of tests. + # Sandbox causes some tests to freak out. + SANDBOX_ON=0 emake check +} + +multilib_src_install() { + default + # libunwind-ptrace.a (and libunwind-ptrace.h) is separate API and without + # shared library, so we keep it in any case + use static-libs || find "${ED}"usr '(' -name 'libunwind-generic.a' -o -name 'libunwind*.la' ')' -delete +} |