Go to:
Gentoo Home
Documentation
Forums
Lists
Bugs
Planet
Store
Wiki
Get Gentoo!
Gentoo's Bugzilla – Attachment 628934 Details for
Bug 673934
dev-util/strace[static,unwind] with sys-libs/libunwind[lzma] - configure: error: failed to find libunwind
Home
|
New
–
[Ex]
|
Browse
|
Search
|
Privacy Policy
|
[?]
|
Reports
|
Requests
|
Help
|
New Account
|
Log In
[x]
|
Forgot Password
Login:
[x]
[patch]
Patch
strace.patch (text/plain), 9.08 KB, created by
Arfrever Frehtes Taifersar Arahesis
on 2020-04-02 07:54:06 UTC
(
hide
)
Description:
Patch
Filename:
MIME Type:
Creator:
Arfrever Frehtes Taifersar Arahesis
Created:
2020-04-02 07:54:06 UTC
Size:
9.08 KB
patch
obsolete
>From 3898986df0fc1c5709f32640428db2f8a60a9f14 Mon Sep 17 00:00:00 2001 >From: Arfrever Frehtes Taifersar Arahesis <Arfrever@Apache.Org> >Date: Thu, 2 Apr 2020 07:51:26 +0000 >Subject: [PATCH] dev-util/strace: Fix building with USE="static". > >Closes: https://bugs.gentoo.org/673934 >Closes: https://bugs.gentoo.org/686946 >Signed-off-by: Arfrever Frehtes Taifersar Arahesis <Arfrever@Apache.Org> >--- > dev-util/strace/files/strace-5.5-static.patch | 178 ++++++++++++++++++ > dev-util/strace/strace-5.5.ebuild | 14 +- > dev-util/strace/strace-9999.ebuild | 14 +- > 3 files changed, 198 insertions(+), 8 deletions(-) > create mode 100644 dev-util/strace/files/strace-5.5-static.patch > >diff --git a/dev-util/strace/files/strace-5.5-static.patch b/dev-util/strace/files/strace-5.5-static.patch >new file mode 100644 >index 00000000000..da57ee0f938 >--- /dev/null >+++ b/dev-util/strace/files/strace-5.5-static.patch >@@ -0,0 +1,178 @@ >+--- /Makefile.am >++++ /Makefile.am >+@@ -379,7 +379,6 @@ >+ if USE_LIBDW >+ strace_SOURCES += unwind-libdw.c >+ strace_CPPFLAGS += $(libdw_CPPFLAGS) >+-strace_CFLAGS += $(libdw_CFLAGS) >+ strace_LDFLAGS += $(libdw_LDFLAGS) >+ strace_LDADD += $(libdw_LIBS) >+ endif >+--- /configure.ac >++++ /configure.ac >+@@ -48,6 +48,15 @@ >+ AC_DEFINE([MANPAGE_DATE], "[manpage_date]", [Date]) >+ AC_SUBST([MANPAGE_DATE], [manpage_date]) >+ >++AC_ARG_ENABLE([static], >++ [AS_HELP_STRING([--enable-static], >++ [link strace statically])], >++ [], [enable_static=no]) >++if test "$enable_static" = "yes"; then >++ # Add -pthread since strace wants -lrt for timer_create, and -lrt uses -lpthread. >++ LDFLAGS="$LDFLAGS -pthread -static" >++fi >++ >+ AC_C_BIGENDIAN >+ >+ AC_MSG_CHECKING([for supported architecture]) >+--- /m4/st_libdw.m4 >++++ /m4/st_libdw.m4 >+@@ -8,7 +8,6 @@ >+ AC_DEFUN([st_ARG_LIBDW], [dnl >+ >+ : ${libdw_CPPFLAGS=} >+-: ${libdw_CFLAGS=} >+ : ${libdw_LDFLAGS=} >+ : ${libdw_LIBS=} >+ >+@@ -34,48 +33,14 @@ >+ have_libdw= >+ >+ AS_IF([test "x$with_libdw" != xno && test "x$use_unwinder" = x], >+- [saved_CPPFLAGS="$CPPFLAGS" >+- saved_CFLAGS="$CFLAGS" >+- CPPFLAGS="$CPPFLAGS $libdw_CPPFLAGS" >+- CFLAGS="$CFLAGS $libdw_CFLAGS" >+- >+- AC_CHECK_HEADERS([elfutils/libdwfl.h], >+- [AC_CHECK_LIB([dw], [dwfl_linux_proc_attach], >+- [libdw_LIBS="-ldw $libdw_LIBS" >+- AC_CACHE_CHECK([for elfutils version], >+- [st_cv_ELFUTILS_VERSION], >+- [[st_cv_ELFUTILS_VERSION="$(echo _ELFUTILS_VERSION | >+- $CPP $CPPFLAGS -P -imacros elfutils/version.h - | >+- grep '^[0-9]')" >+- test -n "$st_cv_ELFUTILS_VERSION" || >+- st_cv_ELFUTILS_VERSION=0 >+- ]] >+- ) >+- AS_IF([test "$st_cv_ELFUTILS_VERSION" -ge 164], >+- [have_libdw=yes], >+- [AS_IF([test "x$with_libdw" = xyes], >+- [AC_MSG_ERROR([elfutils version >= 164 is required for stack tracing support])], >+- [AC_MSG_WARN([elfutils version >= 164 is required for stack tracing support])] >+- ) >+- ] >+- ) >+- ], >+- [AS_IF([test "x$with_libdw" = xyes], >+- [AC_MSG_FAILURE([failed to find dwfl_linux_proc_attach in libdw])], >+- ) >+- ], >+- [$libdw_LDFLAGS $libdw_LIBS] >+- ) >+- ], >+- [AS_IF([test "x$with_libdw" = xyes], >+- [AC_MSG_FAILURE([failed to find elfutils/libdwfl.h])] >+- ) >+- ] >+- ) >+- >+- CFLAGS="$saved_CFLAGS" >+- CPPFLAGS="$saved_CPPFLAGS" >+- ] >++ [if test "$enable_static" = "yes"; then >++ PKG_CHECK_MODULES_STATIC([LIBDW], [libdw >= 0.164]) >++ else >++ PKG_CHECK_MODULES([LIBDW], [libdw >= 0.164]) >++ fi >++ have_libdw=yes >++ libdw_CPPFLAGS="$LIBDW_CFLAGS" >++ libdw_LIBS="$LIBDW_LIBS"] >+ ) >+ >+ AS_IF([test "x$have_libdw" = xyes], >+@@ -84,7 +49,6 @@ >+ [Whether to use libdw for stack tracing] >+ ) >+ AC_SUBST(libdw_CPPFLAGS) >+- AC_SUBST(libdw_CFLAGS) >+ AC_SUBST(libdw_LDFLAGS) >+ AC_SUBST(libdw_LIBS) >+ ] >+--- /m4/st_libunwind.m4 >++++ /m4/st_libunwind.m4 >+@@ -28,64 +28,14 @@ >+ libunwind_LIBS= >+ >+ AS_IF([test "x$with_libunwind" != xno && test "x$use_unwinder" = x], >+- [saved_CPPFLAGS="$CPPFLAGS" >+- CPPFLAGS="$CPPFLAGS $libunwind_CPPFLAGS" >+- >+- AC_CHECK_HEADERS([libunwind-ptrace.h], >+- [saved_LDFLAGS="$LDFLAGS" >+- LDFLAGS="$LDFLAGS $libunwind_LDFLAGS" >+- >+- AC_CHECK_LIB([unwind], [backtrace], >+- [libunwind_LIBS="-lunwind $libunwind_LIBS" >+- >+- AC_MSG_CHECKING([for unw_create_addr_space in libunwind-generic]) >+- saved_LIBS="$LIBS" >+- LIBS="-lunwind-generic $libunwind_LIBS $LIBS" >+- >+- AC_LINK_IFELSE( >+- [AC_LANG_PROGRAM([[#include <libunwind-ptrace.h>]], >+- [[return !unw_create_addr_space(0, 0)]]) >+- ], >+- [AC_MSG_RESULT([yes]) >+- libunwind_LIBS="-lunwind-generic $libunwind_LIBS" >+- >+- AC_CHECK_LIB([unwind-ptrace], [_UPT_create], >+- [libunwind_LIBS="-lunwind-ptrace $libunwind_LIBS" >+- use_unwinder=libunwind >+- ], >+- [if test "x$with_libunwind" != xcheck; then >+- AC_MSG_FAILURE([failed to find _UPT_create in libunwind-ptrace]) >+- fi >+- ], >+- [$libunwind_LIBS] >+- ) >+- ], >+- [AC_MSG_RESULT([no]) >+- if test "x$with_libunwind" != xcheck; then >+- AC_MSG_FAILURE([failed to find unw_create_addr_space in libunwind-generic]) >+- fi >+- ] >+- ) >+- >+- LIBS="$saved_LIBS" >+- ], >+- [if test "x$with_libunwind" != xcheck; then >+- AC_MSG_FAILURE([failed to find libunwind]) >+- fi >+- ], >+- [$libunwind_LIBS] >+- ) >+- >+- LDFLAGS="$saved_LDFLAGS" >+- ], >+- [if test "x$with_libunwind" != xcheck; then >+- AC_MSG_FAILURE([failed to find libunwind-ptrace.h]) >+- fi >+- ] >+- ) >+- >+- CPPFLAGS="$saved_CPPFLAGS" >+- ] >++ [if test "$enable_static" = "yes"; then >++ PKG_CHECK_MODULES_STATIC([LIBUNWIND], [libunwind libunwind-generic libunwind-ptrace]) >++ else >++ PKG_CHECK_MODULES([LIBUNWIND], [libunwind libunwind-generic libunwind-ptrace]) >++ fi >++ use_unwinder="libunwind" >++ libunwind_CPPFLAGS="$LIBUNWIND_CFLAGS" >++ libunwind_LIBS="$LIBUNWIND_LIBS"] >+ ) >+ >+ if test "x$use_unwinder" = xlibunwind; then >diff --git a/dev-util/strace/strace-5.5.ebuild b/dev-util/strace/strace-5.5.ebuild >index 15e9ea94170..cf81c1cc50d 100644 >--- a/dev-util/strace/strace-5.5.ebuild >+++ b/dev-util/strace/strace-5.5.ebuild >@@ -3,7 +3,7 @@ > > EAPI=7 > >-inherit flag-o-matic toolchain-funcs autotools >+inherit autotools flag-o-matic toolchain-funcs > > if [[ ${PV} == "9999" ]] ; then > EGIT_REPO_URI="https://github.com/strace/strace.git" >@@ -22,6 +22,9 @@ IUSE="aio perl static unwind elfutils" > > REQUIRED_USE="?? ( unwind elfutils )" > >+BDEPEND=" >+ virtual/pkgconfig >+" > LIB_DEPEND=" > unwind? ( sys-libs/libunwind[static-libs(+)] ) > elfutils? ( dev-libs/elfutils[static-libs(+)] ) >@@ -37,11 +40,13 @@ RDEPEND=" > perl? ( dev-lang/perl ) > " > >+PATCHES=( >+ "${FILESDIR}/${PN}-5.5-static.patch" >+) >+ > src_prepare() { > default > >- # Needed for applied patch (#701516). Remove with next version. >- # Don't forget about autotools inherit. > eautoreconf > > if [[ ! -e configure ]] ; then >@@ -53,8 +58,6 @@ src_prepare() { > fi > > filter-lfs-flags # configure handles this sanely >- # Add -pthread since strace wants -lrt for timer_create, and -lrt uses -lpthread. >- use static && append-ldflags -static -pthread > > export ac_cv_header_libaio_h=$(usex aio) > use elibc_musl && export ac_cv_header_stdc=no >@@ -75,6 +78,7 @@ src_configure() { > # Don't require mpers support on non-multilib systems. #649560 > local myeconfargs=( > --enable-mpers=check >+ $(use_enable static) > $(use_with unwind libunwind) > $(use_with elfutils libdw) > ) >diff --git a/dev-util/strace/strace-9999.ebuild b/dev-util/strace/strace-9999.ebuild >index 369df34c830..cf81c1cc50d 100644 >--- a/dev-util/strace/strace-9999.ebuild >+++ b/dev-util/strace/strace-9999.ebuild >@@ -3,7 +3,7 @@ > > EAPI=7 > >-inherit flag-o-matic toolchain-funcs >+inherit autotools flag-o-matic toolchain-funcs > > if [[ ${PV} == "9999" ]] ; then > EGIT_REPO_URI="https://github.com/strace/strace.git" >@@ -22,6 +22,9 @@ IUSE="aio perl static unwind elfutils" > > REQUIRED_USE="?? ( unwind elfutils )" > >+BDEPEND=" >+ virtual/pkgconfig >+" > LIB_DEPEND=" > unwind? ( sys-libs/libunwind[static-libs(+)] ) > elfutils? ( dev-libs/elfutils[static-libs(+)] ) >@@ -37,9 +40,15 @@ RDEPEND=" > perl? ( dev-lang/perl ) > " > >+PATCHES=( >+ "${FILESDIR}/${PN}-5.5-static.patch" >+) >+ > src_prepare() { > default > >+ eautoreconf >+ > if [[ ! -e configure ]] ; then > # git generation > sed /autoreconf/d -i bootstrap || die >@@ -49,8 +58,6 @@ src_prepare() { > fi > > filter-lfs-flags # configure handles this sanely >- # Add -pthread since strace wants -lrt for timer_create, and -lrt uses -lpthread. >- use static && append-ldflags -static -pthread > > export ac_cv_header_libaio_h=$(usex aio) > use elibc_musl && export ac_cv_header_stdc=no >@@ -71,6 +78,7 @@ src_configure() { > # Don't require mpers support on non-multilib systems. #649560 > local myeconfargs=( > --enable-mpers=check >+ $(use_enable static) > $(use_with unwind libunwind) > $(use_with elfutils libdw) > ) >-- >2.26.0 >
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Diff
View Attachment As Raw
Actions:
View
|
Diff
Attachments on
bug 673934
:
558744
|
558746
|
558780
|
611544
|
611546
|
611548
| 628934