From 1d8718303b00e24d21ce70a6891a096e89c96f1d Mon Sep 17 00:00:00 2001 From: Sam James Date: Mon, 7 Feb 2022 03:56:24 +0000 Subject: sys-libs/libucontext: respect CFLAGS without overriding upstream define Fixes musl runtime as the right symbols get defined now (unprefixed). Bug: https://github.com/rui314/mold/issues/281 Bug: https://bugs.gentoo.org/832700 Closes: https://bugs.gentoo.org/832677 Thanks-to: Andrew Athalye Signed-off-by: Sam James --- .../files/libucontext-1.1-respect-CFLAGS.patch | 13 +++++ sys-libs/libucontext/libucontext-1.1-r1.ebuild | 55 ++++++++++++++++++++++ sys-libs/libucontext/libucontext-1.1.ebuild | 51 -------------------- 3 files changed, 68 insertions(+), 51 deletions(-) create mode 100644 sys-libs/libucontext/files/libucontext-1.1-respect-CFLAGS.patch create mode 100644 sys-libs/libucontext/libucontext-1.1-r1.ebuild delete mode 100644 sys-libs/libucontext/libucontext-1.1.ebuild (limited to 'sys-libs') diff --git a/sys-libs/libucontext/files/libucontext-1.1-respect-CFLAGS.patch b/sys-libs/libucontext/files/libucontext-1.1-respect-CFLAGS.patch new file mode 100644 index 000000000000..49dd872690d5 --- /dev/null +++ b/sys-libs/libucontext/files/libucontext-1.1-respect-CFLAGS.patch @@ -0,0 +1,13 @@ +https://bugs.gentoo.org/832677 +https://github.com/kaniini/libucontext/issues/39 +--- a/Makefile ++++ b/Makefile +@@ -17,7 +17,7 @@ endif + LIBDIR := /lib + INCLUDEDIR := /usr/include + PKGCONFIGDIR := /usr/lib/pkgconfig +-CFLAGS := -ggdb3 -O2 -Wall ++CFLAGS ?= -ggdb3 -O2 -Wall + CPPFLAGS := -Iinclude -Iarch/${ARCH} -Iarch/common + EXPORT_UNPREFIXED := yes + FREESTANDING := no diff --git a/sys-libs/libucontext/libucontext-1.1-r1.ebuild b/sys-libs/libucontext/libucontext-1.1-r1.ebuild new file mode 100644 index 000000000000..cf76cfa1a756 --- /dev/null +++ b/sys-libs/libucontext/libucontext-1.1-r1.ebuild @@ -0,0 +1,55 @@ +# Copyright 1999-2022 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +inherit toolchain-funcs + +DESCRIPTION="ucontext implementation featuring glibc-compatible ABI" +HOMEPAGE="https://github.com/kaniini/libucontext" +SRC_URI="https://github.com/kaniini/libucontext/archive/refs/tags/${P}.tar.gz" +S="${WORKDIR}"/${PN}-${P} + +LICENSE="ISC" +SLOT="0" +KEYWORDS="~amd64" +IUSE="+man" + +BDEPEND="man? ( app-text/scdoc )" + +# segfault needs investigation +RESTRICT="test" + +PATCHES=( + "${FILESDIR}"/${PN}-1.1-respect-CFLAGS.patch +) + +src_compile() { + tc-export AR CC + + local arch + + # Override arch detection + # https://github.com/kaniini/libucontext/blob/master/Makefile#L3 + if use x86 ; then + arch="x86" + elif use arm ; then + arch="arm" + elif use arm64 ; then + arch="aarch64" + elif use ppc64 ; then + arch="ppc64" + else + arch="$(uname -m)" + fi + + emake ARCH="${arch}" LDFLAGS="${LDFLAGS}" all $(usev man 'docs') +} + +src_test() { + emake LDFLAGS="${LDFLAGS}" check +} + +src_install() { + emake DESTDIR="${ED}" LIBDIR="/usr/$(get_libdir)" install $(usev man 'install_docs') +} diff --git a/sys-libs/libucontext/libucontext-1.1.ebuild b/sys-libs/libucontext/libucontext-1.1.ebuild deleted file mode 100644 index f637a693a337..000000000000 --- a/sys-libs/libucontext/libucontext-1.1.ebuild +++ /dev/null @@ -1,51 +0,0 @@ -# Copyright 1999-2021 Gentoo Authors -# Distributed under the terms of the GNU General Public License v2 - -EAPI=8 - -inherit toolchain-funcs - -DESCRIPTION="ucontext implementation featuring glibc-compatible ABI" -HOMEPAGE="https://github.com/kaniini/libucontext" -SRC_URI="https://github.com/kaniini/libucontext/archive/refs/tags/${P}.tar.gz" -S="${WORKDIR}"/${PN}-${P} - -LICENSE="ISC" -SLOT="0" -KEYWORDS="~amd64" -IUSE="+man" - -BDEPEND="man? ( app-text/scdoc )" - -# segfault needs investigation -RESTRICT="test" - -src_compile() { - tc-export AR CC - - local arch - - # Override arch detection - # https://github.com/kaniini/libucontext/blob/master/Makefile#L3 - if use x86 ; then - arch="x86" - elif use arm ; then - arch="arm" - elif use arm64 ; then - arch="aarch64" - elif use ppc64 ; then - arch="ppc64" - else - arch="$(uname -m)" - fi - - emake ARCH="${arch}" CFLAGS="${CFLAGS}" LDFLAGS="${LDFLAGS}" all $(usev man 'docs') -} - -src_test() { - emake CFLAGS="${CFLAGS}" LDFLAGS="${LDFLAGS}" check -} - -src_install() { - emake DESTDIR="${ED}" LIBDIR="/usr/$(get_libdir)" install $(usev man 'install_docs') -} -- cgit v1.2.3-65-gdbad