From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from lists.gentoo.org (pigeon.gentoo.org [208.92.234.80]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by finch.gentoo.org (Postfix) with ESMTPS id 9996C1392E8 for ; Sat, 24 Jul 2021 20:57:36 +0000 (UTC) Received: from pigeon.gentoo.org (localhost [127.0.0.1]) by pigeon.gentoo.org (Postfix) with SMTP id EBF7EE0AFC; Sat, 24 Jul 2021 20:57:35 +0000 (UTC) Received: from smtp.gentoo.org (dev.gentoo.org [IPv6:2001:470:ea4a:1:5054:ff:fec7:86e4]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by pigeon.gentoo.org (Postfix) with ESMTPS id 6F615E0AFC for ; Sat, 24 Jul 2021 20:57:35 +0000 (UTC) Received: from oystercatcher.gentoo.org (unknown [IPv6:2a01:4f8:202:4333:225:90ff:fed9:fc84]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.gentoo.org (Postfix) with ESMTPS id 26413342D34 for ; Sat, 24 Jul 2021 20:57:34 +0000 (UTC) Received: from localhost.localdomain (localhost [IPv6:::1]) by oystercatcher.gentoo.org (Postfix) with ESMTP id 920C47D6 for ; Sat, 24 Jul 2021 20:57:32 +0000 (UTC) From: "Andreas K. Hüttel" To: gentoo-commits@lists.gentoo.org Content-Transfer-Encoding: 8bit Content-type: text/plain; charset=UTF-8 Reply-To: gentoo-dev@lists.gentoo.org, "Andreas K. Hüttel" Message-ID: <1627155641.bc2a10f35b091063cf84b9cfd5300b6c0f0cf428.dilfridge@gentoo> Subject: [gentoo-commits] proj/toolchain/binutils-patches:master commit in: 9999/ X-VCS-Repository: proj/toolchain/binutils-patches X-VCS-Files: 9999/0007-Give-also-libctf-optionally-a-gentoo-specific-sovers.patch 9999/0008-If-we-use-a-soversion-suffix-then-we-also-use-the-bd.patch X-VCS-Directories: 9999/ X-VCS-Committer: dilfridge X-VCS-Committer-Name: Andreas K. Hüttel X-VCS-Revision: bc2a10f35b091063cf84b9cfd5300b6c0f0cf428 X-VCS-Branch: master Date: Sat, 24 Jul 2021 20:57:32 +0000 (UTC) Precedence: bulk List-Post: List-Help: List-Unsubscribe: List-Subscribe: List-Id: Gentoo Linux mail X-BeenThere: gentoo-commits@lists.gentoo.org X-Auto-Response-Suppress: DR, RN, NRN, OOF, AutoReply X-Archives-Salt: b2aa8a86-a345-45e4-ba06-2f7388625324 X-Archives-Hash: 82e953644f52c5459f8268fd3c487069 commit: bc2a10f35b091063cf84b9cfd5300b6c0f0cf428 Author: Andreas K. Hüttel gentoo org> AuthorDate: Sat Jul 24 19:40:41 2021 +0000 Commit: Andreas K. Hüttel gentoo org> CommitDate: Sat Jul 24 19:40:41 2021 +0000 URL: https://gitweb.gentoo.org/proj/toolchain/binutils-patches.git/commit/?id=bc2a10f3 Add libctf soversion patches Signed-off-by: Andreas K. Hüttel gentoo.org> ...ibctf-optionally-a-gentoo-specific-sovers.patch | 177 +++++++++++++++++++++ ...-soversion-suffix-then-we-also-use-the-bd.patch | 111 +++++++++++++ 2 files changed, 288 insertions(+) diff --git a/9999/0007-Give-also-libctf-optionally-a-gentoo-specific-sovers.patch b/9999/0007-Give-also-libctf-optionally-a-gentoo-specific-sovers.patch new file mode 100644 index 0000000..6f1c6b3 --- /dev/null +++ b/9999/0007-Give-also-libctf-optionally-a-gentoo-specific-sovers.patch @@ -0,0 +1,177 @@ +From d3cd41f5c7e405a8db5e85a7be9dfc42d44ef1b8 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Andreas=20K=2E=20H=C3=BCttel?= +Date: Sat, 24 Jul 2021 15:20:16 +0200 +Subject: [PATCH 1/2] Give also libctf optionally a gentoo-specific soversion + +--- + libctf/Makefile.am | 13 ++++++++++++- + libctf/Makefile.in | 8 +++++++- + libctf/configure | 31 +++++++++++++++++++++++++++++-- + libctf/configure.ac | 8 ++++++++ + 4 files changed, 56 insertions(+), 4 deletions(-) + +diff --git a/libctf/Makefile.am b/libctf/Makefile.am +index e586d25fb37..eabc7fa8394 100644 +--- a/libctf/Makefile.am ++++ b/libctf/Makefile.am +@@ -21,6 +21,8 @@ ACLOCAL_AMFLAGS = -I .. -I ../config -I ../bfd + + AUTOMAKE_OPTIONS = dejagnu foreign no-texinfo.tex + ++EXTRA_SOVERSION_SUFFIX = @EXTRA_SOVERSION_SUFFIX@ ++ + # This is where we get zlib from. zlibdir is -L../zlib and zlibinc is + # -I../zlib, unless we were configured with --with-system-zlib, in which + # case both are empty. +@@ -41,8 +43,17 @@ include_HEADERS = + noinst_LTLIBRARIES = libctf.la libctf-nobfd.la + endif + ++# libctf by default uses libtool versioning. Unfortunately that keeps us from adding ++# a supplement to the soversion. So we need to switch tracks and be creative. ++ ++if HAVE_EXTRA_SOVERSION_SUFFIX ++gentoo_ctf_soversion = 0.0.0.$(EXTRA_SOVERSION_SUFFIX) ++else ++gentoo_ctf_soversion = 0.0.0 ++endif ++ + libctf_nobfd_la_LIBADD = @CTF_LIBADD@ $(ZLIB) +-libctf_nobfd_la_LDFLAGS = -version-info 0:0:0 @SHARED_LDFLAGS@ @VERSION_FLAGS@ ++libctf_nobfd_la_LDFLAGS = -release $(gentoo_ctf_soversion) @SHARED_LDFLAGS@ @VERSION_FLAGS@ + libctf_nobfd_la_CPPFLAGS = $(AM_CPPFLAGS) -DNOBFD=1 + libctf_nobfd_la_SOURCES = ctf-archive.c ctf-dump.c ctf-create.c ctf-decl.c ctf-error.c \ + ctf-hash.c ctf-labels.c ctf-dedup.c ctf-link.c ctf-lookup.c \ +diff --git a/libctf/Makefile.in b/libctf/Makefile.in +index 5cfa100f9cc..b528781af97 100644 +--- a/libctf/Makefile.in ++++ b/libctf/Makefile.in +@@ -338,6 +338,7 @@ EXEEXT = @EXEEXT@ + + # Setup the testing framework, if you have one + EXPECT = expect ++EXTRA_SOVERSION_SUFFIX = @EXTRA_SOVERSION_SUFFIX@ + FGREP = @FGREP@ + GENCAT = @GENCAT@ + GMSGFMT = @GMSGFMT@ +@@ -469,8 +470,13 @@ AM_CFLAGS = -std=gnu99 @ac_libctf_warn_cflags@ @warn@ @c_warn@ @WARN_PEDANTIC@ @ + @INSTALL_LIBBFD_FALSE@include_HEADERS = + @INSTALL_LIBBFD_TRUE@include_HEADERS = $(INCDIR)/ctf.h $(INCDIR)/ctf-api.h + @INSTALL_LIBBFD_FALSE@noinst_LTLIBRARIES = libctf.la libctf-nobfd.la ++@HAVE_EXTRA_SOVERSION_SUFFIX_FALSE@gentoo_ctf_soversion = 0.0.0 ++ ++# libctf by default uses libtool versioning. Unfortunately that keeps us from adding ++# a supplement to the soversion. So we need to switch tracks and be creative. ++@HAVE_EXTRA_SOVERSION_SUFFIX_TRUE@gentoo_ctf_soversion = 0.0.0.$(EXTRA_SOVERSION_SUFFIX) + libctf_nobfd_la_LIBADD = @CTF_LIBADD@ $(ZLIB) +-libctf_nobfd_la_LDFLAGS = -version-info 0:0:0 @SHARED_LDFLAGS@ @VERSION_FLAGS@ ++libctf_nobfd_la_LDFLAGS = -release $(gentoo_ctf_soversion) @SHARED_LDFLAGS@ @VERSION_FLAGS@ + libctf_nobfd_la_CPPFLAGS = $(AM_CPPFLAGS) -DNOBFD=1 + libctf_nobfd_la_SOURCES = ctf-archive.c ctf-dump.c ctf-create.c \ + ctf-decl.c ctf-error.c ctf-hash.c ctf-labels.c ctf-dedup.c \ +diff --git a/libctf/configure b/libctf/configure +index 82bcf13a606..e961f637a69 100755 +--- a/libctf/configure ++++ b/libctf/configure +@@ -643,6 +643,9 @@ CTF_LIBADD + SHARED_LDFLAGS + NEED_CTF_QSORT_R_FALSE + NEED_CTF_QSORT_R_TRUE ++HAVE_EXTRA_SOVERSION_SUFFIX_FALSE ++HAVE_EXTRA_SOVERSION_SUFFIX_TRUE ++EXTRA_SOVERSION_SUFFIX + ENABLE_LIBCTF_HASH_DEBUGGING_FALSE + ENABLE_LIBCTF_HASH_DEBUGGING_TRUE + zlibinc +@@ -804,6 +807,7 @@ enable_maintainer_mode + enable_install_libbfd + with_system_zlib + enable_libctf_hash_debugging ++with_extra_soversion_suffix + ' + ac_precious_vars='build_alias + host_alias +@@ -1461,6 +1465,8 @@ Optional Packages: + both] + --with-gnu-ld assume the C compiler uses GNU ld [default=no] + --with-system-zlib use installed libz ++ --with-extra-soversion-suffix=SUFFIX ++ Append '.SUFFIX' to SONAME [[default=]] + + Some influential environment variables: + CC C compiler command +@@ -11586,7 +11592,7 @@ else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +-#line 11589 "configure" ++#line 11607 "configure" + #include "confdefs.h" + + #if HAVE_DLFCN_H +@@ -11692,7 +11698,7 @@ else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +-#line 11695 "configure" ++#line 11713 "configure" + #include "confdefs.h" + + #if HAVE_DLFCN_H +@@ -12899,6 +12905,23 @@ else + fi + + ++EXTRA_SOVERSION_SUFFIX= ++ ++# Check whether --with-extra-soversion-suffix was given. ++if test "${with_extra_soversion_suffix+set}" = set; then : ++ withval=$with_extra_soversion_suffix; EXTRA_SOVERSION_SUFFIX="${withval}" ++fi ++ ++ ++ if test -n "${with_extra_soversion_suffix}"; then ++ HAVE_EXTRA_SOVERSION_SUFFIX_TRUE= ++ HAVE_EXTRA_SOVERSION_SUFFIX_FALSE='#' ++else ++ HAVE_EXTRA_SOVERSION_SUFFIX_TRUE='#' ++ HAVE_EXTRA_SOVERSION_SUFFIX_FALSE= ++fi ++ ++ + # Similar to GDB_AC_CHECK_BFD. + OLD_CFLAGS=$CFLAGS + OLD_LDFLAGS=$LDFLAGS +@@ -13657,6 +13680,10 @@ if test -z "${ENABLE_LIBCTF_HASH_DEBUGGING_TRUE}" && test -z "${ENABLE_LIBCTF_HA + as_fn_error $? "conditional \"ENABLE_LIBCTF_HASH_DEBUGGING\" was never defined. + Usually this means the macro was only invoked conditionally." "$LINENO" 5 + fi ++if test -z "${HAVE_EXTRA_SOVERSION_SUFFIX_TRUE}" && test -z "${HAVE_EXTRA_SOVERSION_SUFFIX_FALSE}"; then ++ as_fn_error $? "conditional \"HAVE_EXTRA_SOVERSION_SUFFIX\" was never defined. ++Usually this means the macro was only invoked conditionally." "$LINENO" 5 ++fi + + if test -z "${NEED_CTF_QSORT_R_TRUE}" && test -z "${NEED_CTF_QSORT_R_FALSE}"; then + as_fn_error $? "conditional \"NEED_CTF_QSORT_R\" was never defined. +diff --git a/libctf/configure.ac b/libctf/configure.ac +index 80644b89d67..f7e6180afd8 100644 +--- a/libctf/configure.ac ++++ b/libctf/configure.ac +@@ -77,6 +77,14 @@ if test "${enable_libctf_hash_debugging}" = yes; then + fi + AM_CONDITIONAL(ENABLE_LIBCTF_HASH_DEBUGGING, test "${enable_libctf_hash_debugging}" = yes) + ++EXTRA_SOVERSION_SUFFIX= ++AC_ARG_WITH(extra-soversion-suffix, ++ AS_HELP_STRING([--with-extra-soversion-suffix=SUFFIX], ++ [Append '.SUFFIX' to SONAME [[default=]]]), ++[EXTRA_SOVERSION_SUFFIX="${withval}"]) ++AC_SUBST(EXTRA_SOVERSION_SUFFIX) ++AM_CONDITIONAL([HAVE_EXTRA_SOVERSION_SUFFIX], [test -n "${with_extra_soversion_suffix}"]) ++ + # Similar to GDB_AC_CHECK_BFD. + OLD_CFLAGS=$CFLAGS + OLD_LDFLAGS=$LDFLAGS +-- +2.31.1 + diff --git a/9999/0008-If-we-use-a-soversion-suffix-then-we-also-use-the-bd.patch b/9999/0008-If-we-use-a-soversion-suffix-then-we-also-use-the-bd.patch new file mode 100644 index 0000000..b88f50e --- /dev/null +++ b/9999/0008-If-we-use-a-soversion-suffix-then-we-also-use-the-bd.patch @@ -0,0 +1,111 @@ +From 235448cc5c53641417e17fd39ced95a21053c8ca Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Andreas=20K=2E=20H=C3=BCttel?= +Date: Sat, 24 Jul 2021 19:25:32 +0200 +Subject: [PATCH 2/2] If we use a soversion suffix, then we also use the bdf + version as soversion + +--- + libctf/Makefile.am | 3 ++- + libctf/Makefile.in | 3 ++- + libctf/configure | 8 ++++++-- + libctf/configure.ac | 2 ++ + 4 files changed, 12 insertions(+), 4 deletions(-) + +diff --git a/libctf/Makefile.am b/libctf/Makefile.am +index eabc7fa8394..e1304e8e89b 100644 +--- a/libctf/Makefile.am ++++ b/libctf/Makefile.am +@@ -22,6 +22,7 @@ ACLOCAL_AMFLAGS = -I .. -I ../config -I ../bfd + AUTOMAKE_OPTIONS = dejagnu foreign no-texinfo.tex + + EXTRA_SOVERSION_SUFFIX = @EXTRA_SOVERSION_SUFFIX@ ++BFD_VERSION = @BFD_VERSION@ + + # This is where we get zlib from. zlibdir is -L../zlib and zlibinc is + # -I../zlib, unless we were configured with --with-system-zlib, in which +@@ -47,7 +48,7 @@ endif + # a supplement to the soversion. So we need to switch tracks and be creative. + + if HAVE_EXTRA_SOVERSION_SUFFIX +-gentoo_ctf_soversion = 0.0.0.$(EXTRA_SOVERSION_SUFFIX) ++gentoo_ctf_soversion = "$(BFD_VERSION).$(EXTRA_SOVERSION_SUFFIX)" + else + gentoo_ctf_soversion = 0.0.0 + endif +diff --git a/libctf/Makefile.in b/libctf/Makefile.in +index b528781af97..18d482411e8 100644 +--- a/libctf/Makefile.in ++++ b/libctf/Makefile.in +@@ -316,6 +316,7 @@ AUTOCONF = @AUTOCONF@ + AUTOHEADER = @AUTOHEADER@ + AUTOMAKE = @AUTOMAKE@ + AWK = @AWK@ ++BFD_VERSION = @BFD_VERSION@ + CATALOGS = @CATALOGS@ + CATOBJEXT = @CATOBJEXT@ + CC = @CC@ +@@ -474,7 +475,7 @@ AM_CFLAGS = -std=gnu99 @ac_libctf_warn_cflags@ @warn@ @c_warn@ @WARN_PEDANTIC@ @ + + # libctf by default uses libtool versioning. Unfortunately that keeps us from adding + # a supplement to the soversion. So we need to switch tracks and be creative. +-@HAVE_EXTRA_SOVERSION_SUFFIX_TRUE@gentoo_ctf_soversion = 0.0.0.$(EXTRA_SOVERSION_SUFFIX) ++@HAVE_EXTRA_SOVERSION_SUFFIX_TRUE@gentoo_ctf_soversion = "$(BFD_VERSION).$(EXTRA_SOVERSION_SUFFIX)" + libctf_nobfd_la_LIBADD = @CTF_LIBADD@ $(ZLIB) + libctf_nobfd_la_LDFLAGS = -release $(gentoo_ctf_soversion) @SHARED_LDFLAGS@ @VERSION_FLAGS@ + libctf_nobfd_la_CPPFLAGS = $(AM_CPPFLAGS) -DNOBFD=1 +diff --git a/libctf/configure b/libctf/configure +index e961f637a69..520d3a5cb3e 100755 +--- a/libctf/configure ++++ b/libctf/configure +@@ -643,6 +643,7 @@ CTF_LIBADD + SHARED_LDFLAGS + NEED_CTF_QSORT_R_FALSE + NEED_CTF_QSORT_R_TRUE ++BFD_VERSION + HAVE_EXTRA_SOVERSION_SUFFIX_FALSE + HAVE_EXTRA_SOVERSION_SUFFIX_TRUE + EXTRA_SOVERSION_SUFFIX +@@ -11592,7 +11593,7 @@ else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +-#line 11607 "configure" ++#line 11608 "configure" + #include "confdefs.h" + + #if HAVE_DLFCN_H +@@ -11698,7 +11699,7 @@ else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +-#line 11713 "configure" ++#line 11714 "configure" + #include "confdefs.h" + + #if HAVE_DLFCN_H +@@ -12922,6 +12923,9 @@ else + fi + + ++BFD_VERSION=$(${srcdir}/../bfd/configure --version | sed -n -e '1s,.* ,,p') ++ ++ + # Similar to GDB_AC_CHECK_BFD. + OLD_CFLAGS=$CFLAGS + OLD_LDFLAGS=$LDFLAGS +diff --git a/libctf/configure.ac b/libctf/configure.ac +index f7e6180afd8..5306e5499ec 100644 +--- a/libctf/configure.ac ++++ b/libctf/configure.ac +@@ -85,6 +85,8 @@ AC_ARG_WITH(extra-soversion-suffix, + AC_SUBST(EXTRA_SOVERSION_SUFFIX) + AM_CONDITIONAL([HAVE_EXTRA_SOVERSION_SUFFIX], [test -n "${with_extra_soversion_suffix}"]) + ++AC_SUBST(BFD_VERSION, $(${srcdir}/../bfd/configure --version | sed -n -e '1s,.* ,,p'), [Version of the accompanying bfd linker]) ++ + # Similar to GDB_AC_CHECK_BFD. + OLD_CFLAGS=$CFLAGS + OLD_LDFLAGS=$LDFLAGS +-- +2.31.1 +