From ee20250f8b3f5f275cc1f3cebed09ef9c1abad02 Mon Sep 17 00:00:00 2001 From: eabdullin Date: Wed, 27 Mar 2024 19:43:05 +0000 Subject: [PATCH] import CS gcc-toolset-13-binutils-2.40-21.el8 --- SOURCES/binutils-AMD-znver5.patch | 176 ++++++++++++++++++++++++++++++ SPECS/binutils.spec | 105 ++++++++++++++---- 2 files changed, 257 insertions(+), 24 deletions(-) create mode 100644 SOURCES/binutils-AMD-znver5.patch diff --git a/SOURCES/binutils-AMD-znver5.patch b/SOURCES/binutils-AMD-znver5.patch new file mode 100644 index 0000000..c29f35f --- /dev/null +++ b/SOURCES/binutils-AMD-znver5.patch @@ -0,0 +1,176 @@ +diff -rupN binutils.orig/gas/config/tc-i386.c binutils-2.40/gas/config/tc-i386.c +--- binutils.orig/gas/config/tc-i386.c 2024-02-13 16:41:10.787729089 +0000 ++++ binutils-2.40/gas/config/tc-i386.c 2024-02-13 16:52:35.402669140 +0000 +@@ -998,6 +998,7 @@ static const arch_entry cpu_arch[] = + ARCH (znver2, ZNVER, ZNVER2, false), + ARCH (znver3, ZNVER, ZNVER3, false), + ARCH (znver4, ZNVER, ZNVER4, false), ++ ARCH (znver5, ZNVER, ZNVER5, false), + ARCH (btver1, BT, BTVER1, false), + ARCH (btver2, BT, BTVER2, false), + +diff -rupN binutils.orig/gas/doc/c-i386.texi binutils-2.40/gas/doc/c-i386.texi +--- binutils.orig/gas/doc/c-i386.texi 2024-02-13 16:41:10.789729089 +0000 ++++ binutils-2.40/gas/doc/c-i386.texi 2024-02-13 16:52:35.572669132 +0000 +@@ -125,6 +125,7 @@ processor names are recognized: + @code{znver2}, + @code{znver3}, + @code{znver4}, ++@code{znver5}, + @code{btver1}, + @code{btver2}, + @code{generic32} and +@@ -1477,7 +1478,8 @@ supported on the CPU specified. The cho + @item @samp{k6} @tab @samp{k6_2} @tab @samp{athlon} @tab @samp{k8} + @item @samp{amdfam10} @tab @samp{bdver1} @tab @samp{bdver2} @tab @samp{bdver3} + @item @samp{bdver4} @tab @samp{znver1} @tab @samp{znver2} @tab @samp{znver3} +-@item @samp{znver4} @tab @samp{btver1} @tab @samp{btver2} @tab @samp{generic32} ++@item @samp{znver4} @tab @samp{znver5} @tab @samp{btver1} @tab @samp{btver2} ++@item @samp{generic32} + @item @samp{generic64} @tab @samp{.cmov} @tab @samp{.fxsr} @tab @samp{.mmx} + @item @samp{.sse} @tab @samp{.sse2} @tab @samp{.sse3} @tab @samp{.sse4a} + @item @samp{.ssse3} @tab @samp{.sse4.1} @tab @samp{.sse4.2} @tab @samp{.sse4} +diff -rupN binutils.orig/gas/testsuite/gas/i386/arch-15-znver5.d binutils-2.40/gas/testsuite/gas/i386/arch-15-znver5.d +--- binutils.orig/gas/testsuite/gas/i386/arch-15-znver5.d 1970-01-01 01:00:00.000000000 +0100 ++++ binutils-2.40/gas/testsuite/gas/i386/arch-15-znver5.d 2024-02-13 16:52:35.405669140 +0000 +@@ -0,0 +1,5 @@ ++#source: arch-15.s ++#as: -march=znver5 ++#objdump: -dw ++#name: i386 arch 15 (znver5) ++#dump: arch-15.d +diff -rupN binutils.orig/gas/testsuite/gas/i386/arch-15.d binutils-2.40/gas/testsuite/gas/i386/arch-15.d +--- binutils.orig/gas/testsuite/gas/i386/arch-15.d 1970-01-01 01:00:00.000000000 +0100 ++++ binutils-2.40/gas/testsuite/gas/i386/arch-15.d 2024-02-13 16:52:35.405669140 +0000 +@@ -0,0 +1,13 @@ ++#objdump: -dw ++#name: i386 arch 15 ++ ++.*: file format .* ++ ++Disassembly of section .text: ++ ++0+ <.text>: ++[ ]*[a-f0-9]+:[ ]*c4 e2 59 50 d2[ ]*\{vex\} vpdpbusd %xmm2,%xmm4,%xmm2 ++[ ]*[a-f0-9]+:[ ]*0f 38 f9 01[ ]*movdiri %eax,\(%ecx\) ++[ ]*[a-f0-9]+:[ ]*66 0f 38 f8 01[ ]*movdir64b \(%ecx\),%eax ++[ ]*[a-f0-9]+:[ ]*62 f2 6f 48 68 d9[ ]*vp2intersectd %zmm1,%zmm2,%k3 ++#pass +diff -rupN binutils.orig/gas/testsuite/gas/i386/arch-15.s binutils-2.40/gas/testsuite/gas/i386/arch-15.s +--- binutils.orig/gas/testsuite/gas/i386/arch-15.s 1970-01-01 01:00:00.000000000 +0100 ++++ binutils-2.40/gas/testsuite/gas/i386/arch-15.s 2024-02-13 16:52:35.405669140 +0000 +@@ -0,0 +1,7 @@ ++# Test -march= ++ .text ++ ++ {vex} vpdpbusd %xmm2, %xmm4, %xmm2 #AVX_VNNI ++ movdiri %eax, (%ecx) #MOVDIRI ++ movdir64b (%ecx), %eax #MOVDIR64B ++ vp2intersectd %zmm1, %zmm2, %k3 #AVX512_VP2INTERSECT +diff -rupN binutils.orig/gas/testsuite/gas/i386/i386.exp binutils-2.40/gas/testsuite/gas/i386/i386.exp +--- binutils.orig/gas/testsuite/gas/i386/i386.exp 2024-02-13 16:41:10.859729082 +0000 ++++ binutils-2.40/gas/testsuite/gas/i386/i386.exp 2024-02-13 16:52:35.405669140 +0000 +@@ -199,6 +199,7 @@ if [gas_32_check] then { + run_dump_test "arch-13-znver2" + run_dump_test "arch-14-znver3" + run_dump_test "arch-14-znver4" ++ run_dump_test "arch-15-znver5" + run_dump_test "arch-10-btver1" + run_dump_test "arch-10-btver2" + run_list_test "arch-10-1" "-march=generic32 -I${srcdir}/$subdir -al" +@@ -211,6 +212,7 @@ if [gas_32_check] then { + run_dump_test "arch-13" + run_dump_test "arch-14" + run_dump_test "arch-14-1" ++ run_dump_test "arch-15" + run_list_test "arch-dflt" "-march=generic32 -al" + run_list_test "arch-stk" "-march=generic32 -al" + run_dump_test "8087" +diff -rupN binutils.orig/gas/testsuite/gas/i386/x86-64-arch-5-znver5.d binutils-2.40/gas/testsuite/gas/i386/x86-64-arch-5-znver5.d +--- binutils.orig/gas/testsuite/gas/i386/x86-64-arch-5-znver5.d 1970-01-01 01:00:00.000000000 +0100 ++++ binutils-2.40/gas/testsuite/gas/i386/x86-64-arch-5-znver5.d 2024-02-13 16:52:35.406669140 +0000 +@@ -0,0 +1,5 @@ ++#source: x86-64-arch-5.s ++#as: -march=znver5 ++#objdump: -dw ++#name: x86-64 arch 5 (znver5) ++#dump: x86-64-arch-5.d +diff -rupN binutils.orig/gas/testsuite/gas/i386/x86-64-arch-5.d binutils-2.40/gas/testsuite/gas/i386/x86-64-arch-5.d +--- binutils.orig/gas/testsuite/gas/i386/x86-64-arch-5.d 1970-01-01 01:00:00.000000000 +0100 ++++ binutils-2.40/gas/testsuite/gas/i386/x86-64-arch-5.d 2024-02-13 16:52:35.406669140 +0000 +@@ -0,0 +1,14 @@ ++#objdump: -dw ++#name: x86-64 arch 5 ++ ++.*: file format .* ++ ++Disassembly of section .text: ++ ++0+ <.text>: ++[ ]*[a-f0-9]+:[ ]*c4 c2 59 50 d4[ ]*\{vex\} vpdpbusd %xmm12,%xmm4,%xmm2 ++[ ]*[a-f0-9]+:[ ]*48 0f 38 f9 01[ ]*movdiri %rax,\(%rcx\) ++[ ]*[a-f0-9]+:[ ]*66 0f 38 f8 01[ ]*movdir64b \(%rcx\),%rax ++[ ]*[a-f0-9]+:[ ]*62 f2 6f 48 68 d9[ ]*vp2intersectd %zmm1,%zmm2,%k3 ++[ ]*[a-f0-9]+:[ ]*0f 18 3d 78 56 34 12[ ]*prefetchit0 0x12345678\(%rip\) # 0x[0-9a-f]+ ++#pass +diff -rupN binutils.orig/gas/testsuite/gas/i386/x86-64-arch-5.s binutils-2.40/gas/testsuite/gas/i386/x86-64-arch-5.s +--- binutils.orig/gas/testsuite/gas/i386/x86-64-arch-5.s 1970-01-01 01:00:00.000000000 +0100 ++++ binutils-2.40/gas/testsuite/gas/i386/x86-64-arch-5.s 2024-02-13 16:52:35.406669140 +0000 +@@ -0,0 +1,8 @@ ++# Test -march= ++ .text ++ ++ {vex} vpdpbusd %xmm12, %xmm4, %xmm2 #AVX_VNNI ++ movdiri %rax, (%rcx) #MOVDIRI ++ movdir64b (%rcx), %rax #MOVDIR64B ++ vp2intersectd %zmm1, %zmm2, %k3 #AVX512_VP2INTERSECT ++ prefetchit0 0x12345678(%rip) #prefetchi +diff -rupN binutils.orig/opcodes/i386-gen.c binutils-2.40/opcodes/i386-gen.c +--- binutils.orig/opcodes/i386-gen.c 2024-02-13 16:41:11.145729056 +0000 ++++ binutils-2.40/opcodes/i386-gen.c 2024-02-13 16:52:35.406669140 +0000 +@@ -97,6 +97,8 @@ static const dependency isa_dependencies + "ZNVER2|INVLPGB|TLBSYNC|VAES|VPCLMULQDQ|INVPCID|SNP|OSPKE" }, + { "ZNVER4", + "ZNVER3|AVX512F|AVX512DQ|AVX512IFMA|AVX512CD|AVX512BW|AVX512VL|AVX512_BF16|AVX512VBMI|AVX512_VBMI2|AVX512_VNNI|AVX512_BITALG|AVX512_VPOPCNTDQ|GFNI|RMPQUERY" }, ++ { "ZNVER5", ++ "ZNVER4|AVX_VNNI|MOVDIRI|MOVDIR64B|AVX512_VP2INTERSECT|PREFETCHI" }, + { "BTVER1", + "GENERIC64|FISTTP|CX16|Rdtscp|SSSE3|SSE4A|ABM|PRFCHW|CX16|Clflush|FISTTP|SVME" }, + { "BTVER2", +diff -rupN binutils.orig/opcodes/i386-init.h binutils-2.40/opcodes/i386-init.h +--- binutils.orig/opcodes/i386-init.h 2024-02-13 16:41:11.145729056 +0000 ++++ binutils-2.40/opcodes/i386-init.h 2024-02-13 17:32:50.339735343 +0000 +@@ -1431,6 +1431,15 @@ + 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, \ + 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0 } } + ++#define CPU_ZNVER5_FLAGS \ ++ { { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, \ ++ 0, 1, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, \ ++ 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, 1, 1, 0, 1, 1, 1, 1, 1, \ ++ 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 0, \ ++ 0, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, \ ++ 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, \ ++ 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0 } } ++ + #define CPU_BTVER1_FLAGS \ + { { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, \ + 0, 1, 0, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, \ +--- binutils.orig/gas/testsuite/gas/i386/i386.exp 2024-02-22 12:25:43.212505914 +0000 ++++ binutils-2.40/gas/testsuite/gas/i386/i386.exp 2024-02-22 12:28:26.254563823 +0000 +@@ -922,6 +922,7 @@ if [gas_64_check] then { + run_dump_test "x86-64-arch-4" + run_dump_test "x86-64-arch-4-1" + run_dump_test "rmpquery" ++ run_dump_test "x86-64-arch-5" + run_dump_test "x86-64-arch-2-lzcnt" + run_dump_test "x86-64-arch-2-prefetchw" + run_dump_test "x86-64-arch-2-bdver1" +@@ -932,6 +933,7 @@ if [gas_64_check] then { + run_dump_test "x86-64-arch-3-znver2" + run_dump_test "x86-64-arch-4-znver3" + run_dump_test "x86-64-arch-4-znver4" ++ run_dump_test "x86-64-arch-5-znver5" + run_dump_test "x86-64-arch-2-btver1" + run_dump_test "x86-64-arch-2-btver2" + run_list_test "x86-64-arch-2-1" "-march=generic64 -I${srcdir}/$subdir -al" diff --git a/SPECS/binutils.spec b/SPECS/binutils.spec index 01cceba..ab70b42 100644 --- a/SPECS/binutils.spec +++ b/SPECS/binutils.spec @@ -9,7 +9,7 @@ BuildRequires: scl-utils-build Summary: A GNU collection of binary utilities Name: %{?scl_prefix}binutils Version: 2.40 -Release: 14%{?dist} +Release: 21%{?dist} License: GPLv3+ URL: https://sourceware.org/binutils @@ -26,7 +26,7 @@ URL: https://sourceware.org/binutils # --without docs Skip building documentation. Default is with docs, except when building a cross binutils. # --without gold Disable building of the GOLD linker. # --without gprofng Do not build the GprofNG profiler. -# --without systemzlib Use the binutils version of zlib. +# --with systemzlib Use the binutils version of zlib. # --without testsuite Do not run the testsuite. Default is to run it. # Other configuration options can be set by modifying the following defines. @@ -95,9 +95,9 @@ URL: https://sourceware.org/binutils %bcond_without debuginfod # Default: build binutils-gprofng package. %bcond_without gprofng -# Use the system supplied version of the zlib compress library. +# Default: Do not use the system supplied version of the zlib compression library. # Change this to use the binutils builtin version instead. -%bcond_without systemzlib +%bcond_with systemzlib # Allow the user to override the compiler used to build the binutils. # The default build compiler is gcc if %%toolchain is not clang. @@ -277,6 +277,10 @@ Patch20: binutils-reloc-symtab.patch # Lifetime: Fixed in 2.41 Patch21: binutils-CVE-2023-1972.patch +# Purpose: Add support for AMD's znver5 architecture extension. +# Lifetime: Fixed in 2.42 +Patch22: binutils-AMD-znver5.patch + #---------------------------------------------------------------------------- Provides: bundled(libiberty) @@ -349,7 +353,7 @@ Requires(post): %{alternatives_cmd} Requires(preun): %{alternatives_cmd} # We also need rm. -Requires(post): coreutils +Requires(post): coreutils policycoreutils %if %{with gold} # For now we make the binutils package require the gold sub-package. @@ -958,29 +962,35 @@ install_binutils() %endif # Rebuild the static libiaries with -fPIC. - # It would be nice to build the static libraries with -fno-lto so that - # they can be used by programs that are built with a different version - # of GCC from the one used to build the libraries, but this will trigger - # warnings from annocheck. + # + # Also disable LTO. This is because older versions of GCC can crash if + # asked to parse the LTO information generated by newer versions. + # cf: https://issues.redhat.com/browse/RHEL-18800 + # + # Note - disabling LTO does mean that the binutils will be flagged by + # annocheck as being non-compliant. There is not a lot that can be + # done about this. :-( + local static_cflags="-g $RPM_OPT_FLAGS -fPIC -fno-lto" + # Future: Remove libiberty together with its header file, projects should bundle it. %make_build -s -C libiberty clean %set_build_flags - %make_build -s CFLAGS="-g -fPIC $RPM_OPT_FLAGS" -C libiberty + %make_build -s -C libiberty CFLAGS="$static_cflags" # Without the hidden visibility the 3rd party shared libraries would export # the bfd non-stable ABI. %make_build -s -C bfd clean %set_build_flags - %make_build -s CFLAGS="-g -fPIC $RPM_OPT_FLAGS -fvisibility=hidden" LD=%gcc_for_libraries -C bfd + %make_build -s -C bfd CFLAGS="$static_cflags -fvisibility=hidden" LD=%gcc_for_libraries %make_build -s -C opcodes clean %set_build_flags - %make_build -s CFLAGS="-g -fPIC $RPM_OPT_FLAGS" -C opcodes + %make_build -s -C opcodes CFLAGS="$static_cflags" %make_build -s -C libsframe clean %set_build_flags - %make_build -s CFLAGS="-g -fPIC $RPM_OPT_FLAGS" -C libsframe + %make_build -s -C libsframe CFLAGS="$static_cflags" install -m 644 bfd/libbfd.a $local_libdir install -m 644 libiberty/libiberty.a $local_libdir @@ -1105,15 +1115,6 @@ export QA_RPATHS=0x0003 #---------------------------------------------------------------------------- -%if %{with gold} -%post gold - -%{alternatives_cmdline} --install %{_bindir}/ld ld \ - %{_bindir}/ld.gold %{ld_gold_priority} - -exit 0 -%endif - %post %__rm -f %{_bindir}/ld @@ -1125,8 +1126,43 @@ exit 0 %ldconfig_post +# BZ 2232410: We cannot be sure that the GTS runtime rpm has restored the SE context. +restorecon -R %{_scl_root}/usr/share/locale + +# RHEL-22817: Restore the SELinux context of the bfd-plugins. +restorecon -R %{_libdir} + exit 0 +#------------------ + +%post devel +# RHEL-22818: Restore the SELinux context of the libraries. +restorecon -R %{_libdir} +exit 0 + +#------------------ + +%if %{with gprofng} +%post gprofng +# RHEL-22817: Restire the SELinux context of the gprofng libraries. +restorecon -R %{_libdir} +# And the rc file. +restorecon /opt/rh/gcc-toolset-13/root/usr/etc/gprofng.rc +exit 0 +%endif + +#------------------ + +%if %{with gold} +%post gold + +%{alternatives_cmdline} --install %{_bindir}/ld ld \ + %{_bindir}/ld.gold %{ld_gold_priority} + +exit 0 +%endif + #---------------------------------------------------------------------------- # Note: $1 == 0 means that there is an uninstall in progress. @@ -1181,9 +1217,10 @@ exit 0 %license COPYING COPYING3 COPYING3.LIB COPYING.LIB %doc README %{_bindir}/[!l]* -# %%verify(symlink) does not work for some reason, so using "owner" instead. +# %%verify(symlink) is not support in RHEL, so check owner instead. %verify(owner) %{_bindir}/ld -%{_bindir}/ld.bfd +# The mtime check fails for ld.bfd because of the laternatives mechanism, so ignore it. +%verify(owner) %{_bindir}/ld.bfd %if %{with gprofng} %exclude %{_bindir}/gp-* @@ -1276,6 +1313,26 @@ exit 0 #---------------------------------------------------------------------------- %changelog +* Thu Feb 22 2024 Nick Clifton - 2.40-21 +- Run x86_64 assembler tests for znver5 architecture extension. (RHEL-25405) + +* Tue Feb 13 2024 Nick Clifton - 2.40-20 +- Add support for AMD's znver5 architecture extension. (RHEL-25405) + +* Fri Feb 09 2024 Nick Clifton - 2.40-19 +- Spec File: Restore the SElinux context to %%{_libdir}. (RHEL-22817) +- [2.40-18: was a failed attempt to fix RHEL-22817] + +* Thu Jan 11 2024 Nick Clifton - 2.40-17 +- Spec File: Do not use of the system zlib by default. (RHEL-19373) +- Spec File: Do not check the mtime of ld.bfd. (RHEL-21303) + +* Tue Dec 12 2023 Nick Clifton - 2.40-16 +- Disable building static libraries with LTO. (RHEL-18800) + +* Mon Sep 11 2023 Nick Clifton - 2.40-15 +- Restore the SE context during the post install phase. (#2232410) + * Thu Aug 03 2023 Nick Clifton - 2.40-14 - Add expected linker test failure for s390x. (#2228870)