SHA256
3
0
forked from pool/binutils

Compare commits

...

10 Commits

Author SHA256 Message Date
Ana Guerrero
4b78165cf7 Accepting request 1237516 from devel:gcc
- Enable multitarget build on loongarch64 (forwarded request 1236850 from jsulig)

OBS-URL: https://build.opensuse.org/request/show/1237516
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/binutils?expand=0&rev=176
2025-01-15 16:42:31 +00:00
Michael Matz
872ccfe028 - Enable multitarget build on loongarch64
OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=486
2025-01-13 15:24:18 +00:00
Ana Guerrero
0b92143ab3 Accepting request 1235669 from devel:gcc
- Unset SUSE_ZNOW while running testsuite, many tests cannot cope (forwarded request 1231723 from Andreas_Schwab)

OBS-URL: https://build.opensuse.org/request/show/1235669
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/binutils?expand=0&rev=175
2025-01-09 14:04:09 +00:00
Michael Matz
ea6705f235 - Unset SUSE_ZNOW while running testsuite, many tests cannot cope
OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=484
2025-01-07 16:15:39 +00:00
Ana Guerrero
1100ed340e Accepting request 1229830 from devel:gcc
This gives us loongarch, new s390 insns (for SLE), and for now
avoid the issue with zstd we had in the last submission (by not
using it by default).  It's also what is going to be in SLE-15
soon.

- Update to current 2.43.1 branch [PED-10254, PED-10306]:
  * s390 - Add arch15 instructions
  * various fixes from upstream: PR32153, PR32171, PR32189,
    PR32196, PR32191, PR32109, PR32372, PR32387
- Adjusted binutils-2.43-branch.diff.gz.
- Disable zstd-by-default again (needs adjustments in at least
  golang,llvm15,llvm17 first)
- Add binutils-fix-branch.diff.
- Check non-changing of flex/bison inputs only after applying
  branch and fix-branch diffs.

- drop ld-relro.diff (relro is the default for some time)
  and it warns on avr spuriously (bsc#1233520)

- Add loongarch64 as new target

- Enable zstd compression algorithm (instead of zlib)
  for debug info sections by default.

OBS-URL: https://build.opensuse.org/request/show/1229830
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/binutils?expand=0&rev=174
2024-12-11 20:01:22 +00:00
Michael Matz
37d03cdb94 - Disable zstd-by-default again (needs adjustments in at least
golang,llvm15,llvm17 first)
- Add binutils-fix-branch.diff.
- Check non-changing of flex/bison inputs only after applying
  branch and fix-branch diffs.

OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=482
2024-12-09 15:54:38 +00:00
Michael Matz
89ba785707 - Update to current 2.43.1 branch [PED-10254, PED-10306]:
* s390 - Add arch15 instructions
  * various fixes from upstream: PR32153, PR32171, PR32189,
    PR32196, PR32191, PR32109, PR32372, PR32387
- Adjusted binutils-2.43-branch.diff.gz.

OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=481
2024-12-09 14:59:58 +00:00
Richard Biener
a2d6bc201e - Add loongarch64 as new target
OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=480
2024-11-26 10:31:59 +00:00
Richard Biener
38e0c73256 - drop ld-relro.diff (relro is the default for some time)
and it warns on avr spuriously (bsc#1233520)

OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=479
2024-11-26 10:31:08 +00:00
Michael Matz
5b00f2f6a7 Accepting request 1199785 from home:martinliska:branches:devel:gcc
- Enable zstd compression algorithm (instead of zlib)
  for debug info sections by default.

OBS-URL: https://build.opensuse.org/request/show/1199785
OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=478
2024-10-14 13:27:39 +00:00
6 changed files with 83 additions and 77 deletions

View File

@ -16,6 +16,7 @@
<flavor>spu</flavor> <flavor>spu</flavor>
<flavor>avr</flavor> <flavor>avr</flavor>
<flavor>pru</flavor> <flavor>pru</flavor>
<flavor>loongarch64</flavor>
<flavor>mips</flavor> <flavor>mips</flavor>
<flavor>m68k</flavor> <flavor>m68k</flavor>
<flavor>epiphany</flavor> <flavor>epiphany</flavor>

BIN
binutils-2.43-branch.diff.gz (Stored with Git LFS)

Binary file not shown.

22
binutils-fix-branch.diff Normal file
View File

@ -0,0 +1,22 @@
This is used to manually patch the bison generated files when
the binutils-X.YZ-branch.diff touches them. That diff is generated
directly from git and doesn't contain the generated .c/h files.
The base tarball does contain them, but generated from the unpatched state.
In SLE12 and older we can't regenerate them due to too old versions
of flex and bison.
So, when the branch diff _does_ touch them we need to do the regeneration
via such a manual patch.
Index: binutils-2.43/ld/ldgram.c
===================================================================
--- binutils-2.43.orig/ld/ldgram.c 2024-08-04 01:00:00.000000000 +0200
+++ binutils-2.43/ld/ldgram.c 2024-12-09 16:41:08.089715376 +0100
@@ -2839,7 +2839,7 @@ yyreduce:
case 73: /* ifile_p1: SEARCH_DIR '(' filename ')' */
#line 324 "ldgram.y"
- { ldfile_add_library_path ((yyvsp[-1].name), search_dir_linker_script); }
+ { ldfile_add_library_path ((yyvsp[-1].name), false); }
#line 2844 "ldgram.c"
break;

View File

@ -1,3 +1,44 @@
-------------------------------------------------------------------
Fri Jan 10 08:54:55 UTC 2025 - JS <obs.coke518@passinbox.com>
- Enable multitarget build on loongarch64
-------------------------------------------------------------------
Tue Dec 17 14:09:54 UTC 2024 - Andreas Schwab <schwab@suse.de>
- Unset SUSE_ZNOW while running testsuite, many tests cannot cope
-------------------------------------------------------------------
Mon Dec 9 14:49:46 UTC 2024 - Michael Matz <matz@suse.com>
- Update to current 2.43.1 branch [PED-10254, PED-10306]:
* s390 - Add arch15 instructions
* various fixes from upstream: PR32153, PR32171, PR32189,
PR32196, PR32191, PR32109, PR32372, PR32387
- Adjusted binutils-2.43-branch.diff.gz.
- Disable zstd-by-default again (needs adjustments in at least
golang,llvm15,llvm17 first)
- Add binutils-fix-branch.diff.
- Check non-changing of flex/bison inputs only after applying
branch and fix-branch diffs.
-------------------------------------------------------------------
Wed Nov 20 14:59:28 UTC 2024 - Jiri Slaby <jslaby@suse.cz>
- drop ld-relro.diff (relro is the default for some time)
and it warns on avr spuriously (bsc#1233520)
-------------------------------------------------------------------
Mon Nov 18 18:12:05 UTC 2024 - John Paul Adrian Glaubitz <adrian.glaubitz@suse.com>
- Add loongarch64 as new target
-------------------------------------------------------------------
Tue Sep 10 05:25:27 UTC 2024 - Martin Liška <martin.liska@hey.com>
- Enable zstd compression algorithm (instead of zlib)
for debug info sections by default.
------------------------------------------------------------------- -------------------------------------------------------------------
Wed Aug 28 13:18:28 UTC 2024 - Michael Matz <matz@suse.com> Wed Aug 28 13:18:28 UTC 2024 - Michael Matz <matz@suse.com>

View File

@ -1,7 +1,7 @@
# #
# spec file for package binutils # spec file for package binutils
# #
# Copyright (c) 2024 SUSE LLC # Copyright (c) 2025 SUSE LLC
# #
# All modifications and additions to the file contributed by third parties # All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed # remain the property of their copyright owners, unless otherwise agreed
@ -99,12 +99,12 @@ Release: 0
%define make_check_handling false %define make_check_handling false
%endif %endif
# handle all binary object formats supported by SUSE (and a few more) # handle all binary object formats supported by SUSE (and a few more)
%ifarch %ix86 %arm aarch64 ia64 ppc ppc64 ppc64le riscv64 s390 s390x x86_64 %x86_64 %ifarch %ix86 %arm aarch64 ia64 ppc ppc64 ppc64le riscv64 s390 s390x x86_64 %x86_64 loongarch64
%define build_multitarget 1 %define build_multitarget 1
%else %else
%define build_multitarget 0 %define build_multitarget 0
%endif %endif
%define target_list aarch64 alpha armv5l armv6l armv7l armv8l avr pru epiphany hppa hppa64 i686 ia64 m68k mips powerpc powerpc64 powerpc64le riscv64 rx s390 s390x sh4 sparc sparc64 x86_64 xtensa %define target_list aarch64 alpha armv5l armv6l armv7l armv8l avr pru epiphany hppa hppa64 i686 ia64 loongarch64 m68k mips powerpc powerpc64 powerpc64le riscv64 rx s390 s390x sh4 sparc sparc64 x86_64 xtensa
%define build_gprofng 0 %define build_gprofng 0
@ -132,11 +132,11 @@ Source2: binutils-%{version}.tar.bz2.sig
Source3: binutils.keyring Source3: binutils.keyring
Source4: baselibs.conf Source4: baselibs.conf
Patch1: binutils-2.43-branch.diff.gz Patch1: binutils-2.43-branch.diff.gz
Patch2: binutils-fix-branch.diff
Patch3: binutils-skip-rpaths.patch Patch3: binutils-skip-rpaths.patch
Patch4: s390-biarch.diff Patch4: s390-biarch.diff
Patch5: x86-64-biarch.patch Patch5: x86-64-biarch.patch
Patch6: unit-at-a-time.patch Patch6: unit-at-a-time.patch
Patch8: ld-relro.diff
Patch9: testsuite.diff Patch9: testsuite.diff
Patch10: enable-targets-gold.diff Patch10: enable-targets-gold.diff
Patch12: s390-pic-dso.diff Patch12: s390-pic-dso.diff
@ -245,19 +245,23 @@ The next generation profiling tool for Linux
echo "make check will return with %{make_check_handling} in case of testsuite failures." echo "make check will return with %{make_check_handling} in case of testsuite failures."
%setup -q -n binutils-%{version} %setup -q -n binutils-%{version}
# Backup flex and biscon files for later verification.
cp ld/ldlex.l ld/ldlex.l.orig
cp ld/ldgram.y ld/ldgram.y.orig
# Patch is outside test_vanilla because it's supposed to be the # Patch is outside test_vanilla because it's supposed to be the
# patch bringing the tarball to the newest upstream version # patch bringing the tarball to the newest upstream version
%patch -P 1 -p1 %patch -P 1 -p1
%patch -P 2 -p1
# Backup flex and biscon files for later verification. Do this
# after branch and fix-branch patches are applied (which are assumed
# to manual fixup generated files, in case the branch diff touches
# the flex/bison source files)
cp ld/ldlex.l ld/ldlex.l.orig
cp ld/ldgram.y ld/ldgram.y.orig
%if !%{test_vanilla} %if !%{test_vanilla}
%patch -P 3 -p1 %patch -P 3 -p1
%patch -P 4 %patch -P 4
%patch -P 5 %patch -P 5
%patch -P 6 %patch -P 6
%patch -P 8
%patch -P 9 %patch -P 9
%patch -P 10 %patch -P 10
%patch -P 12 %patch -P 12
@ -388,8 +392,9 @@ cd build-dir
--enable-warn-execstack=yes \ --enable-warn-execstack=yes \
--enable-warn-rwx-segments=yes --enable-warn-rwx-segments=yes
#FIXME: enable in the future # FIXME: enable in future, when at least llvm15,llvm17,golang are
#%if %{suse_version} > 1550 # fixed to accept zstd
#%if %{suse_version} > 1600
# --enable-default-compressed-debug-sections-algorithm=zstd \ # --enable-default-compressed-debug-sections-algorithm=zstd \
#%endif #%endif
@ -489,7 +494,7 @@ make -C gas-nesc %{?make_output_sync} %{?_smp_mflags}
%endif %endif
%check %check
unset SUSE_ASNEEDED unset SUSE_ASNEEDED SUSE_ZNOW
# newer distros set this envvar (e.g. to get deterministic archives by default) # newer distros set this envvar (e.g. to get deterministic archives by default)
# but of course that breaks tests that precisely are # but of course that breaks tests that precisely are
# designed for checking file replacement in archives based on mtime. # designed for checking file replacement in archives based on mtime.

View File

@ -1,63 +0,0 @@
Index: ld/lexsup.c
===================================================================
--- ld/lexsup.c.orig 2024-08-04 01:00:00.000000000 +0200
+++ ld/lexsup.c 2024-08-06 16:02:35.554864901 +0200
@@ -772,6 +772,9 @@ parse_args (unsigned argc, char **argv)
}
}
+ optarg = "relro";
+ ldemul_handle_option ('z');
+
last_optind = -1;
while (1)
{
Index: ld/testsuite/config/default.exp
===================================================================
--- ld/testsuite/config/default.exp.orig 2024-08-04 01:00:00.000000000 +0200
+++ ld/testsuite/config/default.exp 2024-08-06 16:05:13.860859897 +0200
@@ -39,7 +39,7 @@ if [info exists env(LD_UNDER_TEST)] {
}
if ![info exists ld] then {
- set ld [findfile $base_dir/ld-new $base_dir/ld-new [transform ld]]
+ set ld "[findfile $base_dir/ld-new $base_dir/ld-new [transform ld]] -znorelro"
}
if ![info exists as] then {
@@ -92,7 +92,7 @@ if {[info exists ld_testsuite_bindir]} {
}
catch "exec ln -s ld tmpdir/ld/collect-ld" status
catch "exec ln -s ../../../gas/as-new tmpdir/ld/as" status
- set gcc_B_opt "-B[pwd]/tmpdir/ld/"
+ set gcc_B_opt "-B[pwd]/tmpdir/ld/ -Wl,-z,norelro"
}
# load the linker path
@@ -343,7 +343,7 @@ if ![info exists ELFEDIT] then {
}
if ![info exists LD] then {
- set LD [findfile $base_dir/ld-new ./ld-new [transform ld]]
+ set LD "[findfile $base_dir/ld-new ./ld-new [transform ld]] -znorelro"
}
if ![info exists LDFLAGS] then {
Index: ld/testsuite/ld-bootstrap/bootstrap.exp
===================================================================
--- ld/testsuite/ld-bootstrap/bootstrap.exp.orig 2024-08-04 01:00:00.000000000 +0200
+++ ld/testsuite/ld-bootstrap/bootstrap.exp 2024-08-06 16:02:35.554864901 +0200
@@ -112,7 +112,12 @@ foreach flags $test_flags {
# This test can only be run if we have the ld build directory,
# since we need the object files.
- if {[file normalize $ld] != [file normalize $objdir/ld-new]} {
+ set ldexe $ld
+ set ldparm [string first " " $ld]
+ if { $ldparm > 0 } then {
+ set ldexe [string range $ld 0 $ldparm]
+ }
+ if {[file normalize $ldexe] != [file normalize $objdir/ld-new]} {
untested $testname
continue
}