import binutils-2.35.2-37.el9

This commit is contained in:
CentOS Sources 2023-03-28 08:53:51 +00:00 committed by root
parent 63308a95fb
commit f43fd3d1e8
6 changed files with 857 additions and 306 deletions

View File

@ -0,0 +1,155 @@
--- binutils.orig/gas/dw2gencfi.c 2022-09-08 13:54:05.539276706 +0100
+++ binutils-2.35.2/gas/dw2gencfi.c 2022-09-08 14:05:56.128016840 +0100
@@ -2054,6 +2054,64 @@ output_fde (struct fde_entry *fde, struc
symbol_set_value_now (end_address);
}
+/* Allow these insns to be put in the initial sequence of a CIE.
+ If J is non-NULL, then compare I and J insns for a match. */
+
+static inline bfd_boolean
+initial_cie_insn (const struct cfi_insn_data *i, const struct cfi_insn_data *j)
+{
+ if (j && i->insn != j->insn)
+ return FALSE;
+
+ switch (i->insn)
+ {
+ case DW_CFA_offset:
+ case DW_CFA_def_cfa:
+ case DW_CFA_val_offset:
+ if (j)
+ {
+ if (i->u.ri.reg != j->u.ri.reg)
+ return FALSE;
+ if (i->u.ri.offset != j->u.ri.offset)
+ return FALSE;
+ }
+ break;
+
+ case DW_CFA_register:
+ if (j)
+ {
+ if (i->u.rr.reg1 != j->u.rr.reg1)
+ return FALSE;
+ if (i->u.rr.reg2 != j->u.rr.reg2)
+ return FALSE;
+ }
+ break;
+
+ case DW_CFA_def_cfa_register:
+ case DW_CFA_restore:
+ case DW_CFA_undefined:
+ case DW_CFA_same_value:
+ if (j)
+ {
+ if (i->u.r != j->u.r)
+ return FALSE;
+ }
+ break;
+
+ case DW_CFA_def_cfa_offset:
+ if (j)
+ {
+ if (i->u.i != j->u.i)
+ return FALSE;
+ }
+ break;
+
+ default:
+ return FALSE;
+ }
+ return TRUE;
+}
+
static struct cie_entry *
select_cie_for_fde (struct fde_entry *fde, bfd_boolean eh_frame,
struct cfi_insn_data **pfirst, int align)
@@ -2099,71 +2157,15 @@ select_cie_for_fde (struct fde_entry *fd
i != cie->last && j != NULL;
i = i->next, j = j->next)
{
- if (i->insn != j->insn)
- goto fail;
- switch (i->insn)
- {
- case DW_CFA_advance_loc:
- case DW_CFA_remember_state:
- /* We reached the first advance/remember in the FDE,
- but did not reach the end of the CIE list. */
- goto fail;
-
- case DW_CFA_offset:
- case DW_CFA_def_cfa:
- if (i->u.ri.reg != j->u.ri.reg)
- goto fail;
- if (i->u.ri.offset != j->u.ri.offset)
- goto fail;
- break;
-
- case DW_CFA_register:
- if (i->u.rr.reg1 != j->u.rr.reg1)
- goto fail;
- if (i->u.rr.reg2 != j->u.rr.reg2)
- goto fail;
- break;
-
- case DW_CFA_def_cfa_register:
- case DW_CFA_restore:
- case DW_CFA_undefined:
- case DW_CFA_same_value:
- if (i->u.r != j->u.r)
- goto fail;
- break;
-
- case DW_CFA_def_cfa_offset:
- if (i->u.i != j->u.i)
- goto fail;
- break;
-
- case CFI_escape:
- case CFI_val_encoded_addr:
- case CFI_label:
- /* Don't bother matching these for now. */
- goto fail;
-
- default:
- abort ();
- }
+ if (!initial_cie_insn (i, j))
+ break;
}
- /* Success if we reached the end of the CIE list, and we've either
- run out of FDE entries or we've encountered an advance,
- remember, or escape. */
- if (i == cie->last
- && (!j
- || j->insn == DW_CFA_advance_loc
- || j->insn == DW_CFA_remember_state
- || j->insn == CFI_escape
- || j->insn == CFI_val_encoded_addr
- || j->insn == CFI_label))
+ if (i == cie->last)
{
*pfirst = j;
return cie;
}
-
- fail:;
}
cie = XNEW (struct cie_entry);
@@ -2181,11 +2183,7 @@ select_cie_for_fde (struct fde_entry *fd
#endif
for (i = cie->first; i ; i = i->next)
- if (i->insn == DW_CFA_advance_loc
- || i->insn == DW_CFA_remember_state
- || i->insn == CFI_escape
- || i->insn == CFI_val_encoded_addr
- || i->insn == CFI_label)
+ if (!initial_cie_insn (i, NULL))
break;
cie->last = i;

View File

@ -0,0 +1,11 @@
--- binutils.orig/config/override.m4 2021-08-31 14:20:17.275574804 +0100
+++ binutils-2.37/config/override.m4 2021-08-31 14:36:37.793954247 +0100
@@ -41,7 +41,7 @@ dnl Or for updating the whole tree at on
AC_DEFUN([_GCC_AUTOCONF_VERSION_CHECK],
[m4_if(m4_defn([_GCC_AUTOCONF_VERSION]),
m4_defn([m4_PACKAGE_VERSION]), [],
- [m4_fatal([Please use exactly Autoconf ]_GCC_AUTOCONF_VERSION[ instead of ]m4_defn([m4_PACKAGE_VERSION])[.])])
+ [])
])
m4_define([AC_INIT], m4_defn([AC_INIT])[
_GCC_AUTOCONF_VERSION_CHECK

View File

@ -0,0 +1,17 @@
diff --git a/ld/testsuite/ld-plugin/lto.exp b/ld/testsuite/ld-plugin/lto.exp
index 3c129760498..dbda6c4465d 100644
--- a/ld/testsuite/ld-plugin/lto.exp
+++ b/ld/testsuite/ld-plugin/lto.exp
@@ -721,7 +721,7 @@ if { [at_least_gcc_version 4 7] } {
] \
]
set exec_output [run_host_cmd "sh" \
- "-c \"ulimit -n 16; \
+ "-c \" \
$ar -rc $plug_opt \
tmpdir/libpr23460.a \
tmpdir/pr23460a.o \
--
2.38.1

View File

@ -0,0 +1,59 @@
diff -rup binutils.orig/bfd/elflink.c binutils-2.35.2/bfd/elflink.c
--- binutils.orig/bfd/elflink.c 2022-11-28 16:10:23.919422266 +0000
+++ binutils-2.35.2/bfd/elflink.c 2022-11-28 16:14:24.308499080 +0000
@@ -1260,14 +1260,25 @@ _bfd_elf_merge_symbol (bfd *abfd,
olddyn = (oldsec->symbol->flags & BSF_DYNAMIC) != 0;
}
- /* Handle a case where plugin_notice won't be called and thus won't
- set the non_ir_ref flags on the first pass over symbols. */
if (oldbfd != NULL
- && (oldbfd->flags & BFD_PLUGIN) != (abfd->flags & BFD_PLUGIN)
- && newdyn != olddyn)
+ && (oldbfd->flags & BFD_PLUGIN) != (abfd->flags & BFD_PLUGIN))
{
- h->root.non_ir_ref_dynamic = TRUE;
- hi->root.non_ir_ref_dynamic = TRUE;
+ if (newdyn != olddyn)
+ {
+ /* Handle a case where plugin_notice won't be called and thus
+ won't set the non_ir_ref flags on the first pass over
+ symbols. */
+ h->root.non_ir_ref_dynamic = TRUE;
+ hi->root.non_ir_ref_dynamic = TRUE;
+ }
+
+ if ((oldbfd->flags & BFD_PLUGIN) != 0
+ && hi->root.type == bfd_link_hash_indirect)
+ {
+ /* Change indirect symbol from IR to undefined. */
+ hi->root.type = bfd_link_hash_undefined;
+ hi->root.u.undef.abfd = oldbfd;
+ }
}
/* NEWDEF and OLDDEF indicate whether the new or old symbol,
diff -rup binutils.orig/bfd/linker.c binutils-2.35.2/bfd/linker.c
--- binutils.orig/bfd/linker.c 2022-11-28 16:10:23.822422639 +0000
+++ binutils-2.35.2/bfd/linker.c 2022-11-28 16:13:28.709712603 +0000
@@ -1672,7 +1672,7 @@ _bfd_generic_link_add_one_symbol (struct
case MIND:
/* Multiple indirect symbols. This is OK if they both point
to the same symbol. */
- if (strcmp (h->u.i.link->root.string, string) == 0)
+ if (string != NULL && strcmp (h->u.i.link->root.string, string) == 0)
break;
/* Fall through. */
case MDEF:
--- binutils.orig/bfd/elflink.c 2023-01-10 15:47:50.062668055 +0000
+++ binutils-2.35.2/bfd/elflink.c 2023-01-10 15:47:59.554659559 +0000
@@ -1271,8 +1271,7 @@ _bfd_elf_merge_symbol (bfd *abfd,
h->root.non_ir_ref_dynamic = TRUE;
hi->root.non_ir_ref_dynamic = TRUE;
}
-
- if ((oldbfd->flags & BFD_PLUGIN) != 0
+ else if ((oldbfd->flags & BFD_PLUGIN) != 0
&& hi->root.type == bfd_link_hash_indirect)
{
/* Change indirect symbol from IR to undefined. */

View File

@ -0,0 +1,30 @@
diff -rup binutils.orig/bfd/configure binutils-2.35.2/bfd/configure
--- binutils.orig/bfd/configure 2023-01-19 12:17:21.293513059 +0000
+++ binutils-2.35.2/bfd/configure 2023-01-19 12:27:25.783974084 +0000
@@ -18921,11 +18921,6 @@ _LT_EOF
esac
done ;;
"bfd_stdint.h":C)
-if test "$GCC" = yes; then
- echo "/* generated for " `$CC --version | sed 1q` "*/" > tmp-stdint.h
-else
- echo "/* generated for $CC */" > tmp-stdint.h
-fi
sed 's/^ *//' >> tmp-stdint.h <<EOF
diff -rup binutils.orig/config/stdint.m4 binutils-2.35.2/config/stdint.m4
--- binutils.orig/config/stdint.m4 2023-01-19 12:17:20.169515897 +0000
+++ binutils-2.35.2/config/stdint.m4 2023-01-19 12:27:02.920032688 +0000
@@ -192,11 +192,6 @@ fi
# ----------------- done all checks, emit header -------------
AC_CONFIG_COMMANDS(_GCC_STDINT_H, [
-if test "$GCC" = yes; then
- echo "/* generated for " `$CC --version | sed 1q` "*/" > tmp-stdint.h
-else
- echo "/* generated for $CC */" > tmp-stdint.h
-fi
sed 's/^ *//' >> tmp-stdint.h <<EOF

View File

@ -1,45 +1,8 @@
# Determine if this is a native build or a cross build.
#
# For a cross build add --define "binutils_target <target>" to the command
# line when building the rpms.
#
# For example:
# --define "binutils_target aarch64-linux-gnu"
#
# Cross builds will create a set of binutils executables that will run on the
# host machine but which will create binaries suitable for running on the
# target machine. The cross tools will have the target name as a prefix,
# but for compatibility with the kernel the rpms will use the target name
# as an infix. So for example building with the above define will create a
# set of rpms like this:
#
# binutils-aarch64-linux-gnu-2.35.1-14.fc34.x86_64.rpm
# binutils-aarch64-linux-gnu-debuginfo-2.35.1-14.fc34.x86_64.rpm
# [etc]
#
# and the rpms will contain files like:
#
# /usr/bin/aarch64-linux-gnu-addr2line
# /usr/bin/aarch64-linux-gnu-ar
# /usr/bin/aarch64-linux-gnu-as
# [etc]
%if 0%{!?binutils_target:1}
%define binutils_target %{_target_platform}
%define isnative 1
%define enable_shared 1
%else
%define cross %{binutils_target}-
%define name_cross -%{binutils_target}
%define isnative 0
%define enable_shared 0
%endif
Summary: A GNU collection of binary utilities
Name: binutils%{?name_cross}%{?_with_debug:-debug}
Name: binutils%{?_with_debug:-debug}
Version: 2.35.2
Release: 24%{?dist}
Release: 37%{?dist}
License: GPLv3+
URL: https://sourceware.org/binutils
@ -59,9 +22,14 @@ URL: https://sourceware.org/binutils
# --without gold Disable building of the GOLD linker.
# --with clang To force building with the CLANG.
# --without debuginfod Disable support for debuginfod.
# --without systemzlib Use the binutils version of zlib.
# --without crossbuilds Do not build cross targeted versions of the binutils.
#---Start of Configure Options-----------------------------------------------
# Create shared libraries.
%define enable_shared 1
# Create deterministic archives (ie ones without timestamps).
# Default is off because of BZ 1195883.
%define enable_deterministic_archives 0
@ -118,11 +86,18 @@ URL: https://sourceware.org/binutils
%bcond_with clang
# Default: support debuginfod.
%bcond_without debuginfod
# Use the system supplied version of the zlib compress library.
# Change this to use the binutils builtin version instead.
%bcond_without systemzlib
# Create cross targeted versions of the binutils.
# For now we only do this for x86_64 hosts.
%ifarch x86_64
%bcond_without crossbuilds
%else
%bcond_with crossbuilds
%endif
%if %{with bootstrap}
%undefine with_docs
%undefine with_testsuite
@ -424,10 +399,31 @@ Patch55: binutils-s390-z16.patch
# Lifetime: Fixed in 2.37
Patch56: binutils-s390x-static-PIE.patch
# Purpose: Fix bogis linker warnings about references to undefined symbols.
# Purpose: Fix bogus linker warnings about references to undefined symbols.
# Lifetime: Fixed in 2.36
Patch57: binutils-undefined-ref-to-sym.patch
# Purpose: Fix unnecessary generation of CIE debug frames.
# Lifetime: Fixed in 2.40
Patch58: binutils-CIE-generation.patch
# Purpose: Fix a problem with symbol versioning with the LTO plugin.
# Lifetime: Fixed in 2.38
Patch59: binutils-ld-ir-plugin.patch
# Purpose: Allow the binutils to be configured with any (recent) version of
# autoconf.
# Lifetime: Fixed in 2.39 (maybe ?)
Patch60: binutils-autoconf-version.patch
# Purpose: Increase the max number of open files to 20 for upstream binutils
# PR23460 test which may have more than 16 file descriptors open
# Lifetime: Fixed in 2.39
Patch61: binutils-increase-the-max-number-of-open-fi.patch
# Purpose: Remove a comment from bfd_stdint.h, indicating how the file was generated.
# Lifetime: Fixed in 2.39 ?
Patch62: binutils-no-comment-in-bfd-stdint.patch
#----------------------------------------------------------------------------
Provides: bundled(libiberty)
@ -573,6 +569,62 @@ Conflicts: gcc-c++ < 4.0.0
%{!?ld_bfd_priority: %global ld_bfd_priority 50}
#----------------------------------------------------------------------------
%if %{with crossbuilds}
# Only undefine with_testsuite here when testing changes to the spec file.
# %%undefine with_testsuite
%global cross_targets aarch64-redhat-linux ppc64le-redhat-linux s390x-redhat-linux x86_64-redhat-linux
%package -n cross-binutils-aarch64
Summary: Cross targeted AArch64 binutils for developer use. Not intended for production.
Provides: cross-binutils-aarch64 = %{version}-%{release}
Requires: zlib-devel coreutils
BuildRequires: autoconf automake perl sed coreutils make gcc findutils gcc-c++
ExcludeArch: aarch64-linux-gnu aarch64-redhat-linux
%description -n cross-binutils-aarch64
This package contains an AArch64 cross targeted version of the binutils for
use by developers. It is NOT INTENDED FOR PRODUCTION use.
%package -n cross-binutils-ppc64le
Summary: Cross targeted PPC64LE binutils for developer use. Not intended for production.
Provides: cross-binutils-ppc64le = %{version}-%{release}
Requires: zlib-devel coreutils
BuildRequires: autoconf automake perl sed coreutils make gcc findutils gcc-c++
ExcludeArch: ppc64le-linux-gnu ppc64le-redhat-linux
%description -n cross-binutils-ppc64le
This package contains a PPC64LE cross targeted version of the binutils for
use by developers. It is NOT INTENDED FOR PRODUCTION use.
%package -n cross-binutils-s390x
Summary: Cross targeted S390X binutils for developer use. Not intended for production.
Provides: cross-binutils-s390x = %{version}-%{release}
Requires: zlib-devel coreutils
BuildRequires: autoconf automake perl sed coreutils make gcc findutils gcc-c++
ExcludeArch: s390x-linux-gnu s390x-redhat-linux
%description -n cross-binutils-s390x
This package contains a S390X cross targeted version of the binutils for
use by developers. It is NOT INTENDED FOR PRODUCTION use.
%package -n cross-binutils-x86_64
Summary: Cross targeted X86_64 binutils for developer use. Not intended for production.
Provides: cross-binutils-x86_64 = %{version}-%{release}
Requires: zlib-devel coreutils
BuildRequires: autoconf automake perl sed coreutils make gcc findutils gcc-c++
ExcludeArch: x86_64-linux-gnu x86_64-redhat-linux i686-linux-gnu i686-redhat-linux
%description -n cross-binutils-x86_64
This package contains a X86_64 cross targeted version of the binutils for
use by developers. It is NOT INTENDED FOR PRODUCTION use.
%endif
#----------------------------------------------------------------------------
%prep
@ -618,72 +670,68 @@ touch */configure
#----------------------------------------------------------------------------
%build
echo target is %{binutils_target}
%ifarch %{power64}
export CFLAGS="$RPM_OPT_FLAGS -Wno-error"
%else
export CFLAGS="$RPM_OPT_FLAGS"
%endif
CARGS=
set_build_configuration()
{
CARGS="--quiet \
--build=%{_target_platform} \
--host=%{_target_platform} \
--enable-ld \
--enable-plugins \
--enable-64-bit-bfd \
--with-bugurl=http://bugzilla.redhat.com/bugzilla/"
%if %{with debuginfod}
CARGS="$CARGS --with-debuginfod"
%endif
case %{binutils_target} in i?86*|sparc*|ppc*|s390*|sh*|arm*|aarch64*|riscv*)
CARGS="$CARGS --enable-64-bit-bfd"
;;
esac
# Extra targets to build along with the default one.
#
# BZ 1920373: Enable PEP support for all targets as the PERF package's
# testsuite expects to be able to read PE format files ragrdless of
# the host's architecture.
#
# Also enable the BPF target so that strip will work on BPF files.
case %{binutils_target} in
s390*)
# FIXME: For some unknown reason settting --enable-targets=x86_64-pep
# here breaks the building of GOLD. I have no idea why, and not enough
# knowledge of how gold is configured to fix quickly. So instead I have
# found that supporting "all" targets works.
CARGS="$CARGS --enable-targets=all"
;;
ia64*)
CARGS="$CARGS --enable-targets=ia64-linux,x86_64-pep,bpf-unknown-none"
;;
ppc64-*)
CARGS="$CARGS --enable-targets=powerpc64le-linux,spu,x86_64-pep,bpf-unknown-none"
;;
ppc64le*)
CARGS="$CARGS --enable-targets=powerpc-linux,spu,x86_64-pep,bpf-unknown-none"
;;
*)
CARGS="$CARGS --enable-targets=x86_64-pep,bpf-unknown-none"
;;
esac
%if %{default_relro}
CARGS="$CARGS --enable-relro=yes"
%else
CARGS="$CARGS --enable-relro=no"
%endif
%if %{with debug}
export CFLAGS="$CFLAGS -O0 -ggdb2 -Wno-error -D_FORTIFY_SOURCE=0"
%define enable_shared 0
%if %{with systemzlib}
CARGS="$CARGS --with-system-zlib"
%endif
# BZ 1541027 - include the linker flags from redhat-rpm-config as well.
export LDFLAGS=$RPM_LD_FLAGS
%if %{with clang}
%define _with_cc_clang 1
%if %{enable_deterministic_archives}
CARGS="$CARGS --enable-deterministic-archives"
%else
CARGS="$CARGS --enable-deterministic-archives=no"
%endif
%if %{enable_lto}
CARGS="$CARGS --enable-lto"
%endif
%if %{enable_new_dtags}
CARGS="$CARGS --enable-new-dtags"
%endif
%if %{default_compress_debug}
CARGS="$CARGS --enable-compressed-debug-sections=all"
%else
CARGS="$CARGS --enable-compressed-debug-sections=none"
%endif
%if %{default_generate_notes}
CARGS="$CARGS --enable-generate-build-notes=yes"
%else
CARGS="$CARGS --enable-generate-build-notes=no"
%endif
%if %{enable_threading}
CARGS="$CARGS --enable-threads=yes"
%else
CARGS="$CARGS --enable-threads=no"
%endif
}
# ----------------------------------------------------------------
reconfigure_sources()
{
# Dependencies are not set up to rebuild the configure files
# in the subdirectories. So we just rebuild the ones we care
# about after applying the configure patches
@ -693,79 +741,156 @@ popd
pushd intl
autoconf
popd
}
# ----------------------------------------------------------------
#
# build()
# Build the binutils.
# $1 is the target architecture
# $2 is 1 if this is a native build
# $3 is 1 if shared libraries should be built
#
build()
{
local target="$1"
local native="$2"
local shared="$3"
local builddir=build-$target
# Create a buyild directory
rm -rf $builddir
mkdir $builddir
pushd $builddir
echo "BUILDING the binutils FOR TARGET $target (native ? $native) (shared ? $shared)"
%ifarch %{power64}
export CFLAGS="$RPM_OPT_FLAGS -Wno-error"
%else
export CFLAGS="$RPM_OPT_FLAGS"
%endif
%if %{with debug}
export CFLAGS="$CFLAGS -O0 -ggdb2 -Wno-error -D_FORTIFY_SOURCE=0"
shared=0
%endif
export CXXFLAGS="$CXXFLAGS $CFLAGS"
# BZ 1541027 - include the linker flags from redhat-rpm-config as well.
export LDFLAGS=$RPM_LD_FLAGS
%if %{with clang}
%define _with_cc_clang 1
%endif
# We could improve the cross build's size by setting --enable-shared but
# the produced binaries may be less convenient in the embedded environment.
%configure \
--quiet \
--build=%{_target_platform} --host=%{_target_platform} \
--target=%{binutils_target} \
%if %{with gold}
--enable-gold=default \
%endif
--enable-ld \
%if %{isnative}
--with-sysroot=/ \
%else
--enable-targets=%{_host} \
--with-sysroot=%{_prefix}/%{binutils_target}/sys-root \
--program-prefix=%{cross} \
%endif
%if %{with systemzlib}
--with-system-zlib \
%endif
%if %{enable_shared}
--enable-shared \
%else
--disable-shared \
%endif
%if %{enable_deterministic_archives}
--enable-deterministic-archives \
%else
--enable-deterministic-archives=no \
%endif
%if %{enable_lto}
--enable-lto \
%endif
%if %{enable_new_dtags}
--enable-new-dtags \
%endif
%if %{default_compress_debug}
--enable-compressed-debug-sections=all \
%else
--enable-compressed-debug-sections=none \
%endif
%if %{default_generate_notes}
--enable-generate-build-notes=yes \
%else
--enable-generate-build-notes=no \
%endif
%if %{enable_threading}
--enable-threads=yes \
%else
--enable-threads=no \
%endif
$CARGS \
--enable-plugins \
--with-bugurl=http://bugzilla.redhat.com/bugzilla/ \
|| cat config.log
# Extra targets to build along with the default one.
#
# BZ 1920373: Enable PEP support for all targets as the PERF package's
# testsuite expects to be able to read PE format files ragrdless of
# the host's architecture.
#
# Also enable the BPF target so that strip will work on BPF files.
case $target in
s390*)
# Note - The s390-linux target is there so that the GOLD linker will
# build. By default, if configured for just s390x-linux, the GOLD
# configure system will only include support for 64-bit targets, but
# the s390x gold backend uses both 32-bit and 64-bit templates.
TARGS="--enable-targets=s390-linux,s390x-linux,x86_64-pep,bpf-unknown-none"
;;
ia64*)
TARGS="--enable-targets=ia64-linux,x86_64-pep,bpf-unknown-none"
;;
ppc64-*)
TARGS="--enable-targets=powerpc64le-linux,spu,x86_64-pep,bpf-unknown-none"
;;
ppc64le*)
TARGS="--enable-targets=powerpc-linux,spu,x86_64-pep,bpf-unknown-none"
;;
*)
TARGS="--enable-targets=x86_64-pep,bpf-unknown-none"
;;
esac
# We disable the GOLD linker for cross builds because although it does
# support sysroots specified on the command line, it does not support
# them in linker scripts via the =/$SYSROOT prefix.
if test x$native == x1 ; then
SARGS="--with-sysroot=/ \
--prefix=%{_prefix} \
--libdir=%{_libdir} \
--enable-gold=default"
else
TARGS=""
SARGS="--with-sysroot=yes \
--program-prefix=$target- \
--prefix=%{_prefix}/$target \
--libdir=%{_libdir} \
--exec-prefix=%{_usr} \
--disable-gold"
fi
if test x$shared == x1 ; then
RARGS="--enable-shared"
else
RARGS="--disable-shared"
fi
../configure --target=$target $SARGS $RARGS $CARGS $TARGS || cat config.log
%if %{with docs}
# Because of parallel building, info has to be made after all.
%make_build %{_smp_mflags} tooldir=%{_prefix} all
%make_build %{_smp_mflags} tooldir=%{_prefix} info
%else
%make_build %{_smp_mflags} tooldir=%{_prefix} MAKEINFO=true all
%endif
popd
}
#----------------------------------------------------------------------------
#
# run_tests()
# Test a built (but not installed) binutils.
# $1 is the target architecture
# $2 is 1 if this is a native build
#
run_tests()
{
local target="$1"
local native="$2"
echo "TESTING the binutils FOR TARGET $target (native ? $native)"
# Do not use %%check as it is run after %%install where libbfd.so is rebuilt
# with -fvisibility=hidden no longer being usable in its shared form.
%if %{without testsuite}
echo ====================TESTSUITE DISABLED=========================
%else
echo ================ $target == TESTSUITE DISABLED ====================
return
%endif
pushd build-$target
if test x$native == x1 ; then
make -k check < /dev/null || :
echo ====================TESTING=========================
cat {gas/testsuite/gas,ld/ld,binutils/binutils}.sum
else
make -k check-gas check-binutils < /dev/null || :
fi
echo ================ $target == TESTING BEGINS ========================
for f in {gas/testsuite/gas,ld/ld,binutils/binutils}.sum
do
if [ -f $f ]; then
cat $f
fi
done
%if %{with gold}
if [ -f gold/test-suite.log ]; then
cat gold/test-suite.log
@ -774,79 +899,140 @@ if [ -f gold/testsuite/test-suite.log ]; then
cat gold/testsuite/*.log
fi
%endif
echo ====================TESTING END=====================
echo ================ $target == TESTING END ===========================
for file in {gas/testsuite/gas,ld/ld,binutils/binutils}.{sum,log}
do
ln $file binutils-%{_target_platform}-$(basename $file) || :
if [ -f $file ]; then
ln $file binutils-$target-$(basename $file) || :
fi
done
tar cjf binutils-%{_target_platform}.tar.xz binutils-%{_target_platform}-*.{sum,log}
uuencode binutils-%{_target_platform}.tar.xz binutils-%{_target_platform}.tar.xz
rm -f binutils-%{_target_platform}.tar.xz binutils-%{_target_platform}-*.{sum,log}
tar cjf binutils-$target.tar.xz binutils-$target-*.{sum,log}
uuencode binutils-$target.tar.xz binutils-$target.tar.xz
rm -f binutils-$target.tar.xz binutils-$target-*.{sum,log}
%if %{with gold}
if [ -f gold/testsuite/test-suite.log ]; then
tar cjf binutils-%{_target_platform}-gold.log.tar.xz gold/testsuite/*.log
uuencode binutils-%{_target_platform}-gold.log.tar.xz binutils-%{_target_platform}-gold.log.tar.xz
rm -f binutils-%{_target_platform}-gold.log.tar.xz
tar cjf binutils-$target-gold.log.tar.xz gold/testsuite/*.log
uuencode binutils-$target-gold.log.tar.xz binutils-$target-gold.log.tar.xz
rm -f binutils-$target-gold.log.tar.xz
fi
%endif
%endif
popd
}
#----------------------------------------------------------------------------
set_build_configuration
# reconfigure_sources
build %{_target_platform} 1 %{enable_shared}
run_tests %{_target_platform} 1
%if %{with crossbuilds}
for f in %{cross_targets}; do
if test x$f != x%{_target_platform}; then
# We could improve the cross build's size by enabling shared libraries but
# the produced binaries may be less convenient in the embedded environment.
build $f 0 0
run_tests $f 0
fi
done
%endif
#----------------------------------------------------------------------------
#----------------------------------------------------------------------------
%install
# install_binutils()
# Install the binutils.
# $1 is the target architecture
# $2 is 1 if this is a native build
# $3 is 1 if shared libraries should be built
#
install_binutils()
{
local target="$1"
local native="$2"
local shared="$3"
local local_root=%{buildroot}/usr
local local_bindir=$local_root/bin
local local_libdir=%{buildroot}%{_libdir}
local local_mandir=$local_root/share/man/man1
local local_incdir=$local_root/include
local local_infodir=$local_root/share/info
local local_libdir
mkdir -p $local_libdir
mkdir -p $local_incdir
mkdir -p $local_mandir
mkdir -p $local_infodir
echo "INSTALLING the binutils FOR TARGET $target (native ? $native) (shared ? $shared)"
pushd build-$target
if test x$native == x1 ; then
%if %{with docs}
%make_install DESTDIR=%{buildroot}
make prefix=%{buildroot}%{_prefix} infodir=$local_infodir install-info
%else
%make_install DESTDIR=%{buildroot} MAKEINFO=true
%endif
%if %{isnative}
%if %{with docs}
make prefix=%{buildroot}%{_prefix} infodir=%{buildroot}%{_infodir} install-info
%endif
# Rebuild libiberty.a with -fPIC.
# Future: Remove it together with its header file, projects should bundle it.
%make_build -C libiberty clean
%make_build -s -C libiberty clean
%set_build_flags
%make_build CFLAGS="-g -fPIC $RPM_OPT_FLAGS" -C libiberty
%make_build -s CFLAGS="-g -fPIC $RPM_OPT_FLAGS" -C libiberty
# Rebuild libbfd.a with -fPIC.
# Without the hidden visibility the 3rd party shared libraries would export
# the bfd non-stable ABI.
%make_build -C bfd clean
%make_build -s -C bfd clean
%set_build_flags
%make_build CFLAGS="-g -fPIC $RPM_OPT_FLAGS -fvisibility=hidden" -C bfd
%make_build -s CFLAGS="-g -fPIC $RPM_OPT_FLAGS -fvisibility=hidden" -C bfd
# Rebuild libopcodes.a with -fPIC.
%make_build -C opcodes clean
%make_build -s -C opcodes clean
%set_build_flags
%make_build CFLAGS="-g -fPIC $RPM_OPT_FLAGS" -C opcodes
%make_build -s CFLAGS="-g -fPIC $RPM_OPT_FLAGS" -C opcodes
install -m 644 bfd/libbfd.a $local_libdir
install -m 644 libiberty/libiberty.a $local_libdir
install -m 644 ../include/libiberty.h $local_incdir
install -m 644 opcodes/libopcodes.a $local_libdir
install -m 644 bfd/libbfd.a %{buildroot}%{_libdir}
install -m 644 libiberty/libiberty.a %{buildroot}%{_libdir}
install -m 644 include/libiberty.h %{buildroot}%{_prefix}/include
install -m 644 opcodes/libopcodes.a %{buildroot}%{_libdir}
# Remove Windows/Novell only man pages
rm -f %{buildroot}%{_mandir}/man1/{dlltool,nlmconv,windres,windmc}*
rm -f $local_mandir/{dlltool,nlmconv,windres,windmc}*
%if %{without docs}
rm -f %{buildroot}%{_mandir}/man1/{addr2line,ar,as,c++filt,elfedit,gprof,ld,nm,objcopy,objdump,ranlib,readelf,size,strings,strip}*
rm -f %{buildroot}%{_infodir}/{as,bfd,binutils,gprof,ld}*
rm -f $local_mandir/{addr2line,ar,as,c++filt,elfedit,gprof,ld,nm,objcopy,objdump,ranlib,readelf,size,strings,strip}*
rm -f $local_infodir/{as,bfd,binutils,gprof,ld}*
%endif
%if %{enable_shared}
chmod +x %{buildroot}%{_libdir}/lib*.so*
chmod +x $local_libdir/lib*.so*
%endif
# Prevent programs from linking against libbfd and libopcodes
# dynamically, as they are changed far too often.
rm -f %{buildroot}%{_libdir}/lib{bfd,opcodes}.so
rm -f $local_libdir/lib{bfd,opcodes}.so
# Remove libtool files, which reference the .so libs
rm -f %{buildroot}%{_libdir}/lib{bfd,opcodes}.la
rm -f %local_libdir/lib{bfd,opcodes}.la
# Sanity check --enable-64-bit-bfd really works.
grep '^#define BFD_ARCH_SIZE 64$' %{buildroot}%{_prefix}/include/bfd.h
grep '^#define BFD_ARCH_SIZE 64$' $local_incdir/bfd.h
# Fix multilib conflicts of generated values by __WORDSIZE-based expressions.
%ifarch %{ix86} x86_64 ppc %{power64} s390 s390x sh3 sh4 sparc sparc64 arm
sed -i -e '/^#include "ansidecl.h"/{p;s~^.*$~#include <bits/wordsize.h>~;}' \
@ -858,9 +1044,10 @@ sed -i -e '/^#include "ansidecl.h"/{p;s~^.*$~#include <bits/wordsize.h>~;}' \
#define BFD_HOST_64_BIT long\
#endif/' \
-e 's/^#define BFD_HOST_U_64_BIT unsigned \(long \)\?long *$/#define BFD_HOST_U_64_BIT unsigned BFD_HOST_64_BIT/' \
%{buildroot}%{_prefix}/include/bfd.h
$local_incdir/bfd.h
%endif
touch -r bfd/bfd-in2.h %{buildroot}%{_prefix}/include/bfd.h
touch -r ../bfd/bfd-in2.h $local_incdir/bfd.h
# Generate .so linker scripts for dependencies; imported from glibc/Makerules:
@ -871,7 +1058,7 @@ OUTPUT_FORMAT="\
on a multi-architecture system. */
$(gcc $CFLAGS $LDFLAGS -shared -x c /dev/null -o /dev/null -Wl,--verbose -v 2>&1 | sed -n -f "%{SOURCE2}")"
tee %{buildroot}%{_libdir}/libbfd.so <<EOH
tee $local_libdir/libbfd.so <<EOH
/* GNU ld script */
$OUTPUT_FORMAT
@ -881,7 +1068,7 @@ $OUTPUT_FORMAT
INPUT ( %{_libdir}/libbfd.a -liberty -lz -ldl )
EOH
tee %{buildroot}%{_libdir}/libopcodes.so <<EOH
tee $local_libdir/libopcodes.so <<EOH
/* GNU ld script */
$OUTPUT_FORMAT
@ -889,62 +1076,78 @@ $OUTPUT_FORMAT
INPUT ( %{_libdir}/libopcodes.a -lbfd )
EOH
%else
# For cross-binutils we drop the documentation.
rm -rf %{buildroot}%{_infodir}
# We keep these as one can have native + cross binutils of different versions.
#rm -rf {buildroot}{_prefix}/share/locale
#rm -rf {buildroot}{_mandir}
rm -rf %{buildroot}%{_libdir}/libiberty.a
# Remove libtool files, which reference the .so libs
rm -f %{buildroot}%{_libdir}/lib{bfd,opcodes}.la
%endif
rm -fr $local_root/$target
else # CROSS BUILDS
local target_root=$local_root/$target
%make_install DESTDIR=%{buildroot} MAKEINFO=true
fi
# This one comes from gcc
rm -f %{buildroot}%{_infodir}/dir
rm -rf %{buildroot}%{_prefix}/%{binutils_target}
rm -f $local_infodir/dir
%find_lang %{?cross}binutils
%find_lang %{?cross}opcodes
%find_lang %{?cross}bfd
%find_lang %{?cross}gas
%find_lang %{?cross}gprof
cat %{?cross}opcodes.lang >> %{?cross}binutils.lang
cat %{?cross}bfd.lang >> %{?cross}binutils.lang
cat %{?cross}gas.lang >> %{?cross}binutils.lang
cat %{?cross}gprof.lang >> %{?cross}binutils.lang
%find_lang binutils
%find_lang opcodes
%find_lang bfd
%find_lang gas
%find_lang gprof
cat opcodes.lang >> binutils.lang
cat bfd.lang >> binutils.lang
cat gas.lang >> binutils.lang
cat gprof.lang >> binutils.lang
if [ -x ld/ld-new ]; then
%find_lang %{?cross}ld
cat %{?cross}ld.lang >> %{?cross}binutils.lang
%find_lang ld
cat ld.lang >> binutils.lang
fi
if [ -x gold/ld-new ]; then
%find_lang %{?cross}gold
cat %{?cross}gold.lang >> %{?cross}binutils.lang
%find_lang gold
cat gold.lang >> binutils.lang
fi
popd
}
#----------------------------------------------------------------------------
install_binutils %{_target_platform} 1 %{enable_shared}
%if %{with crossbuilds}
for f in %{cross_targets}; do
if test x$f != x%{_target_platform}; then
# We could improve the cross build's size by enabling shared libraries but
# the produced binaries may be less convenient in the embedded environment.
install_binutils $f 0 0
fi
done
%endif
# Stop check-rpaths from complaining about standard runpaths.
export QA_RPATHS=0x0001
export QA_RPATHS=0x0003
#----------------------------------------------------------------------------
#----------------------------------------------------------------------------
%post
%__rm -f %{_bindir}/%{?cross}ld
%{_sbindir}/alternatives --install %{_bindir}/%{?cross}ld %{?cross}ld \
%{_bindir}/%{?cross}ld.bfd %{ld_bfd_priority}
%__rm -f %{_bindir}/ld
%{_sbindir}/alternatives --install %{_bindir}/ld ld \
%{_bindir}/ld.bfd %{ld_bfd_priority}
%if %{with gold}
%{_sbindir}/alternatives --install %{_bindir}/%{?cross}ld %{?cross}ld \
%{_bindir}/%{?cross}ld.gold %{ld_gold_priority}
%{_sbindir}/alternatives --install %{_bindir}/ld ld \
%{_bindir}/ld.gold %{ld_gold_priority}
%endif
# Do not run "alternatives --auto ld" here. Leave the setting to
# however the user previously had it set. See BZ 1592069 for more details.
%if %{isnative}
%ldconfig_post
%endif
exit 0
@ -952,11 +1155,11 @@ exit 0
%preun
if [ $1 = 0 ]; then
%{_sbindir}/alternatives --remove %{?cross}ld %{_bindir}/%{?cross}ld.bfd
%{_sbindir}/alternatives --remove ld %{_bindir}/ld.bfd
fi
%if %{with gold}
if [ $1 = 0 ]; then
%{_sbindir}/alternatives --remove %{?cross}ld %{_bindir}/%{?cross}ld.gold
%{_sbindir}/alternatives --remove ld %{_bindir}/ld.gold
fi
%endif
@ -964,63 +1167,139 @@ exit 0
#----------------------------------------------------------------------------
%if %{isnative}
%postun
%ldconfig_postun
%endif
#----------------------------------------------------------------------------
%files -f %{?cross}binutils.lang
%files -f build-%{_target_platform}/binutils.lang
%if %{with crossbuilds}
%if "%{_target_platform}" != "aarch64-redhat-linux"
%exclude /usr/aarch64-redhat-linux/*
%exclude /usr/bin/aarch64-redhat-linux-*
%endif
%if "%{_target_platform}" != "ppc64le-redhat-linux"
%exclude /usr/ppc64le-redhat-linux/*
%exclude /usr/bin/ppc64le-redhat-linux-*
%endif
%if "%{_target_platform}" != "s390x-redhat-linux"
%exclude /usr/s390x-redhat-linux/*
%exclude /usr/bin/s390x-redhat-linux-*
%endif
%if "%{_target_platform}" != "x86_64-redhat-linux"
%exclude /usr/x86_64-redhat-linux/*
%exclude /usr/bin/x86_64-redhat-linux-*
%endif
%endif
%license COPYING COPYING3 COPYING3.LIB COPYING.LIB
%doc README
%{_bindir}/%{?cross}[!l]*
%{_bindir}/[!l]*
# Strictly speaking ld is a symlink not a ghost file, but %%verify does not support symlinks
%ghost %{_bindir}/%{?cross}ld
%{_bindir}/%{?cross}ld.bfd
# Do not export any Windows tools (if they were built)
%exclude %{_bindir}/%{?cross}dll*
%exclude %{_bindir}/%{?cross}wind*
%ghost %{_bindir}/ld
%{_bindir}/ld.bfd
%if %{with docs}
%{_mandir}/man1/
%if %{isnative}
%{_infodir}/as.info.*
%{_infodir}/binutils.info.*
%{_infodir}/gprof.info.*
%{_infodir}/ld.info.*
%{_infodir}/bfd.info.*
%endif
%endif
%if %{enable_shared}
%{_libdir}/lib*.so
%{_libdir}/libctf*
%{_libdir}/lib*.so*
%{_libdir}/lib*.la
%exclude %{_libdir}/libbfd.so
%exclude %{_libdir}/libopcodes.so
%exclude %{_libdir}/libctf.a
%exclude %{_libdir}/libctf-nobfd.a
%exclude %{_libdir}/libbfd.la
%exclude %{_libdir}/libopcodes.la
%endif
%if %{isnative}
%if %{with gold}
%files gold
%{_bindir}/ld.gold
%endif
%files devel
%{_prefix}/include/*
%{_libdir}/lib*.a
%{_libdir}/libbfd.so
%{_libdir}/libopcodes.so
%{_libdir}/libbfd.la
%{_libdir}/libopcodes.la
%if %{with crossbuilds}
%if "%{_target_platform}" != "aarch64-redhat-linux"
%files -n cross-binutils-aarch64
/usr/aarch64-redhat-linux/
/usr/bin/aarch64-redhat-linux-*
%endif
%if %{with gold}
%files gold
%{_bindir}/%{?cross}ld.gold
%if "%{_target_platform}" != "ppc64le-redhat-linux"
%files -n cross-binutils-ppc64le
/usr/ppc64le-redhat-linux/
/usr/bin/ppc64le-redhat-linux-*
%endif
# %%ghost %%{_bindir}/%%{?cross}ld
%if "%{_target_platform}" != "s390x-redhat-linux"
%files -n cross-binutils-s390x
/usr/s390x-redhat-linux/
/usr/bin/s390x-redhat-linux-*
%endif
%if "%{_target_platform}" != "x86_64-redhat-linux"
%files -n cross-binutils-x86_64
/usr/x86_64-redhat-linux/
/usr/bin/x86_64-redhat-linux-*
%endif
%endif
#----------------------------------------------------------------------------
%changelog
* Fri Jan 20 2023 Nick Clifton <nickc@redhat.com> - 2.35.2-37
- Stop the cross binaries from leaking into the native packages.
* Thu Jan 19 2023 Nick Clifton <nickc@redhat.com> - 2.35.2-36
- Ensure that x76_64 and i686 versions of bfd_stdint.h are the same. (#2162328)
* Tue Jan 10 2023 Nick Clifton <nickc@redhat.com> - 2.35.2-35
- Extend fix handling symbol versioning with LTO plugins. (#2148469)
* Mon Dec 19 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-33
- Restore libiberty.a to the binutils-devel package. (#2154772)
* Wed Dec 14 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-32
- Fix special case of previous delta for s390x. (#2151938)
* Mon Dec 12 2022 Yara Ahmamd <yahmad@redhat.com> -2.35.2-31
- Increase the max number of open files to 20. (#2151938)
* Mon Dec 12 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-30
- Disable building GOLD for cross-binutils.
* Wed Dec 07 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-29
- Eliminate duplicates between sub-packages and add missing shared libraries. (#2149646)
* Wed Nov 30 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-28
- Eliminate duplicates between sub-packages. (#2149646)
* Wed Nov 30 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-27
- Create cross-binutils-<ARCH> sub-packages. (#2149646)
* Mon Nov 28 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-26
- Fix handling symbol versioning with LTO plugins. (#2148469)
* Thu Sep 08 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-25
- Fix the generation of unnecesaary CIE stack unwinding frames. (#2121123)
* Mon Jun 13 2022 Nick Clifton <nickc@redhat.com> - 2.35.2-24
- Fix bogus linker warnings about references to undefined symbols. (#2095926)