commit:     64b018b8728e2fc39ff4496f3d80da3e2a6a76f0
Author:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 30 08:53:18 2023 +0000
Commit:     Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Wed Aug 30 08:53:18 2023 +0000
URL:        https://gitweb.gentoo.org/repo/proj/prefix.git/commit/?id=64b018b8

sys-devel/binutils-2.40-r8: pull in EAPI=8 ebuild from gx86

Signed-off-by: Fabian Groffen <grobian <AT> gentoo.org>

 sys-devel/binutils/Manifest                        |   7 +-
 sys-devel/binutils/binutils-2.34-r1.ebuild         | 445 ------------------
 sys-devel/binutils/binutils-2.39-r2.ebuild         | 498 --------------------
 sys-devel/binutils/binutils-2.39-r4.ebuild         | 499 ---------------------
 ...tils-2.40-r2.ebuild => binutils-2.40-r8.ebuild} |  20 +-
 .../files/binutils-2.24-cygwin-nointl.patch        |  26 --
 .../files/binutils-2.29.1-nogoldtest.patch         |  27 --
 .../binutils/files/binutils-2.33-gcc-10.patch      |  39 --
 .../binutils/files/binutils-2.34-riscv-SEGV.patch  |  40 --
 ...inutils-2.39-protected-visibility-solaris.patch |  64 ---
 .../binutils/files/binutils-configure-LANG.patch   |  65 +++
 11 files changed, 80 insertions(+), 1650 deletions(-)

diff --git a/sys-devel/binutils/Manifest b/sys-devel/binutils/Manifest
index 83ad995e9e..b6c1313f33 100644
--- a/sys-devel/binutils/Manifest
+++ b/sys-devel/binutils/Manifest
@@ -1,7 +1,2 @@
-DIST binutils-2.34-patches-4.tar.xz 95232 BLAKE2B 
0a355120ecaf447d863f6d0837028061968166c9024da36212ce7d172ee2060e4027be1fca0089e38ab9073b5332307ff1dc05b868603bd2aa0ec8e88af7cd0a
 SHA512 
e593edbeddaf97ef23fa8eb25c5714c7f2dd2500d11422bd9dba42e119884fe71593adc98862f74c7d391ceb298556ed049eee3c504733c634faef236045876b
-DIST binutils-2.34.tar.xz 21637796 BLAKE2B 
07dd23916a7d27f71c3f160c8c16abe2bd4fce294c738c665a012a3be6a87dbe8160d0c38740524f9025e01d438e99b2a94bcf9f9f79ee214f5dd033de8aad3d
 SHA512 
2c7976939dcf5e8c5b7374cccd39bfe803b1bec73c6abfa0eb17c24e1942574c6bdb874c66a092a82adc443182eacd8a5a8001c19a76101f0c7ba40c27de0bbd
-DIST binutils-2.39-patches-4.tar.xz 62880 BLAKE2B 
5cc335769d9c88417583ce059c61d0d7655f3ab9ac69647e6e2f65bd3a9dd143fe34c50bb68ab81d4226ddd0e4ef405d7102f67375a672eedc3d01b92b8ef497
 SHA512 
ef81350979af64cf35800b39982c84657a5c01362c01d221164a43d8f0dd80276c9f052c55d24516fad457e6671a58d467d71b5edd6c1f53fddbdb31172a21ee
-DIST binutils-2.39-patches-5.tar.xz 82924 BLAKE2B 
2cf75f661989f22270d6afe5f3c543814eb6a331be4493016fa2871e1f10a84a123c1c51e77a19b35e46680b9fe77390cb1532ca40d470a6041fa768fed3ccd7
 SHA512 
4b5811b4822b3a06f590fc7d082dc0ddf18a6058ac23887254e2ee9bd63c7f06f1636e446152115c7e0b01a6c5298a0d9df6904bd1582e66504ccde80dd1ecbd
-DIST binutils-2.39.tar.xz 25167756 BLAKE2B 
ac6a5296c6586d53eaadcbffc5c399a6d79edf72450b9bb8b3525ce525129cef3d2eb90c85ef3bb3270b5a03b0e1ffb8f0b705f028158726f9777ebb8685066f
 SHA512 
68e038f339a8c21faa19a57bbc447a51c817f47c2e06d740847c6e9cc3396c025d35d5369fa8c3f8b70414757c89f0e577939ddc0d70f283182504920f53b0a3
-DIST binutils-2.40-patches-2.tar.xz 183760 BLAKE2B 
447f1c40ac8212b1e91f6f2137f87958c3f4e2366b11b9979d9d09d52e9fcde9a9d74f0c1871616157e001f505849fceb2097a512f434b9c848885e367a07c35
 SHA512 
30efbfcbd2d936c74d9480e4f2f4b8dcd30abcd0f1b22d21d20558002fdb8c90bd2fe97e3f27c2905714dcfd1297cac2646ede1e2c3d9fbf159f93c8cf01a290
+DIST binutils-2.40-patches-7.tar.xz 299188 BLAKE2B 
170cd2432e0458889b240c3603461d0b4bfa62d5314634b101a629db455d87235ac14ad44c63920b713d5235fa8b73902960df1019153873ef06a33aa7050b4b
 SHA512 
a60da163caee68fe1fa355385d404e8998ebed0e390d50e0713e95334733a8b4e37bc63d522817284c027953e43848dbc98042461a47131fb53bc69203b4ee87
 DIST binutils-2.40.tar.xz 25241484 BLAKE2B 
8d799f7c595f878b9af5b17a490021dd8b8300ac2fe0ed8574c012929d22d2d0493e003a3e631a9436e8e712da801779b777c566167fe42b0bde119ffa5ad1c2
 SHA512 
a37e042523bc46494d99d5637c3f3d8f9956d9477b748b3b1f6d7dfbb8d968ed52c932e88a4e946c6f77b8f48f1e1b360ca54c3d298f17193f3b4963472f6925

diff --git a/sys-devel/binutils/binutils-2.34-r1.ebuild 
b/sys-devel/binutils/binutils-2.34-r1.ebuild
deleted file mode 100644
index 48fc6daf6d..0000000000
--- a/sys-devel/binutils/binutils-2.34-r1.ebuild
+++ /dev/null
@@ -1,445 +0,0 @@
-# Copyright 1999-2021 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=7
-
-inherit eutils libtool flag-o-matic gnuconfig multilib toolchain-funcs
-
-DESCRIPTION="Tools necessary to build programs"
-HOMEPAGE="https://sourceware.org/binutils/";
-LICENSE="GPL-3+"
-IUSE="default-gold doc +gold multitarget +nls +plugins static-libs test"
-REQUIRED_USE="default-gold? ( gold )"
-
-# Variables that can be set here:
-# PATCH_VER          - the patchset version
-#                      Default: empty, no patching
-# PATCH_BINUTILS_VER - the binutils version in the patchset name
-#                    - Default: PV
-# PATCH_DEV          - Use download URI 
https://dev.gentoo.org/~{PATCH_DEV}/distfiles/...
-#                      for the patchsets
-
-PATCH_VER=4
-PATCH_DEV=dilfridge
-
-case ${PV} in
-       9999)
-               EGIT_REPO_URI="https://sourceware.org/git/binutils-gdb.git";
-               inherit git-r3
-               S=${WORKDIR}/binutils
-               EGIT_CHECKOUT_DIR=${S}
-               SLOT=${PV}
-               ;;
-       *.9999)
-               EGIT_REPO_URI="https://sourceware.org/git/binutils-gdb.git";
-               inherit git-r3
-               S=${WORKDIR}/binutils
-               EGIT_CHECKOUT_DIR=${S}
-               EGIT_BRANCH=$(ver_cut 1-2)
-               EGIT_BRANCH="binutils-${EGIT_BRANCH/./_}-branch"
-               SLOT=$(ver_cut 1-2)
-               ;;
-       *)
-               SRC_URI="mirror://gnu/binutils/binutils-${PV}.tar.xz"
-               SLOT=$(ver_cut 1-2)
-               KEYWORDS="~amd64-linux ~x86-linux ~x64-solaris"
-               ;;
-esac
-
-#
-# The Gentoo patchset
-#
-PATCH_BINUTILS_VER=${PATCH_BINUTILS_VER:-${PV}}
-PATCH_DEV=${PATCH_DEV:-sam}
-
-[[ -z ${PATCH_VER} ]] || SRC_URI="${SRC_URI}
-       
https://dev.gentoo.org/~${PATCH_DEV}/distfiles/binutils-${PATCH_BINUTILS_VER}-patches-${PATCH_VER}.tar.xz";
-
-#
-# The cross-compile logic
-#
-export CTARGET=${CTARGET:-${CHOST}}
-if [[ ${CTARGET} == ${CHOST} ]] ; then
-       if [[ ${CATEGORY} == cross-* ]] ; then
-               export CTARGET=${CATEGORY#cross-}
-       fi
-fi
-is_cross() { [[ ${CHOST} != ${CTARGET} ]] ; }
-
-#
-# The dependencies
-#
-RDEPEND="
-       >=sys-devel/binutils-config-3
-       sys-libs/zlib
-"
-DEPEND="${RDEPEND}"
-BDEPEND="
-       doc? ( sys-apps/texinfo )
-       test? ( dev-util/dejagnu )
-       nls? ( sys-devel/gettext )
-       sys-devel/flex
-       app-alternatives/yacc
-"
-
-RESTRICT="!test? ( test )"
-
-PATCHES=(
-       "${FILESDIR}"/${PN}-2.33-gcc-10.patch
-       "${FILESDIR}"/${PN}-2.34-riscv-SEGV.patch
-       "${FILESDIR}"/${PN}-2.22-solaris-anonymous-version-script-fix.patch
-)
-
-MY_BUILDDIR=${WORKDIR}/build
-
-src_unpack() {
-       case ${PV} in
-               *9999)
-                       git-r3_src_unpack
-                       ;;
-               *)
-                       ;;
-       esac
-       default
-       mkdir -p "${MY_BUILDDIR}"
-}
-
-src_prepare() {
-       if [[ ! -z ${PATCH_VER} ]] ; then
-               # Use upstream patch to enable development mode
-               rm -v "${WORKDIR}/patch"/0000-Gentoo-Git-is-development.patch 
|| die
-
-               einfo "Applying binutils-${PATCH_BINUTILS_VER} patchset 
${PATCH_VER}"
-               eapply "${WORKDIR}/patch"/*.patch
-       fi
-
-       # This check should probably go somewhere else, like pkg_pretend.
-       if [[ ${CTARGET} == *-uclibc* ]] ; then
-               if grep -qs 'linux-gnu' "${S}"/ltconfig ; then
-                       die "sorry, but this binutils doesn't yet support 
uClibc :("
-               fi
-       fi
-
-       # Make sure our explicit libdir paths don't get clobbered. #562460
-       sed -i \
-               -e 's:@bfdlibdir@:@libdir@:g' \
-               -e 's:@bfdincludedir@:@includedir@:g' \
-               {bfd,opcodes}/Makefile.in || die
-
-       # Fix locale issues if possible #122216
-       if [[ -e ${FILESDIR}/binutils-configure-LANG.patch ]] ; then
-               einfo "Fixing misc issues in configure files"
-               for f in $(find "${S}" -name configure -exec grep -l 'autoconf 
version 2.13' {} +) ; do
-                       ebegin "  Updating ${f/${S}\/}"
-                       patch "${f}" 
"${FILESDIR}"/binutils-configure-LANG.patch >& "${T}"/configure-patch.log \
-                               || eerror "Please file a bug about this"
-                       eend $?
-               done
-       fi
-
-       # Fix conflicts with newer glibc #272594
-       if [[ -e libiberty/testsuite/test-demangle.c ]] ; then
-               sed -i 's:\<getline\>:get_line:g' 
libiberty/testsuite/test-demangle.c
-       fi
-
-       # Apply things from PATCHES and user dirs
-       default
-
-       # Run misc portage update scripts
-       gnuconfig_update
-       elibtoolize --portage --no-uclibc
-}
-
-toolchain-binutils_bugurl() {
-       printf "https://bugs.gentoo.org/";
-}
-toolchain-binutils_pkgversion() {
-       printf "Gentoo ${PV}"
-       [[ -n ${PATCH_VER} ]] && printf " p${PATCH_VER}"
-}
-
-src_configure() {
-       # Setup some paths
-       LIBPATH=/usr/$(get_libdir)/binutils/${CTARGET}/${PV}
-       INCPATH=${LIBPATH}/include
-       DATAPATH=/usr/share/binutils-data/${CTARGET}/${PV}
-       if is_cross ; then
-               TOOLPATH=/usr/${CHOST}/${CTARGET}
-       else
-               TOOLPATH=/usr/${CTARGET}
-       fi
-       BINPATH=${TOOLPATH}/binutils-bin/${PV}
-
-       # Make sure we filter $LINGUAS so that only ones that
-       # actually work make it through #42033
-       strip-linguas -u */po
-
-       # Keep things sane
-       strip-flags
-
-       local x
-       echo
-       for x in CATEGORY CBUILD CHOST CTARGET CFLAGS LDFLAGS ; do
-               einfo "$(printf '%10s' ${x}:) ${!x}"
-       done
-       echo
-
-       cd "${MY_BUILDDIR}"
-       local myconf=()
-
-       if use plugins ; then
-               myconf+=( --enable-plugins )
-       fi
-       # enable gold (installed as ld.gold) and ld's plugin architecture
-       if use gold ; then
-               myconf+=( --enable-gold )
-               if use default-gold; then
-                       myconf+=( --enable-gold=default )
-               fi
-       fi
-
-       if use nls ; then
-               myconf+=( --without-included-gettext )
-               [[ ${CHOST} == *"-solaris"* ]] && append-libs -lintl
-       else
-               myconf+=( --disable-nls )
-       fi
-
-       myconf+=( --with-system-zlib )
-
-       # For bi-arch systems, enable a 64bit bfd.  This matches
-       # the bi-arch logic in toolchain.eclass. #446946
-       # We used to do it for everyone, but it's slow on 32bit arches. #438522
-       case $(tc-arch) in
-               ppc|sparc|x86) myconf+=( --enable-64-bit-bfd ) ;;
-       esac
-
-       use multitarget && myconf+=( --enable-targets=all --enable-64-bit-bfd )
-
-       [[ -n ${CBUILD} ]] && myconf+=( --build=${CBUILD} )
-
-       is_cross && myconf+=(
-               --with-sysroot="${EPREFIX}"/usr/${CTARGET}
-               --enable-poison-system-directories
-       )
-
-       # glibc-2.3.6 lacks support for this ... so rather than force glibc-2.5+
-       # on everyone in alpha (for now), we'll just enable it when possible
-       has_version ">=${CATEGORY}/glibc-2.5" && myconf+=( --enable-secureplt )
-       has_version ">=sys-libs/glibc-2.5" && myconf+=( --enable-secureplt )
-
-       # mips can't do hash-style=gnu ...
-       # let's not do this on Solaris either
-       if [[ $(tc-arch) != mips && ${CHOST} != *-solaris* ]] ; then
-               myconf+=( --enable-default-hash-style=gnu )
-       fi
-
-       myconf+=(
-               --prefix="${EPREFIX}"/usr
-               --host=${CHOST}
-               --target=${CTARGET}
-               --datadir="${EPREFIX}"${DATAPATH}
-               --datarootdir="${EPREFIX}"${DATAPATH}
-               --infodir="${EPREFIX}"${DATAPATH}/info
-               --mandir="${EPREFIX}"${DATAPATH}/man
-               --bindir="${EPREFIX}"${BINPATH}
-               --libdir="${EPREFIX}"${LIBPATH}
-               --libexecdir="${EPREFIX}"${LIBPATH}
-               --includedir="${EPREFIX}"${INCPATH}
-               --enable-obsolete
-               --enable-shared
-               --enable-threads
-               # Newer versions (>=2.27) offer a configure flag now.
-               --enable-relro
-               # Newer versions (>=2.24) make this an explicit option. #497268
-               --enable-install-libiberty
-               --disable-werror
-               --with-bugurl="$(toolchain-binutils_bugurl)"
-               --with-pkgversion="$(toolchain-binutils_pkgversion)"
-               $(use_enable static-libs static)
-               ${EXTRA_ECONF}
-               # Disable modules that are in a combined binutils/gdb tree. 
#490566
-               --disable-{gdb,libdecnumber,readline,sim}
-               # Strip out broken static link flags.
-               # https://gcc.gnu.org/PR56750
-               --without-stage1-ldflags
-               # Change SONAME to avoid conflict across
-               # {native,cross}/binutils, binutils-libs. #666100
-               --with-extra-soversion-suffix=gentoo-${CATEGORY}-${PN}-$(usex 
multitarget mt st)
-       )
-       echo ./configure "${myconf[@]}"
-       "${S}"/configure "${myconf[@]}" || die
-
-       # Prevent makeinfo from running if doc is unset.
-       if ! use doc ; then
-               sed -i \
-                       -e '/^MAKEINFO/s:=.*:= true:' \
-                       Makefile || die
-       fi
-}
-
-src_compile() {
-       cd "${MY_BUILDDIR}"
-       # see Note [tooldir hack for ldscripts]
-       emake tooldir="${EPREFIX}${TOOLPATH}" all
-
-       # only build info pages if the user wants them
-       if use doc ; then
-               emake info
-       fi
-
-       # we nuke the manpages when we're left with junk
-       # (like when we bootstrap, no perl -> no manpages)
-       find . -name '*.1' -a -size 0 -delete
-}
-
-src_test() {
-       cd "${MY_BUILDDIR}"
-
-       # bug 637066
-       filter-flags -Wall -Wreturn-type
-
-       emake -k check
-}
-
-src_install() {
-       local x d
-
-       cd "${MY_BUILDDIR}"
-       # see Note [tooldir hack for ldscripts]
-       emake DESTDIR="${D}" tooldir="${EPREFIX}${LIBPATH}" install
-       rm -rf "${ED}"/${LIBPATH}/bin
-       use static-libs || find "${ED}" -name '*.la' -delete
-
-       # Newer versions of binutils get fancy with ${LIBPATH} #171905
-       cd "${ED}"/${LIBPATH}
-       for d in ../* ; do
-               [[ ${d} == ../${PV} ]] && continue
-               mv ${d}/* . || die
-               rmdir ${d} || die
-       done
-
-       # Now we collect everything intp the proper SLOT-ed dirs
-       # When something is built to cross-compile, it installs into
-       # /usr/$CHOST/ by default ... we have to 'fix' that :)
-       if is_cross ; then
-               cd "${ED}"/${BINPATH}
-               for x in * ; do
-                       mv ${x} ${x/${CTARGET}-}
-               done
-
-               if [[ -d ${ED}/usr/${CHOST}/${CTARGET} ]] ; then
-                       mv "${ED}"/usr/${CHOST}/${CTARGET}/include 
"${ED}"/${INCPATH}
-                       mv "${ED}"/usr/${CHOST}/${CTARGET}/lib/* 
"${ED}"/${LIBPATH}/
-                       rm -r "${ED}"/usr/${CHOST}/{include,lib}
-               fi
-       fi
-       insinto ${INCPATH}
-       local libiberty_headers=(
-               # Not all the libiberty headers.  See 
libiberty/Makefile.in:install_to_libdir.
-               demangle.h
-               dyn-string.h
-               fibheap.h
-               hashtab.h
-               libiberty.h
-               objalloc.h
-               splay-tree.h
-       )
-       doins "${libiberty_headers[@]/#/${S}/include/}"
-       if [[ -d ${ED}/${LIBPATH}/lib ]] ; then
-               mv "${ED}"/${LIBPATH}/lib/* "${ED}"/${LIBPATH}/
-               rm -r "${ED}"/${LIBPATH}/lib
-       fi
-
-       # Generate an env.d entry for this binutils
-       insinto /etc/env.d/binutils
-       cat <<-EOF > "${T}"/env.d
-               TARGET="${CTARGET}"
-               VER="${PV}"
-               LIBPATH="${EPREFIX}${LIBPATH}"
-       EOF
-       newins "${T}"/env.d ${CTARGET}-${PV}
-
-       # Handle documentation
-       if ! is_cross ; then
-               cd "${S}"
-               dodoc README
-               docinto bfd
-               dodoc bfd/ChangeLog* bfd/README bfd/PORTING bfd/TODO
-               docinto binutils
-               dodoc binutils/ChangeLog binutils/NEWS binutils/README
-               docinto gas
-               dodoc gas/ChangeLog* gas/CONTRIBUTORS gas/NEWS gas/README*
-               docinto gprof
-               dodoc gprof/ChangeLog* gprof/TEST gprof/TODO gprof/bbconv.pl
-               docinto ld
-               dodoc ld/ChangeLog* ld/README ld/NEWS ld/TODO
-               docinto libiberty
-               dodoc libiberty/ChangeLog* libiberty/README
-               docinto opcodes
-               dodoc opcodes/ChangeLog*
-       fi
-
-       # Remove shared info pages
-       rm -f "${ED}"/${DATAPATH}/info/{dir,configure.info,standards.info}
-
-       # Trim all empty dirs
-       find "${ED}" -depth -type d -exec rmdir {} + 2>/dev/null
-}
-
-pkg_postinst() {
-       # Make sure this ${CTARGET} has a binutils version selected
-       [[ -e ${EROOT}/etc/env.d/binutils/config-${CTARGET} ]] && return 0
-       binutils-config ${CTARGET}-${PV}
-}
-
-pkg_postrm() {
-       local current_profile=$(binutils-config -c ${CTARGET})
-
-       # If no other versions exist, then uninstall for this
-       # target ... otherwise, switch to the newest version
-       # Note: only do this if this version is unmerged.  We
-       #       rerun binutils-config if this is a remerge, as
-       #       we want the mtimes on the symlinks updated (if
-       #       it is the same as the current selected profile)
-       if [[ ! -e ${EPREFIX}${BINPATH}/ld ]] && [[ ${current_profile} == 
${CTARGET}-${PV} ]] ; then
-               local choice=$(binutils-config -l | grep ${CTARGET} | awk 
'{print $2}')
-               choice=${choice//$'\n'/ }
-               choice=${choice/* }
-               if [[ -z ${choice} ]] ; then
-                       env -i ROOT="${ROOT}" binutils-config -u ${CTARGET}
-               else
-                       binutils-config ${choice}
-               fi
-       elif [[ $(CHOST=${CTARGET} binutils-config -c) == ${CTARGET}-${PV} ]] ; 
then
-               binutils-config ${CTARGET}-${PV}
-       fi
-}
-
-# Note [slotting support]
-# -----------------------
-# Gentoo's layout for binutils files is non-standard as Gentoo
-# supports slotted installation for binutils. Many tools
-# still expect binutils to reside in known locations.
-# binutils-config package restores symlinks into known locations,
-# like:
-#    /usr/bin/${CTARGET}-<tool>
-#    /usr/bin/${CHOST}/${CTARGET}/lib/ldscrips
-#    /usr/include/
-#
-# Note [tooldir hack for ldscripts]
-# ---------------------------------
-# Build system does not allow ./configure to tweak every location
-# we need for slotting binutils hence all the shuffling in
-# src_install(). This note is about SCRIPTDIR define handling.
-#
-# SCRIPTDIR defines 'ldscripts/' directory location. SCRIPTDIR value
-# is set at build-time in ld/Makefile.am as: 'scriptdir = $(tooldir)/lib'
-# and hardcoded as -DSCRIPTDIR='"$(scriptdir)"' at compile time.
-# Thus we can't just move files around after compilation finished.
-#
-# Our goal is the following:
-# - at build-time set scriptdir to point to symlinked location:
-#   ${TOOLPATH}: /usr/${CHOST} (or /usr/${CHOST}/${CTARGET} for cross-case)
-# - at install-time set scriptdir to point to slotted location:
-#   ${LIBPATH}: /usr/$(get_libdir)/binutils/${CTARGET}/${PV}

diff --git a/sys-devel/binutils/binutils-2.39-r2.ebuild 
b/sys-devel/binutils/binutils-2.39-r2.ebuild
deleted file mode 100644
index e409201076..0000000000
--- a/sys-devel/binutils/binutils-2.39-r2.ebuild
+++ /dev/null
@@ -1,498 +0,0 @@
-# Copyright 1999-2022 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=7
-
-inherit libtool flag-o-matic gnuconfig strip-linguas toolchain-funcs
-
-DESCRIPTION="Tools necessary to build programs"
-HOMEPAGE="https://sourceware.org/binutils/";
-
-LICENSE="GPL-3+"
-IUSE="cet default-gold doc gold gprofng multitarget +nls pgo +plugins 
static-libs test vanilla"
-REQUIRED_USE="default-gold? ( gold )"
-
-# Variables that can be set here  (ignored for live ebuilds)
-# PATCH_VER          - the patchset version
-#                      Default: empty, no patching
-# PATCH_BINUTILS_VER - the binutils version in the patchset name
-#                    - Default: PV
-# PATCH_DEV          - Use download URI 
https://dev.gentoo.org/~{PATCH_DEV}/distfiles/...
-#                      for the patchsets
-
-PATCH_VER=4
-PATCH_DEV=dilfridge
-
-if [[ ${PV} == 9999* ]]; then
-       inherit git-r3
-       SLOT=${PV}
-else
-       PATCH_BINUTILS_VER=${PATCH_BINUTILS_VER:-${PV}}
-       PATCH_DEV=${PATCH_DEV:-dilfridge}
-       SRC_URI="mirror://gnu/binutils/binutils-${PV}.tar.xz 
https://dev.gentoo.org/~${PATCH_DEV}/distfiles/binutils-${PV}.tar.xz";
-       [[ -z ${PATCH_VER} ]] || SRC_URI="${SRC_URI}
-               
https://dev.gentoo.org/~${PATCH_DEV}/distfiles/binutils-${PATCH_BINUTILS_VER}-patches-${PATCH_VER}.tar.xz";
-       SLOT=$(ver_cut 1-2)
-       KEYWORDS="~amd64-linux ~x86-linux ~x64-solaris"
-fi
-
-#
-# The cross-compile logic
-#
-export CTARGET=${CTARGET:-${CHOST}}
-if [[ ${CTARGET} == ${CHOST} ]] ; then
-       if [[ ${CATEGORY} == cross-* ]] ; then
-               export CTARGET=${CATEGORY#cross-}
-       fi
-fi
-is_cross() { [[ ${CHOST} != ${CTARGET} ]] ; }
-
-#
-# The dependencies
-#
-RDEPEND="
-       >=sys-devel/binutils-config-3
-       sys-libs/zlib
-"
-DEPEND="${RDEPEND}"
-BDEPEND="
-       doc? ( sys-apps/texinfo )
-       test? (
-               dev-util/dejagnu
-               sys-devel/bc
-       )
-       nls? ( sys-devel/gettext )
-       sys-devel/flex
-       app-alternatives/yacc
-"
-
-RESTRICT="!test? ( test )"
-
-PATCHES=(
-       "${FILESDIR}"/${PN}-2.22-solaris-anonymous-version-script-fix.patch
-)
-
-MY_BUILDDIR=${WORKDIR}/build
-
-src_unpack() {
-       if [[ ${PV} == 9999* ]] ; then
-               
EGIT_REPO_URI="https://anongit.gentoo.org/git/proj/toolchain/binutils-patches.git";
-               EGIT_CHECKOUT_DIR=${WORKDIR}/patches-git
-               git-r3_src_unpack
-               mv patches-git/9999 patch || die
-
-               EGIT_REPO_URI="https://sourceware.org/git/binutils-gdb.git";
-               S=${WORKDIR}/binutils
-               EGIT_CHECKOUT_DIR=${S}
-               git-r3_src_unpack
-       else
-               unpack ${P/-hppa64/}.tar.xz
-
-               cd "${WORKDIR}" || die
-               unpack 
binutils-${PATCH_BINUTILS_VER}-patches-${PATCH_VER}.tar.xz
-
-               # _p patch versions are Gentoo specific tarballs ...
-               local dir=${P%_p?}
-               dir=${dir/-hppa64/}
-
-               S=${WORKDIR}/${dir}
-       fi
-
-       cd "${WORKDIR}" || die
-       mkdir -p "${MY_BUILDDIR}" || die
-}
-
-src_prepare() {
-       local patchsetname
-       if [[ ${PV} == 9999* ]] ; then
-               patchsetname="from git master"
-       else
-               patchsetname="${PATCH_BINUTILS_VER}-${PATCH_VER}"
-       fi
-
-       if [[ -n ${PATCH_VER} ]] || [[ ${PV} == 9999* ]] ; then
-               if ! use vanilla; then
-                       einfo "Applying binutils patchset ${patchsetname}"
-                       eapply "${WORKDIR}/patch"
-                       einfo "Done."
-               fi
-       fi
-
-       # Make sure our explicit libdir paths don't get clobbered, bug #562460
-       sed -i \
-               -e 's:@bfdlibdir@:@libdir@:g' \
-               -e 's:@bfdincludedir@:@includedir@:g' \
-               {bfd,opcodes}/Makefile.in || die
-
-       # Fix locale issues if possible, bug #122216
-       if [[ -e ${FILESDIR}/binutils-configure-LANG.patch ]] ; then
-               einfo "Fixing misc issues in configure files"
-               for f in $(find "${S}" -name configure -exec grep -l 'autoconf 
version 2.13' {} +) ; do
-                       ebegin "  Updating ${f/${S}\/}"
-                       patch "${f}" 
"${FILESDIR}"/binutils-configure-LANG.patch >& "${T}"/configure-patch.log \
-                               || eerror "Please file a bug about this"
-                       eend $?
-               done
-       fi
-
-       # Apply things from PATCHES and user dirs
-       default
-
-       # Run misc portage update scripts
-       gnuconfig_update
-       elibtoolize --portage --no-uclibc
-}
-
-toolchain-binutils_bugurl() {
-       printf "https://bugs.gentoo.org/";
-}
-toolchain-binutils_pkgversion() {
-       printf "Gentoo ${PV}"
-       [[ -n ${PATCH_VER} ]] && printf " p${PATCH_VER}"
-}
-
-src_configure() {
-       # See 
https://www.gnu.org/software/make/manual/html_node/Parallel-Output.html
-       # Avoid really confusing logs from subconfigure spam, makes logs far
-       # more legible.
-       MAKEOPTS="--output-sync=line ${MAKEOPTS}"
-
-       # Setup some paths
-       LIBPATH=/usr/$(get_libdir)/binutils/${CTARGET}/${PV}
-       INCPATH=${LIBPATH}/include
-       DATAPATH=/usr/share/binutils-data/${CTARGET}/${PV}
-       if is_cross ; then
-               TOOLPATH=/usr/${CHOST}/${CTARGET}
-       else
-               TOOLPATH=/usr/${CTARGET}
-       fi
-       BINPATH=${TOOLPATH}/binutils-bin/${PV}
-
-       # Make sure we filter $LINGUAS so that only ones that
-       # actually work make it through, bug #42033
-       strip-linguas -u */po
-
-       # Keep things sane
-       strip-flags
-
-       use elibc_musl && append-ldflags -Wl,-z,stack-size=2097152
-
-       local x
-       echo
-       for x in CATEGORY CBUILD CHOST CTARGET CFLAGS LDFLAGS ; do
-               einfo "$(printf '%10s' ${x}:) ${!x}"
-       done
-       echo
-
-       cd "${MY_BUILDDIR}" || die
-       local myconf=()
-
-       if use plugins ; then
-               myconf+=( --enable-plugins )
-       fi
-       # enable gold (installed as ld.gold) and ld's plugin architecture
-       if use gold ; then
-               myconf+=( --enable-gold )
-               if use default-gold; then
-                       myconf+=( --enable-gold=default )
-               fi
-       fi
-
-       if use nls ; then
-               myconf+=( --without-included-gettext )
-               [[ ${CHOST} == *"-solaris"* ]] && append-libs -lintl
-       else
-               myconf+=( --disable-nls )
-       fi
-
-       myconf+=( --with-system-zlib )
-
-       # For bi-arch systems, enable a 64bit bfd. This matches the bi-arch
-       # logic in toolchain.eclass. bug #446946
-       #
-       # We used to do it for everyone, but it's slow on 32bit arches. bug 
#438522
-       case $(tc-arch) in
-               ppc|sparc|x86) myconf+=( --enable-64-bit-bfd ) ;;
-       esac
-
-       use multitarget && myconf+=( --enable-targets=all --enable-64-bit-bfd )
-
-       [[ -n ${CBUILD} ]] && myconf+=( --build=${CBUILD} )
-
-       is_cross && myconf+=(
-               --with-sysroot="${EPREFIX}"/usr/${CTARGET}
-               --enable-poison-system-directories
-       )
-
-       myconf+=( --enable-secureplt )
-
-       # mips can't do hash-style=gnu ...
-       # let's not do this on Solaris either
-       if [[ $(tc-arch) != mips && ${CHOST} != *-solaris* ]] ; then
-               myconf+=( --enable-default-hash-style=gnu )
-       fi
-
-       myconf+=(
-               --prefix="${EPREFIX}"/usr
-               --host=${CHOST}
-               --target=${CTARGET}
-               --datadir="${EPREFIX}"${DATAPATH}
-               --datarootdir="${EPREFIX}"${DATAPATH}
-               --infodir="${EPREFIX}"${DATAPATH}/info
-               --mandir="${EPREFIX}"${DATAPATH}/man
-               --bindir="${EPREFIX}"${BINPATH}
-               --libdir="${EPREFIX}"${LIBPATH}
-               --libexecdir="${EPREFIX}"${LIBPATH}
-               --includedir="${EPREFIX}"${INCPATH}
-               --enable-obsolete
-               --enable-shared
-               --enable-threads
-               # Newer versions (>=2.27) offer a configure flag now.
-               --enable-relro
-               # Newer versions (>=2.24) make this an explicit option, bug 
#497268
-               --enable-install-libiberty
-               # Available from 2.35 on
-               --enable-textrel-check=warning
-
-               # Available from 2.39 on
-               --enable-warn-execstack
-               --enable-warn-rwx-segments
-               # TODO: Available from 2.39+ on but let's try the warning on 
for a bit
-               # first... (--enable-warn-execstack)
-               # Could put it under USE=hardened?
-               #--disable-default-execstack (or is it 
--enable-default-execstack=no? docs are confusing)
-
-               # Things to think about
-               #--enable-deterministic-archives
-
-               # Works better than vapier's patch, bug #808787
-               --enable-new-dtags
-
-               --disable-jansson
-               --disable-werror
-               --with-bugurl="$(toolchain-binutils_bugurl)"
-               --with-pkgversion="$(toolchain-binutils_pkgversion)"
-               $(use_enable static-libs static)
-               # Disable modules that are in a combined binutils/gdb tree, bug 
#490566
-               --disable-{gdb,libdecnumber,readline,sim}
-               # Strip out broken static link flags.
-               # https://gcc.gnu.org/PR56750
-               --without-stage1-ldflags
-               # Change SONAME to avoid conflict across
-               # {native,cross}/binutils, binutils-libs. bug #666100
-               --with-extra-soversion-suffix=gentoo-${CATEGORY}-${PN}-$(usex 
multitarget mt st)
-
-               # Avoid automagic dependency on (currently prefix) systems
-               # systems with debuginfod library, bug #754753
-               --without-debuginfod
-
-               # Avoid automagic dev-libs/msgpack dep, bug #865875
-               --without-msgpack
-
-               # Allow user to opt into CET for host libraries.
-               # Ideally we would like automagic-or-disabled here.
-               # But the check does not quite work on i686: bug #760926.
-               $(use_enable cet)
-
-               # We can enable this by default in future, but it's brand new
-               # in 2.39 with several bugs:
-               # - Doesn't build on musl 
(https://sourceware.org/bugzilla/show_bug.cgi?id=29477)
-               # - No man pages 
(https://sourceware.org/bugzilla/show_bug.cgi?id=29521)
-               # - Broken at runtime without Java 
(https://sourceware.org/bugzilla/show_bug.cgi?id=29479)
-               # - binutils-config (and this ebuild?) needs adaptation first 
(https://bugs.gentoo.org/865113)
-               $(use_enable gprofng)
-       )
-
-       if ! is_cross ; then
-               myconf+=( $(use_enable pgo pgo-build lto) )
-
-               if use pgo ; then
-                       export BUILD_CFLAGS="${CFLAGS}"
-               fi
-       fi
-
-       ECONF_SOURCE="${S}" econf "${myconf[@]}" || die
-
-       # Prevent makeinfo from running if doc is unset.
-       if ! use doc ; then
-               sed -i \
-                       -e '/^MAKEINFO/s:=.*:= true:' \
-                       Makefile || die
-       fi
-}
-
-src_compile() {
-       cd "${MY_BUILDDIR}" || die
-
-       # see Note [tooldir hack for ldscripts]
-       emake V=1 tooldir="${EPREFIX}${TOOLPATH}" all
-
-       # only build info pages if the user wants them
-       if use doc ; then
-               emake V=1 info
-       fi
-
-       # we nuke the manpages when we're left with junk
-       # (like when we bootstrap, no perl -> no manpages)
-       find . -name '*.1' -a -size 0 -delete
-}
-
-src_test() {
-       cd "${MY_BUILDDIR}" || die
-
-       # bug #637066
-       filter-flags -Wall -Wreturn-type
-
-       emake -k V=1 check
-}
-
-src_install() {
-       local x d
-
-       cd "${MY_BUILDDIR}" || die
-
-       # see Note [tooldir hack for ldscripts]
-       emake V=1 DESTDIR="${D}" tooldir="${EPREFIX}${LIBPATH}" install
-       rm -rf "${ED}"/${LIBPATH}/bin || die
-       use static-libs || find "${ED}" -name '*.la' -delete
-
-       # Newer versions of binutils get fancy with ${LIBPATH}, bug #171905
-       cd "${ED}"/${LIBPATH} || die
-       for d in ../* ; do
-               [[ ${d} == ../${PV} ]] && continue
-               mv ${d}/* . || die
-               rmdir ${d} || die
-       done
-
-       # Now we collect everything intp the proper SLOT-ed dirs
-       # When something is built to cross-compile, it installs into
-       # /usr/$CHOST/ by default ... we have to 'fix' that :)
-       if is_cross ; then
-               cd "${ED}"/${BINPATH} || die
-               for x in * ; do
-                       mv ${x} ${x/${CTARGET}-} || die
-               done
-
-               if [[ -d ${ED}/usr/${CHOST}/${CTARGET} ]] ; then
-                       mv "${ED}"/usr/${CHOST}/${CTARGET}/include 
"${ED}"/${INCPATH}
-                       mv "${ED}"/usr/${CHOST}/${CTARGET}/lib/* 
"${ED}"/${LIBPATH}/
-                       rm -r "${ED}"/usr/${CHOST}/{include,lib}
-               fi
-       fi
-
-       insinto ${INCPATH}
-       local libiberty_headers=(
-               # Not all the libiberty headers.  See 
libiberty/Makefile.in:install_to_libdir.
-               demangle.h
-               dyn-string.h
-               fibheap.h
-               hashtab.h
-               libiberty.h
-               objalloc.h
-               splay-tree.h
-       )
-       doins "${libiberty_headers[@]/#/${S}/include/}"
-       if [[ -d ${ED}/${LIBPATH}/lib ]] ; then
-               mv "${ED}"/${LIBPATH}/lib/* "${ED}"/${LIBPATH}/ || die
-               rm -r "${ED}"/${LIBPATH}/lib || die
-       fi
-
-       # Generate an env.d entry for this binutils
-       insinto /etc/env.d/binutils
-       cat <<-EOF > "${T}"/env.d
-               TARGET="${CTARGET}"
-               VER="${PV}"
-               LIBPATH="${EPREFIX}${LIBPATH}"
-       EOF
-       newins "${T}"/env.d ${CTARGET}-${PV}
-
-       # Handle documentation
-       if ! is_cross ; then
-               cd "${S}" || die
-               dodoc README
-
-               docinto bfd
-               dodoc bfd/ChangeLog* bfd/README bfd/PORTING bfd/TODO
-
-               docinto binutils
-               dodoc binutils/ChangeLog binutils/NEWS binutils/README
-
-               docinto gas
-               dodoc gas/ChangeLog* gas/CONTRIBUTORS gas/NEWS gas/README*
-
-               docinto gprof
-               dodoc gprof/ChangeLog* gprof/TEST gprof/TODO gprof/bbconv.pl
-
-               docinto ld
-               dodoc ld/ChangeLog* ld/README ld/NEWS ld/TODO
-
-               docinto libiberty
-               dodoc libiberty/ChangeLog* libiberty/README
-
-               docinto opcodes
-               dodoc opcodes/ChangeLog*
-       fi
-
-       # Remove shared info pages
-       rm -f "${ED}"/${DATAPATH}/info/{dir,configure.info,standards.info}
-
-       # Trim all empty dirs
-       find "${ED}" -depth -type d -exec rmdir {} + 2>/dev/null
-}
-
-pkg_postinst() {
-       # Make sure this ${CTARGET} has a binutils version selected
-       [[ -e ${EROOT}/etc/env.d/binutils/config-${CTARGET} ]] && return 0
-       binutils-config ${CTARGET}-${PV}
-}
-
-pkg_postrm() {
-       local current_profile=$(binutils-config -c ${CTARGET})
-
-       # If no other versions exist, then uninstall for this
-       # target ... otherwise, switch to the newest version
-       # Note: only do this if this version is unmerged.  We
-       #       rerun binutils-config if this is a remerge, as
-       #       we want the mtimes on the symlinks updated (if
-       #       it is the same as the current selected profile)
-       if [[ ! -e ${EPREFIX}${BINPATH}/ld ]] && [[ ${current_profile} == 
${CTARGET}-${PV} ]] ; then
-               local choice=$(binutils-config -l | grep ${CTARGET} | awk 
'{print $2}')
-               choice=${choice//$'\n'/ }
-               choice=${choice/* }
-               if [[ -z ${choice} ]] ; then
-                       env -i ROOT="${ROOT}" binutils-config -u ${CTARGET}
-               else
-                       binutils-config ${choice}
-               fi
-       elif [[ $(CHOST=${CTARGET} binutils-config -c) == ${CTARGET}-${PV} ]] ; 
then
-               binutils-config ${CTARGET}-${PV}
-       fi
-}
-
-# Note [slotting support]
-# -----------------------
-# Gentoo's layout for binutils files is non-standard as Gentoo
-# supports slotted installation for binutils. Many tools
-# still expect binutils to reside in known locations.
-# binutils-config package restores symlinks into known locations,
-# like:
-#    /usr/bin/${CTARGET}-<tool>
-#    /usr/bin/${CHOST}/${CTARGET}/lib/ldscrips
-#    /usr/include/
-#
-# Note [tooldir hack for ldscripts]
-# ---------------------------------
-# Build system does not allow ./configure to tweak every location
-# we need for slotting binutils hence all the shuffling in
-# src_install(). This note is about SCRIPTDIR define handling.
-#
-# SCRIPTDIR defines 'ldscripts/' directory location. SCRIPTDIR value
-# is set at build-time in ld/Makefile.am as: 'scriptdir = $(tooldir)/lib'
-# and hardcoded as -DSCRIPTDIR='"$(scriptdir)"' at compile time.
-# Thus we can't just move files around after compilation finished.
-#
-# Our goal is the following:
-# - at build-time set scriptdir to point to symlinked location:
-#   ${TOOLPATH}: /usr/${CHOST} (or /usr/${CHOST}/${CTARGET} for cross-case)
-# - at install-time set scriptdir to point to slotted location:
-#   ${LIBPATH}: /usr/$(get_libdir)/binutils/${CTARGET}/${PV}

diff --git a/sys-devel/binutils/binutils-2.39-r4.ebuild 
b/sys-devel/binutils/binutils-2.39-r4.ebuild
deleted file mode 100644
index fd27c6420c..0000000000
--- a/sys-devel/binutils/binutils-2.39-r4.ebuild
+++ /dev/null
@@ -1,499 +0,0 @@
-# Copyright 1999-2022 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=7
-
-inherit libtool flag-o-matic gnuconfig strip-linguas toolchain-funcs
-
-DESCRIPTION="Tools necessary to build programs"
-HOMEPAGE="https://sourceware.org/binutils/";
-
-LICENSE="GPL-3+"
-IUSE="cet default-gold doc gold gprofng multitarget +nls pgo +plugins 
static-libs test vanilla"
-REQUIRED_USE="default-gold? ( gold )"
-
-# Variables that can be set here  (ignored for live ebuilds)
-# PATCH_VER          - the patchset version
-#                      Default: empty, no patching
-# PATCH_BINUTILS_VER - the binutils version in the patchset name
-#                    - Default: PV
-# PATCH_DEV          - Use download URI 
https://dev.gentoo.org/~{PATCH_DEV}/distfiles/...
-#                      for the patchsets
-
-PATCH_VER=5
-PATCH_DEV=dilfridge
-
-if [[ ${PV} == 9999* ]]; then
-       inherit git-r3
-       SLOT=${PV}
-else
-       PATCH_BINUTILS_VER=${PATCH_BINUTILS_VER:-${PV}}
-       PATCH_DEV=${PATCH_DEV:-dilfridge}
-       SRC_URI="mirror://gnu/binutils/binutils-${PV}.tar.xz 
https://dev.gentoo.org/~${PATCH_DEV}/distfiles/binutils-${PV}.tar.xz";
-       [[ -z ${PATCH_VER} ]] || SRC_URI="${SRC_URI}
-               
https://dev.gentoo.org/~${PATCH_DEV}/distfiles/binutils-${PATCH_BINUTILS_VER}-patches-${PATCH_VER}.tar.xz";
-       SLOT=$(ver_cut 1-2)
-       KEYWORDS="~amd64-linux ~x86-linux ~x64-solaris"
-fi
-
-#
-# The cross-compile logic
-#
-export CTARGET=${CTARGET:-${CHOST}}
-if [[ ${CTARGET} == ${CHOST} ]] ; then
-       if [[ ${CATEGORY} == cross-* ]] ; then
-               export CTARGET=${CATEGORY#cross-}
-       fi
-fi
-is_cross() { [[ ${CHOST} != ${CTARGET} ]] ; }
-
-#
-# The dependencies
-#
-RDEPEND="
-       >=sys-devel/binutils-config-3
-       sys-libs/zlib
-"
-DEPEND="${RDEPEND}"
-BDEPEND="
-       doc? ( sys-apps/texinfo )
-       test? (
-               dev-util/dejagnu
-               sys-devel/bc
-       )
-       nls? ( sys-devel/gettext )
-       sys-devel/flex
-       app-alternatives/yacc
-"
-
-RESTRICT="!test? ( test )"
-
-PATCHES=(
-       "${FILESDIR}"/${PN}-2.22-solaris-anonymous-version-script-fix.patch
-       "${FILESDIR}"/${PN}-2.39-protected-visibility-solaris.patch
-)
-
-MY_BUILDDIR=${WORKDIR}/build
-
-src_unpack() {
-       if [[ ${PV} == 9999* ]] ; then
-               
EGIT_REPO_URI="https://anongit.gentoo.org/git/proj/toolchain/binutils-patches.git";
-               EGIT_CHECKOUT_DIR=${WORKDIR}/patches-git
-               git-r3_src_unpack
-               mv patches-git/9999 patch || die
-
-               EGIT_REPO_URI="https://sourceware.org/git/binutils-gdb.git";
-               S=${WORKDIR}/binutils
-               EGIT_CHECKOUT_DIR=${S}
-               git-r3_src_unpack
-       else
-               unpack ${P/-hppa64/}.tar.xz
-
-               cd "${WORKDIR}" || die
-               unpack 
binutils-${PATCH_BINUTILS_VER}-patches-${PATCH_VER}.tar.xz
-
-               # _p patch versions are Gentoo specific tarballs ...
-               local dir=${P%_p?}
-               dir=${dir/-hppa64/}
-
-               S=${WORKDIR}/${dir}
-       fi
-
-       cd "${WORKDIR}" || die
-       mkdir -p "${MY_BUILDDIR}" || die
-}
-
-src_prepare() {
-       local patchsetname
-       if [[ ${PV} == 9999* ]] ; then
-               patchsetname="from git master"
-       else
-               patchsetname="${PATCH_BINUTILS_VER}-${PATCH_VER}"
-       fi
-
-       if [[ -n ${PATCH_VER} ]] || [[ ${PV} == 9999* ]] ; then
-               if ! use vanilla; then
-                       einfo "Applying binutils patchset ${patchsetname}"
-                       eapply "${WORKDIR}/patch"
-                       einfo "Done."
-               fi
-       fi
-
-       # Make sure our explicit libdir paths don't get clobbered, bug #562460
-       sed -i \
-               -e 's:@bfdlibdir@:@libdir@:g' \
-               -e 's:@bfdincludedir@:@includedir@:g' \
-               {bfd,opcodes}/Makefile.in || die
-
-       # Fix locale issues if possible, bug #122216
-       if [[ -e ${FILESDIR}/binutils-configure-LANG.patch ]] ; then
-               einfo "Fixing misc issues in configure files"
-               for f in $(find "${S}" -name configure -exec grep -l 'autoconf 
version 2.13' {} +) ; do
-                       ebegin "  Updating ${f/${S}\/}"
-                       patch "${f}" 
"${FILESDIR}"/binutils-configure-LANG.patch >& "${T}"/configure-patch.log \
-                               || eerror "Please file a bug about this"
-                       eend $?
-               done
-       fi
-
-       # Apply things from PATCHES and user dirs
-       default
-
-       # Run misc portage update scripts
-       gnuconfig_update
-       elibtoolize --portage --no-uclibc
-}
-
-toolchain-binutils_bugurl() {
-       printf "https://bugs.gentoo.org/";
-}
-toolchain-binutils_pkgversion() {
-       printf "Gentoo ${PV}"
-       [[ -n ${PATCH_VER} ]] && printf " p${PATCH_VER}"
-}
-
-src_configure() {
-       # See 
https://www.gnu.org/software/make/manual/html_node/Parallel-Output.html
-       # Avoid really confusing logs from subconfigure spam, makes logs far
-       # more legible.
-       MAKEOPTS="--output-sync=line ${MAKEOPTS}"
-
-       # Setup some paths
-       LIBPATH=/usr/$(get_libdir)/binutils/${CTARGET}/${PV}
-       INCPATH=${LIBPATH}/include
-       DATAPATH=/usr/share/binutils-data/${CTARGET}/${PV}
-       if is_cross ; then
-               TOOLPATH=/usr/${CHOST}/${CTARGET}
-       else
-               TOOLPATH=/usr/${CTARGET}
-       fi
-       BINPATH=${TOOLPATH}/binutils-bin/${PV}
-
-       # Make sure we filter $LINGUAS so that only ones that
-       # actually work make it through, bug #42033
-       strip-linguas -u */po
-
-       # Keep things sane
-       strip-flags
-
-       use elibc_musl && append-ldflags -Wl,-z,stack-size=2097152
-
-       local x
-       echo
-       for x in CATEGORY CBUILD CHOST CTARGET CFLAGS LDFLAGS ; do
-               einfo "$(printf '%10s' ${x}:) ${!x}"
-       done
-       echo
-
-       cd "${MY_BUILDDIR}" || die
-       local myconf=()
-
-       if use plugins ; then
-               myconf+=( --enable-plugins )
-       fi
-       # enable gold (installed as ld.gold) and ld's plugin architecture
-       if use gold ; then
-               myconf+=( --enable-gold )
-               if use default-gold; then
-                       myconf+=( --enable-gold=default )
-               fi
-       fi
-
-       if use nls ; then
-               myconf+=( --without-included-gettext )
-               [[ ${CHOST} == *"-solaris"* ]] && append-libs -lintl
-       else
-               myconf+=( --disable-nls )
-       fi
-
-       myconf+=( --with-system-zlib )
-
-       # For bi-arch systems, enable a 64bit bfd. This matches the bi-arch
-       # logic in toolchain.eclass. bug #446946
-       #
-       # We used to do it for everyone, but it's slow on 32bit arches. bug 
#438522
-       case $(tc-arch) in
-               ppc|sparc|x86) myconf+=( --enable-64-bit-bfd ) ;;
-       esac
-
-       use multitarget && myconf+=( --enable-targets=all --enable-64-bit-bfd )
-
-       [[ -n ${CBUILD} ]] && myconf+=( --build=${CBUILD} )
-
-       is_cross && myconf+=(
-               --with-sysroot="${EPREFIX}"/usr/${CTARGET}
-               --enable-poison-system-directories
-       )
-
-       myconf+=( --enable-secureplt )
-
-       # mips can't do hash-style=gnu ...
-       # let's not do this on Solaris either
-       if [[ $(tc-arch) != mips && ${CHOST} != *-solaris* ]] ; then
-               myconf+=( --enable-default-hash-style=gnu )
-       fi
-
-       myconf+=(
-               --prefix="${EPREFIX}"/usr
-               --host=${CHOST}
-               --target=${CTARGET}
-               --datadir="${EPREFIX}"${DATAPATH}
-               --datarootdir="${EPREFIX}"${DATAPATH}
-               --infodir="${EPREFIX}"${DATAPATH}/info
-               --mandir="${EPREFIX}"${DATAPATH}/man
-               --bindir="${EPREFIX}"${BINPATH}
-               --libdir="${EPREFIX}"${LIBPATH}
-               --libexecdir="${EPREFIX}"${LIBPATH}
-               --includedir="${EPREFIX}"${INCPATH}
-               --enable-obsolete
-               --enable-shared
-               --enable-threads
-               # Newer versions (>=2.27) offer a configure flag now.
-               --enable-relro
-               # Newer versions (>=2.24) make this an explicit option, bug 
#497268
-               --enable-install-libiberty
-               # Available from 2.35 on
-               --enable-textrel-check=warning
-
-               # These hardening options are available from 2.39+ but
-               # they unconditionally enable the behaviour even on arches
-               # where e.g. execstacks can't be avoided.
-               # See https://sourceware.org/bugzilla/show_bug.cgi?id=29592.
-               #--enable-warn-execstack
-               #--enable-warn-rwx-segments
-               #--disable-default-execstack (or is it 
--enable-default-execstack=no? docs are confusing)
-
-               # Things to think about
-               #--enable-deterministic-archives
-
-               # Works better than vapier's patch, bug #808787
-               --enable-new-dtags
-
-               --disable-jansson
-               --disable-werror
-               --with-bugurl="$(toolchain-binutils_bugurl)"
-               --with-pkgversion="$(toolchain-binutils_pkgversion)"
-               $(use_enable static-libs static)
-               # Disable modules that are in a combined binutils/gdb tree, bug 
#490566
-               --disable-{gdb,libdecnumber,readline,sim}
-               # Strip out broken static link flags.
-               # https://gcc.gnu.org/PR56750
-               --without-stage1-ldflags
-               # Change SONAME to avoid conflict across
-               # {native,cross}/binutils, binutils-libs. bug #666100
-               --with-extra-soversion-suffix=gentoo-${CATEGORY}-${PN}-$(usex 
multitarget mt st)
-
-               # Avoid automagic dependency on (currently prefix) systems
-               # systems with debuginfod library, bug #754753
-               --without-debuginfod
-
-               # Avoid automagic dev-libs/msgpack dep, bug #865875
-               --without-msgpack
-
-               # Allow user to opt into CET for host libraries.
-               # Ideally we would like automagic-or-disabled here.
-               # But the check does not quite work on i686: bug #760926.
-               $(use_enable cet)
-
-               # We can enable this by default in future, but it's brand new
-               # in 2.39 with several bugs:
-               # - Doesn't build on musl 
(https://sourceware.org/bugzilla/show_bug.cgi?id=29477)
-               # - No man pages 
(https://sourceware.org/bugzilla/show_bug.cgi?id=29521)
-               # - Broken at runtime without Java 
(https://sourceware.org/bugzilla/show_bug.cgi?id=29479)
-               # - binutils-config (and this ebuild?) needs adaptation first 
(https://bugs.gentoo.org/865113)
-               $(use_enable gprofng)
-       )
-
-       if ! is_cross ; then
-               myconf+=( $(use_enable pgo pgo-build lto) )
-
-               if use pgo ; then
-                       export BUILD_CFLAGS="${CFLAGS}"
-               fi
-       fi
-
-       ECONF_SOURCE="${S}" econf "${myconf[@]}" || die
-
-       # Prevent makeinfo from running if doc is unset.
-       if ! use doc ; then
-               sed -i \
-                       -e '/^MAKEINFO/s:=.*:= true:' \
-                       Makefile || die
-       fi
-}
-
-src_compile() {
-       cd "${MY_BUILDDIR}" || die
-
-       # see Note [tooldir hack for ldscripts]
-       emake V=1 tooldir="${EPREFIX}${TOOLPATH}" all
-
-       # only build info pages if the user wants them
-       if use doc ; then
-               emake V=1 info
-       fi
-
-       # we nuke the manpages when we're left with junk
-       # (like when we bootstrap, no perl -> no manpages)
-       find . -name '*.1' -a -size 0 -delete
-}
-
-src_test() {
-       cd "${MY_BUILDDIR}" || die
-
-       # bug #637066
-       filter-flags -Wall -Wreturn-type
-
-       emake -k V=1 check
-}
-
-src_install() {
-       local x d
-
-       cd "${MY_BUILDDIR}" || die
-
-       # see Note [tooldir hack for ldscripts]
-       emake V=1 DESTDIR="${D}" tooldir="${EPREFIX}${LIBPATH}" install
-       rm -rf "${ED}"/${LIBPATH}/bin || die
-       use static-libs || find "${ED}" -name '*.la' -delete
-
-       # Newer versions of binutils get fancy with ${LIBPATH}, bug #171905
-       cd "${ED}"/${LIBPATH} || die
-       for d in ../* ; do
-               [[ ${d} == ../${PV} ]] && continue
-               mv ${d}/* . || die
-               rmdir ${d} || die
-       done
-
-       # Now we collect everything intp the proper SLOT-ed dirs
-       # When something is built to cross-compile, it installs into
-       # /usr/$CHOST/ by default ... we have to 'fix' that :)
-       if is_cross ; then
-               cd "${ED}"/${BINPATH} || die
-               for x in * ; do
-                       mv ${x} ${x/${CTARGET}-} || die
-               done
-
-               if [[ -d ${ED}/usr/${CHOST}/${CTARGET} ]] ; then
-                       mv "${ED}"/usr/${CHOST}/${CTARGET}/include 
"${ED}"/${INCPATH}
-                       mv "${ED}"/usr/${CHOST}/${CTARGET}/lib/* 
"${ED}"/${LIBPATH}/
-                       rm -r "${ED}"/usr/${CHOST}/{include,lib}
-               fi
-       fi
-
-       insinto ${INCPATH}
-       local libiberty_headers=(
-               # Not all the libiberty headers.  See 
libiberty/Makefile.in:install_to_libdir.
-               demangle.h
-               dyn-string.h
-               fibheap.h
-               hashtab.h
-               libiberty.h
-               objalloc.h
-               splay-tree.h
-       )
-       doins "${libiberty_headers[@]/#/${S}/include/}"
-       if [[ -d ${ED}/${LIBPATH}/lib ]] ; then
-               mv "${ED}"/${LIBPATH}/lib/* "${ED}"/${LIBPATH}/ || die
-               rm -r "${ED}"/${LIBPATH}/lib || die
-       fi
-
-       # Generate an env.d entry for this binutils
-       insinto /etc/env.d/binutils
-       cat <<-EOF > "${T}"/env.d
-               TARGET="${CTARGET}"
-               VER="${PV}"
-               LIBPATH="${EPREFIX}${LIBPATH}"
-       EOF
-       newins "${T}"/env.d ${CTARGET}-${PV}
-
-       # Handle documentation
-       if ! is_cross ; then
-               cd "${S}" || die
-               dodoc README
-
-               docinto bfd
-               dodoc bfd/ChangeLog* bfd/README bfd/PORTING bfd/TODO
-
-               docinto binutils
-               dodoc binutils/ChangeLog binutils/NEWS binutils/README
-
-               docinto gas
-               dodoc gas/ChangeLog* gas/CONTRIBUTORS gas/NEWS gas/README*
-
-               docinto gprof
-               dodoc gprof/ChangeLog* gprof/TEST gprof/TODO gprof/bbconv.pl
-
-               docinto ld
-               dodoc ld/ChangeLog* ld/README ld/NEWS ld/TODO
-
-               docinto libiberty
-               dodoc libiberty/ChangeLog* libiberty/README
-
-               docinto opcodes
-               dodoc opcodes/ChangeLog*
-       fi
-
-       # Remove shared info pages
-       rm -f "${ED}"/${DATAPATH}/info/{dir,configure.info,standards.info}
-
-       # Trim all empty dirs
-       find "${ED}" -depth -type d -exec rmdir {} + 2>/dev/null
-}
-
-pkg_postinst() {
-       # Make sure this ${CTARGET} has a binutils version selected
-       [[ -e ${EROOT}/etc/env.d/binutils/config-${CTARGET} ]] && return 0
-       binutils-config ${CTARGET}-${PV}
-}
-
-pkg_postrm() {
-       local current_profile=$(binutils-config -c ${CTARGET})
-
-       # If no other versions exist, then uninstall for this
-       # target ... otherwise, switch to the newest version
-       # Note: only do this if this version is unmerged.  We
-       #       rerun binutils-config if this is a remerge, as
-       #       we want the mtimes on the symlinks updated (if
-       #       it is the same as the current selected profile)
-       if [[ ! -e ${EPREFIX}${BINPATH}/ld ]] && [[ ${current_profile} == 
${CTARGET}-${PV} ]] ; then
-               local choice=$(binutils-config -l | grep ${CTARGET} | awk 
'{print $2}')
-               choice=${choice//$'\n'/ }
-               choice=${choice/* }
-               if [[ -z ${choice} ]] ; then
-                       env -i ROOT="${ROOT}" binutils-config -u ${CTARGET}
-               else
-                       binutils-config ${choice}
-               fi
-       elif [[ $(CHOST=${CTARGET} binutils-config -c) == ${CTARGET}-${PV} ]] ; 
then
-               binutils-config ${CTARGET}-${PV}
-       fi
-}
-
-# Note [slotting support]
-# -----------------------
-# Gentoo's layout for binutils files is non-standard as Gentoo
-# supports slotted installation for binutils. Many tools
-# still expect binutils to reside in known locations.
-# binutils-config package restores symlinks into known locations,
-# like:
-#    /usr/bin/${CTARGET}-<tool>
-#    /usr/bin/${CHOST}/${CTARGET}/lib/ldscrips
-#    /usr/include/
-#
-# Note [tooldir hack for ldscripts]
-# ---------------------------------
-# Build system does not allow ./configure to tweak every location
-# we need for slotting binutils hence all the shuffling in
-# src_install(). This note is about SCRIPTDIR define handling.
-#
-# SCRIPTDIR defines 'ldscripts/' directory location. SCRIPTDIR value
-# is set at build-time in ld/Makefile.am as: 'scriptdir = $(tooldir)/lib'
-# and hardcoded as -DSCRIPTDIR='"$(scriptdir)"' at compile time.
-# Thus we can't just move files around after compilation finished.
-#
-# Our goal is the following:
-# - at build-time set scriptdir to point to symlinked location:
-#   ${TOOLPATH}: /usr/${CHOST} (or /usr/${CHOST}/${CTARGET} for cross-case)
-# - at install-time set scriptdir to point to slotted location:
-#   ${LIBPATH}: /usr/$(get_libdir)/binutils/${CTARGET}/${PV}

diff --git a/sys-devel/binutils/binutils-2.40-r2.ebuild 
b/sys-devel/binutils/binutils-2.40-r8.ebuild
similarity index 96%
rename from sys-devel/binutils/binutils-2.40-r2.ebuild
rename to sys-devel/binutils/binutils-2.40-r8.ebuild
index 08700c31bf..5f1cfd4510 100644
--- a/sys-devel/binutils/binutils-2.40-r2.ebuild
+++ b/sys-devel/binutils/binutils-2.40-r8.ebuild
@@ -9,7 +9,7 @@ DESCRIPTION="Tools necessary to build programs"
 HOMEPAGE="https://sourceware.org/binutils/";
 
 LICENSE="GPL-3+"
-IUSE="cet doc gold gprofng multitarget +nls pgo +plugins static-libs test 
vanilla zstd"
+IUSE="cet debuginfod doc gold gprofng multitarget +nls pgo +plugins 
static-libs test vanilla zstd"
 
 # Variables that can be set here  (ignored for live ebuilds)
 # PATCH_VER          - the patchset version
@@ -19,7 +19,7 @@ IUSE="cet doc gold gprofng multitarget +nls pgo +plugins 
static-libs test vanill
 # PATCH_DEV          - Use download URI 
https://dev.gentoo.org/~{PATCH_DEV}/distfiles/...
 #                      for the patchsets
 
-PATCH_VER=2
+PATCH_VER=7
 PATCH_DEV=dilfridge
 
 if [[ ${PV} == 9999* ]]; then
@@ -52,6 +52,9 @@ is_cross() { [[ ${CHOST} != ${CTARGET} ]] ; }
 RDEPEND="
        >=sys-devel/binutils-config-3
        sys-libs/zlib
+       debuginfod? (
+               dev-libs/elfutils[debuginfod(-)]
+       )
        zstd? ( app-arch/zstd:= )
 "
 DEPEND="${RDEPEND}"
@@ -253,6 +256,11 @@ src_configure() {
                --libdir="${EPREFIX}"${LIBPATH}
                --libexecdir="${EPREFIX}"${LIBPATH}
                --includedir="${EPREFIX}"${INCPATH}
+               # portage's econf() does not detect presence of --d-d-t
+               # because it greps only top-level ./configure. But not
+               # libiberty's or bfd's configure.
+               --disable-dependency-tracking
+               --disable-silent-rules
                --enable-obsolete
                --enable-shared
                --enable-threads
@@ -336,11 +344,11 @@ src_compile() {
        cd "${MY_BUILDDIR}" || die
 
        # see Note [tooldir hack for ldscripts]
-       emake V=1 tooldir="${EPREFIX}${TOOLPATH}" all
+       emake tooldir="${EPREFIX}${TOOLPATH}" all
 
        # only build info pages if the user wants them
        if use doc ; then
-               emake V=1 info
+               emake info
        fi
 
        # we nuke the manpages when we're left with junk
@@ -354,7 +362,7 @@ src_test() {
        # bug #637066
        filter-flags -Wall -Wreturn-type
 
-       emake -k V=1 check
+       emake -k check
 }
 
 src_install() {
@@ -363,7 +371,7 @@ src_install() {
        cd "${MY_BUILDDIR}" || die
 
        # see Note [tooldir hack for ldscripts]
-       emake V=1 DESTDIR="${D}" tooldir="${EPREFIX}${LIBPATH}" install
+       emake DESTDIR="${D}" tooldir="${EPREFIX}${LIBPATH}" install
        rm -rf "${ED}"/${LIBPATH}/bin || die
        use static-libs || find "${ED}" -name '*.la' -delete
 

diff --git a/sys-devel/binutils/files/binutils-2.24-cygwin-nointl.patch 
b/sys-devel/binutils/files/binutils-2.24-cygwin-nointl.patch
deleted file mode 100644
index 753996335b..0000000000
--- a/sys-devel/binutils/files/binutils-2.24-cygwin-nointl.patch
+++ /dev/null
@@ -1,26 +0,0 @@
-diff --git a/bfd/configure b/bfd/configure
-index eeeb89a..6b7c5b8 100755
---- a/bfd/configure
-+++ b/bfd/configure
-@@ -15105,7 +15105,7 @@ if test "$enable_shared" = "yes"; then
-   case "${host}" in
-   *-*-cygwin*)
-     SHARED_LDFLAGS="-no-undefined"
--    SHARED_LIBADD="-L`pwd`/../libiberty -liberty -L`pwd`/../intl -lintl 
-lcygwin -lkernel32"
-+      SHARED_LIBADD="-L`pwd`/../libiberty -liberty -L`pwd`/../intl 
\$(LIBINTL) -lcygwin -lkernel32"
-   ;;
- 
-   # Hack to build or1k-src on OSX
-diff --git a/opcodes/configure b/opcodes/configure
-index e5048e2..1e9ca69 100755
---- a/opcodes/configure
-+++ b/opcodes/configure
-@@ -12456,7 +12456,7 @@ if test "$enable_shared" = "yes"; then
-   case "${host}" in
-     *-*-cygwin*)
-       SHARED_LDFLAGS="-no-undefined"
--      SHARED_LIBADD="-L`pwd`/../bfd -lbfd -L`pwd`/../libiberty -liberty 
-L`pwd`/../intl -lintl -lcygwin"
-+        SHARED_LIBADD="-L`pwd`/../bfd -lbfd -L`pwd`/../libiberty -liberty 
-L`pwd`/../intl \$(LIBINTL) -lcygwin"
-       ;;
-    *-*-darwin*)
-      SHARED_LIBADD="-Wl,`pwd`/../bfd/.libs/libbfd.dylib ${SHARED_LIBADD}"

diff --git a/sys-devel/binutils/files/binutils-2.29.1-nogoldtest.patch 
b/sys-devel/binutils/files/binutils-2.29.1-nogoldtest.patch
deleted file mode 100644
index 8e0669922d..0000000000
--- a/sys-devel/binutils/files/binutils-2.29.1-nogoldtest.patch
+++ /dev/null
@@ -1,27 +0,0 @@
-From 40f6e93e5078f16897f23856886566fe3b546206 Mon Sep 17 00:00:00 2001
-From: =?UTF-8?q?Andreas=20K=2E=20H=C3=BCttel?= <[email protected]>
-Date: Fri, 3 Nov 2017 21:51:35 +0100
-Subject: [PATCH] Gentoo: Disable gold testsuite for users since it fails
- upstream
-
-https://bugs.gentoo.org/634348
-https://sourceware.org/bugzilla/show_bug.cgi?id=21090
----
- Makefile.in | 1 -
- 1 file changed, 1 deletion(-)
-
-diff --git a/Makefile.in b/Makefile.in
-index 3acb83b8de..49de829bfa 100644
---- a/Makefile.in
-+++ b/Makefile.in
-@@ -2340,7 +2340,6 @@ check-host:  \
-     maybe-check-mpc \
-     maybe-check-isl \
-     maybe-check-libelf \
--    maybe-check-gold \
-     maybe-check-gprof \
-     maybe-check-intl \
-     maybe-check-tcl \
--- 
-2.15.0
-

diff --git a/sys-devel/binutils/files/binutils-2.33-gcc-10.patch 
b/sys-devel/binutils/files/binutils-2.33-gcc-10.patch
deleted file mode 100644
index 9e1a999be9..0000000000
--- a/sys-devel/binutils/files/binutils-2.33-gcc-10.patch
+++ /dev/null
@@ -1,39 +0,0 @@
-binutils: drop redundant 'program_name' definition
-
-https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;a=commitdiff;h=0b398d69acde3377dfbbeb8a4cfe87ae8c8562fa
---- a/binutils/coffdump.c
-+++ b/binutils/coffdump.c
-@@ -456,8 +456,6 @@ coff_dump (struct coff_ofile *ptr)
-     dump_coff_section (ptr->sections + i);
- }
- 
--char * program_name;
--
- static void
- show_usage (FILE *file, int status)
- {
---- a/binutils/srconv.c
-+++ b/binutils/srconv.c
-@@ -1687,8 +1687,6 @@ prescan (struct coff_ofile *otree)
-     }
- }
- 
--char *program_name;
--
- ATTRIBUTE_NORETURN static void
- show_usage (FILE *ffile, int status)
- {
---- a/binutils/sysdump.c
-+++ b/binutils/sysdump.c
-@@ -633,8 +633,6 @@ module (void)
-     }
- }
- 
--char *program_name;
--
- ATTRIBUTE_NORETURN static void
- show_usage (FILE *ffile, int status)
- {
--- 
-2.25.0
-

diff --git a/sys-devel/binutils/files/binutils-2.34-riscv-SEGV.patch 
b/sys-devel/binutils/files/binutils-2.34-riscv-SEGV.patch
deleted file mode 100644
index ac70e50491..0000000000
--- a/sys-devel/binutils/files/binutils-2.34-riscv-SEGV.patch
+++ /dev/null
@@ -1,40 +0,0 @@
-https://sourceware.org/PR25900
-https://sourceware.org/git/?p=binutils-gdb.git;a=patch;h=a2714d6cca1f1c7695f8dc84b49a4a51d1db86c8
-
-From a2714d6cca1f1c7695f8dc84b49a4a51d1db86c8 Mon Sep 17 00:00:00 2001
-From: Alan Modra <[email protected]>
-Date: Fri, 1 May 2020 15:32:00 +0930
-Subject: [PATCH] PR25900, RISC-V: null pointer dereference
-
-       PR 25900
-       * elfnn-riscv.c (_bfd_riscv_relax_section): Check root.type before
-       accessing root.u.def of symbols.  Also check root.u.def.section
-       is non-NULL.  Reverse tests so as to make the logic positive.
-
---- a/bfd/elfnn-riscv.c
-+++ b/bfd/elfnn-riscv.c
-@@ -4161,15 +4161,16 @@ _bfd_riscv_relax_section (bfd *abfd, asection *sec,
-             symval = 0;
-             sym_sec = bfd_und_section_ptr;
-           }
--        else if (h->root.u.def.section->output_section == NULL
--                 || (h->root.type != bfd_link_hash_defined
--                     && h->root.type != bfd_link_hash_defweak))
--          continue;
--        else
-+        else if ((h->root.type == bfd_link_hash_defined
-+                  || h->root.type == bfd_link_hash_defweak)
-+                 && h->root.u.def.section != NULL
-+                 && h->root.u.def.section->output_section != NULL)
-           {
-             symval = h->root.u.def.value;
-             sym_sec = h->root.u.def.section;
-           }
-+        else
-+          continue;
- 
-         if (h->type != STT_FUNC)
-           reserve_size =
--- 
-2.18.2
-

diff --git 
a/sys-devel/binutils/files/binutils-2.39-protected-visibility-solaris.patch 
b/sys-devel/binutils/files/binutils-2.39-protected-visibility-solaris.patch
deleted file mode 100644
index 2e83e74b8d..0000000000
--- a/sys-devel/binutils/files/binutils-2.39-protected-visibility-solaris.patch
+++ /dev/null
@@ -1,64 +0,0 @@
-From 2c43d202aefb2b6f202a44bbb8a0baf251aae845 Mon Sep 17 00:00:00 2001
-From: "H.J. Lu" <[email protected]>
-Date: Mon, 22 Aug 2022 10:26:17 -0700
-Subject: [PATCH] x86: Ignore protected visibility in shared libraries on
- Solaris
-
-On x86, the PLT entry in executable may be used as function address for
-functions in shared libraries.  If functions are protected, the function
-address used in executable can be different from the function address
-used in shared library.  This will lead to incorrect run-time behavior
-if function pointer equality is needed.  By default, x86 linker issues
-an error in this case.
-
-On Solaris, linker issued an error for
-
-struct tm *tb = (kind == CPP_time_kind::FIXED ? gmtime : localtime) (&tt);
-
-where gmtime is a protected function in libc.so.  Use gmtime's PLT entry
-in executable as function address is safe since function pointer equality
-isn't needed.  Ignore protected visibility in shared libraries on Solaris
-to disable linker error.  If function pointer equality is needed, linker
-will silently generate executable with incorrect run-time behavior on
-Solaris.
-
-       PR ld/29512
-       * elf32-i386.c (elf_i386_scan_relocs): Ignore protected
-       visibility in shared libraries on Solaris.
-       * elf64-x86-64.c (elf_x86_64_scan_relocs): Likewise.
----
- bfd/elf32-i386.c   | 3 ++-
- bfd/elf64-x86-64.c | 3 ++-
- 2 files changed, 4 insertions(+), 2 deletions(-)
-
-diff --git a/bfd/elf32-i386.c b/bfd/elf32-i386.c
-index 52b1db44546..9717e2c5ed6 100644
---- a/bfd/elf32-i386.c
-+++ b/bfd/elf32-i386.c
-@@ -1808,7 +1808,8 @@ elf_i386_scan_relocs (bfd *abfd,
-                     || (sec->flags & (SEC_CODE | SEC_READONLY)) != 0)
-                   h->plt.refcount = 1;
- 
--                if (h->pointer_equality_needed
-+                if (htab->elf.target_os != is_solaris
-+                    && h->pointer_equality_needed
-                     && h->type == STT_FUNC
-                     && eh->def_protected
-                     && !SYMBOL_DEFINED_NON_SHARED_P (h)
-diff --git a/bfd/elf64-x86-64.c b/bfd/elf64-x86-64.c
-index 62a9a22317a..f3b54400013 100644
---- a/bfd/elf64-x86-64.c
-+++ b/bfd/elf64-x86-64.c
-@@ -2251,7 +2251,8 @@ elf_x86_64_scan_relocs (bfd *abfd, struct bfd_link_info 
*info,
-                     || (sec->flags & (SEC_CODE | SEC_READONLY)) != 0)
-                   h->plt.refcount = 1;
- 
--                if (h->pointer_equality_needed
-+                if (htab->elf.target_os != is_solaris
-+                    && h->pointer_equality_needed
-                     && h->type == STT_FUNC
-                     && eh->def_protected
-                     && !SYMBOL_DEFINED_NON_SHARED_P (h)
--- 
-2.31.1
-

diff --git a/sys-devel/binutils/files/binutils-configure-LANG.patch 
b/sys-devel/binutils/files/binutils-configure-LANG.patch
new file mode 100644
index 0000000000..5521d196cf
--- /dev/null
+++ b/sys-devel/binutils/files/binutils-configure-LANG.patch
@@ -0,0 +1,65 @@
+The LANG vars aren't reset early enough so when sed tries to use [a-zA-Z] in 
+option parsing, it may break.
+
+http://bugs.gentoo.org/103483
+http://bugs.gentoo.org/122216
+
+--- configure
++++ configure
+@@ -54,6 +54,19 @@
+ infodir='${prefix}/info'
+ mandir='${prefix}/man'
+ 
++# NLS nuisances.
++for as_var in \
++  LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \
++  LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \
++  LC_TELEPHONE LC_TIME
++do
++  if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then
++    eval $as_var=C; export $as_var
++  else
++    unset $as_var
++  fi
++done
++
+ # Initialize some other variables.
+ subdirs=
+ MFLAGS= MAKEFLAGS=
+@@ -452,16 +463,6 @@
+   esac
+ done
+ 
+-# NLS nuisances.
+-# Only set these to C if already set.  These must not be set unconditionally
+-# because not all systems understand e.g. LANG=C (notably SCO).
+-# Fixing LC_MESSAGES prevents Solaris sh from translating var values in `set'!
+-# Non-C LC_CTYPE values break the ctype check.
+-if test "${LANG+set}"   = set; then LANG=C;   export LANG;   fi
+-if test "${LC_ALL+set}" = set; then LC_ALL=C; export LC_ALL; fi
+-if test "${LC_MESSAGES+set}" = set; then LC_MESSAGES=C; export LC_MESSAGES; fi
+-if test "${LC_CTYPE+set}"    = set; then LC_CTYPE=C;    export LC_CTYPE;    fi
+-
+ # confdefs.h avoids OS command line length limits that DEFS can exceed.
+ rm -rf conftest* confdefs.h
+ # AIX cpp loses on an empty file, so make sure it contains at least a newline.
+@@ -1850,6 +1850,19 @@
+ # Compiler output produced by configure, useful for debugging
+ # configure, is in ./config.log if it exists.
+ 
++# NLS nuisances.
++for as_var in \
++  LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \
++  LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \
++  LC_TELEPHONE LC_TIME
++do
++  if (set +x; test -z "`(eval \$as_var=C; export \$as_var) 2>&1`"); then
++    eval \$as_var=C; export \$as_var
++  else
++    unset \$as_var
++  fi
++done
++
+ ac_cs_usage="Usage: $CONFIG_STATUS [--recheck] [--version] [--help]"
+ for ac_option
+ do

Reply via email to