From e3ed4782eef2fd1892fa7a661bff1f12668406c35eb83f924d99dcb44baed806 Mon Sep 17 00:00:00 2001 From: Michael Matz Date: Fri, 26 Nov 2021 15:07:14 +0000 Subject: [PATCH] - Remove cross compilers for i386 target OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc11?expand=0&rev=374 --- change_spec | 1 - cross-aarch64-gcc11-bootstrap.changes | 1 + cross-aarch64-gcc11.changes | 1 + cross-amdgcn-gcc11.changes | 1 + cross-arm-gcc11.changes | 1 + cross-arm-none-gcc11-bootstrap.changes | 1 + cross-arm-none-gcc11.changes | 1 + cross-avr-gcc11-bootstrap.changes | 1 + cross-avr-gcc11.changes | 1 + cross-epiphany-gcc11-bootstrap.changes | 1 + cross-epiphany-gcc11.changes | 1 + cross-hppa-gcc11.changes | 1 + cross-i386-gcc11.changes | 215 ----- cross-i386-gcc11.spec | 994 ---------------------- cross-m68k-gcc11.changes | 1 + cross-mips-gcc11.changes | 1 + cross-nvptx-gcc11.changes | 1 + cross-ppc64-gcc11.changes | 1 + cross-ppc64le-gcc11.changes | 1 + cross-riscv64-elf-gcc11-bootstrap.changes | 1 + cross-riscv64-elf-gcc11.changes | 1 + cross-riscv64-gcc11-bootstrap.changes | 1 + cross-riscv64-gcc11.changes | 1 + cross-rx-gcc11-bootstrap.changes | 1 + cross-rx-gcc11.changes | 1 + cross-s390x-gcc11.changes | 1 + cross-sparc-gcc11.changes | 1 + cross-sparc64-gcc11.changes | 1 + cross-x86_64-gcc11.changes | 1 + gcc11-testresults.changes | 1 + gcc11.changes | 1 + 31 files changed, 28 insertions(+), 1210 deletions(-) delete mode 100644 cross-i386-gcc11.changes delete mode 100644 cross-i386-gcc11.spec diff --git a/change_spec b/change_spec index cf6dbd9..9f61f15 100644 --- a/change_spec +++ b/change_spec @@ -103,7 +103,6 @@ add_glibc_cross cross-riscv64-gcc$base_ver riscv64 riscv64-suse-linux add_cross cross-arm-gcc$base_ver arm arm-suse-linux-gnueabi %define gcc_icecream 1 add_cross cross-avr-gcc$base_ver-bootstrap avr avr "%define gcc_libc_bootstrap 1" add_cross cross-avr-gcc$base_ver avr avr -add_cross cross-i386-gcc$base_ver i386 i586-suse-linux %define gcc_icecream 1 add_cross cross-x86_64-gcc$base_ver x86_64 x86_64-suse-linux %define gcc_icecream 1 add_cross cross-s390x-gcc$base_ver s390x s390x-suse-linux %define gcc_icecream 1 add_cross cross-sparc-gcc$base_ver sparcv9 sparc-suse-linux %define gcc_icecream 1 diff --git a/cross-aarch64-gcc11-bootstrap.changes b/cross-aarch64-gcc11-bootstrap.changes index ddcb0b3..998b6e5 100644 --- a/cross-aarch64-gcc11-bootstrap.changes +++ b/cross-aarch64-gcc11-bootstrap.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-aarch64-gcc11.changes b/cross-aarch64-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-aarch64-gcc11.changes +++ b/cross-aarch64-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-amdgcn-gcc11.changes b/cross-amdgcn-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-amdgcn-gcc11.changes +++ b/cross-amdgcn-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-arm-gcc11.changes b/cross-arm-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-arm-gcc11.changes +++ b/cross-arm-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-arm-none-gcc11-bootstrap.changes b/cross-arm-none-gcc11-bootstrap.changes index ddcb0b3..998b6e5 100644 --- a/cross-arm-none-gcc11-bootstrap.changes +++ b/cross-arm-none-gcc11-bootstrap.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-arm-none-gcc11.changes b/cross-arm-none-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-arm-none-gcc11.changes +++ b/cross-arm-none-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-avr-gcc11-bootstrap.changes b/cross-avr-gcc11-bootstrap.changes index ddcb0b3..998b6e5 100644 --- a/cross-avr-gcc11-bootstrap.changes +++ b/cross-avr-gcc11-bootstrap.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-avr-gcc11.changes b/cross-avr-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-avr-gcc11.changes +++ b/cross-avr-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-epiphany-gcc11-bootstrap.changes b/cross-epiphany-gcc11-bootstrap.changes index ddcb0b3..998b6e5 100644 --- a/cross-epiphany-gcc11-bootstrap.changes +++ b/cross-epiphany-gcc11-bootstrap.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-epiphany-gcc11.changes b/cross-epiphany-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-epiphany-gcc11.changes +++ b/cross-epiphany-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-hppa-gcc11.changes b/cross-hppa-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-hppa-gcc11.changes +++ b/cross-hppa-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-i386-gcc11.changes b/cross-i386-gcc11.changes deleted file mode 100644 index ddcb0b3..0000000 --- a/cross-i386-gcc11.changes +++ /dev/null @@ -1,215 +0,0 @@ -------------------------------------------------------------------- -Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - -- Enable the cross compilers also on i586 - -------------------------------------------------------------------- -Wed Nov 24 10:41:45 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (7510c23c1ec53aa4a62705f03), git1018 - * fixes issue with debug dumping together with -o /dev/null - * fixes libgccjit issue showing up in emacs build [boo#1192951] -- Package mwaitintrin.h - -------------------------------------------------------------------- -Wed Oct 20 13:59:09 UTC 2021 - Richard Biener - -- Remove spurious exit from change_spec. - -------------------------------------------------------------------- -Mon Sep 20 17:15:19 UTC 2021 - Michael Matz - -- Enable the full cross compiler, cross-aarch64-gcc11 and - cross-riscv64-gcc11 now provide a fully hosted C (and C++) - cross compiler, not just a freestanding one. I.e. with a cross - glibc. They don't yet support the sanitizer libraries. - Part of [jsc#OBS-124]. - -------------------------------------------------------------------- -Wed Aug 18 15:07:05 UTC 2021 - Andreas Schwab - -- Require libgccjit%{libgccjit_sover}%{libgccjit_suffix} from - libgccjit%{libgccjit_sover}-devel%{libdevel_suffix}. - -------------------------------------------------------------------- -Mon Aug 16 06:34:40 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (056e324ce46a7924b5cf10f610), git610 - * Includes GCC 11.2 release - * Includes fix for opie build with glibc 2.34 [boo#1188623] - -------------------------------------------------------------------- -Wed Jul 21 09:08:04 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (076930b9690ac3564638636f6b), git536 - * Includes GCC 11.2 RC1. -- Refresh gcc10-foffload-default.patch - -------------------------------------------------------------------- -Wed Jul 21 09:06:11 UTC 2021 - Richard Biener - -- Properly adjust GPL-3.0 WITH GCC-exception-3.1 to - GPL-3.0-or-later WITH GCC-exception-3.1 - -------------------------------------------------------------------- -Mon Jul 19 14:49:07 UTC 2021 - Andreas Schwab - -- Remove bits/unistd_ext.h from include-fixed - -------------------------------------------------------------------- -Fri Jul 9 07:34:24 UTC 2021 - Richard Biener - -- Add BuildRequires on netcfg for the testsuite when testing Go. - -------------------------------------------------------------------- -Tue Jul 6 15:51:37 UTC 2021 - Michael Matz - -- Provide a libc-bootstrap cross compiler for aarch64 and riscv64 -- More preparation for a full glibc cross compiler (not yet active) - -------------------------------------------------------------------- -Fri Jun 25 11:23:02 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (62bbb113ae68a7e724255e1714), git400 - * Fixes issue with legacy Fortran code. [gcc#101123, boo#1187273] - -------------------------------------------------------------------- -Thu Jun 17 06:28:18 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (79c1185de4a05fdea13b6b0207), git340 - * Fixes ceph build failure. [gcc#101078] - -------------------------------------------------------------------- -Tue Jun 15 09:16:11 UTC 2021 - Richard Biener - -- Change disable_32bit to only disable multilibs for arhcs subject - to 32bit/64bit handling and make it effective on x86_64. -- Remove the duplicate spec header from cross.spec.in - -------------------------------------------------------------------- -Thu Jun 10 10:03:37 UTC 2021 - Richard Biener - -- Add newlib-4.1.0-aligned_alloc.patch to fix nvptx cross build - fail. [bsc#1187153] - -------------------------------------------------------------------- -Wed Jun 9 08:50:44 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (c6d2487098f9dde4f9ac59e5be), git273 - -------------------------------------------------------------------- -Tue Jun 8 08:22:22 UTC 2021 - Dirk Müller - -- tune armv7 to generic-armv7-a -- enable build for arm-none cross builders in rings, - needed by arm-trusted-firmware - -------------------------------------------------------------------- -Tue May 25 19:21:01 UTC 2021 - Andreas Schwab - -- Fix value of %slibdir64 for usrmerge - -------------------------------------------------------------------- -Mon May 10 12:08:19 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (23855a176609fe8dda6abaf2b2), git121 -- Disable build-id generation on non-glibc targeting cross compilers. - -------------------------------------------------------------------- -Thu Apr 29 08:39:32 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (cd0a059bd384da58d43674496a7), git67 - * Includes GCC 11.1 release -- Drop upstreamed gcc11-no-offload.patch. - -------------------------------------------------------------------- -Wed Apr 21 12:31:23 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (7a7fc01b9d20afb1a2b805d93cb), git31 - * Includes GCC 11.1 RC2 -- Add gcc11-no-offload.patch and - gcc11-amdgcn-disable-hot-cold-partitioning.patch. -- Enable gfortran for offload compilers. -- BuildRequire procps from gcc11-testresults if we test go. -- Force using llvm11 for amdgcn offloading since llvm12 doesn't - yet work. Package expanded symlinks so concurrent installs do - not pull in another llvm-mc. -- Add gcc11-gdwarf-4-default.patch to default to DWARF4 generation - in SLES15 and older. - -------------------------------------------------------------------- -Tue Apr 20 14:57:07 UTC 2021 - Richard Biener - -- Update to gcc-11 branch head (27350b77a92062667427100afb4), git10 - * Includes GCC 11.1 RC1 - -------------------------------------------------------------------- -Fri Apr 16 19:54:03 UTC 2021 - Martin Liška - -- Bump to 49813aad3292f7f2bef69206274da78a9a7116ed. - -------------------------------------------------------------------- -Thu Apr 15 11:22:19 UTC 2021 - Richard Biener - -- Disable nvptx offloading on aarch64 since it doesn't work. - -------------------------------------------------------------------- -Wed Apr 14 19:51:08 UTC 2021 - Martin Liška - -- Bump to a87d3f964df31d4fbceb822c6d293e85c117d992. - -------------------------------------------------------------------- -Fri Apr 9 12:25:39 UTC 2021 - Richard Biener - -- Remove gcc48-remove-mpfr-2.4.0-requirement.patch which does no - longer apply. -- Arrange for a C++ 11 capable host compiler to be available. -- Do not require ISL for cross compiler builds on old distros. - -------------------------------------------------------------------- -Thu Apr 8 19:52:03 UTC 2021 - Martin Liška - -- Bump to 123b3e03c911a43054c1f88f5d3110e1d084dd4e. - -------------------------------------------------------------------- -Mon Mar 8 14:10:15 UTC 2021 - Richard Biener - -- Update embedded newlib version from 3.3.0 to 4.1.0. - -------------------------------------------------------------------- -Mon Feb 22 10:44:40 UTC 2021 - Martin Liška - -- Pack %{GCCDIST}-gcc%{binsuffix}. -- Add a new dependency for libgccjit. - -------------------------------------------------------------------- -Fri Feb 5 08:40:22 UTC 2021 - Martin Liška - -- New package, inherits from gcc10 - * gcc-add-defaultsspec.diff, add the ability to provide a specs - file that is read by default - * tls-no-direct.diff, avoid direct %fs references on x86 to not - slow down Xen - * gcc43-no-unwind-tables.diff, do not produce unwind tables for - CRT files - * gcc41-ppc32-retaddr.patch, fix expansion of __builtin_return_addr - for ppc, just a testcase - * gcc44-textdomain.patch, make translation files version specific - and adjust textdomain to find them - * gcc44-rename-info-files.patch, fix cross-references in info files - when renaming them to be version specific - * gcc48-libstdc++-api-reference.patch, fix link in the installed - libstdc++ html documentation - * gcc48-remove-mpfr-2.4.0-requirement.patch, make GCC work with - earlier mpfr versions on old products - * gcc5-no-return-gcc43-workaround.patch, make build work with - host gcc 4.3 - * gcc7-remove-Wexpansion-to-defined-from-Wextra.patch, removes - new warning from -Wextra - * gcc7-avoid-fixinc-error.diff - * gcc9-reproducible-builds-buildid-for-checksum.patch - * gcc9-reproducible-builds.patch - * gcc10-amdgcn-llvm-as.patch - * gcc10-foffload-default.patch -- libgccjit subpackage is added. -- HWASAN is built for aarch64 target. diff --git a/cross-i386-gcc11.spec b/cross-i386-gcc11.spec deleted file mode 100644 index fcb51eb..0000000 --- a/cross-i386-gcc11.spec +++ /dev/null @@ -1,994 +0,0 @@ -# -# spec file -# -# Copyright (c) 2021 SUSE LLC -# -# All modifications and additions to the file contributed by third parties -# remain the property of their copyright owners, unless otherwise agreed -# upon. The license for this file, and modifications and additions to the -# file, is the same license as for the pristine package itself (unless the -# license for the pristine package is not an Open Source License, in which -# case the license is the MIT License). An "Open Source License" is a -# license that conforms to the Open Source Definition (Version 1.9) -# published by the Open Source Initiative. - -# Please submit bugfixes or comments via https://bugs.opensuse.org/ -# - - -%define pkgname cross-i386-gcc11 -%define cross_arch i386 -%define gcc_target_arch i586-suse-linux -%define gcc_icecream 1 -# nospeccleaner - -# In the staging/ring projects, we don't want to build the unneeded -# cross-* packages, but by default, we do: -%bcond_with ringdisabled - -%if "%{cross_arch}" != "arm-none" && "%{cross_arch}" != "arm" && %{with ringdisabled} -ExclusiveArch: do-not-build -%endif - -%define build_cp 0%{!?gcc_accel:1} -%if 0%{?gcc_libc_bootstrap:1} -%define build_cp 0 -%endif -%define build_ada 0 -%define build_libjava 0 -%define build_java 0 - -%define build_fortran 0%{?gcc_accel:1} -%define build_objc 0 -%define build_objcp 0 -%define build_go 0 -%define build_nvptx 0 -%define build_gcn 0 -%define build_d 0 - -%define enable_plugins 0 -%define build_jit 0 -%define use_lto_bootstrap 0 - -%define binutils_target %{cross_arch} -%if "%{cross_arch}" == "armv7l" || "%{cross_arch}" == "armv7hl" -%define binutils_target arm -%endif -%if "%{cross_arch}" == "armv6l" || "%{cross_arch}" == "armv6hl" -%define binutils_target arm -%endif -%if "%{cross_arch}" == "armv5tel" -%define binutils_target arm -%endif -%if "%{cross_arch}" == "arm-none" -%define binutils_target arm -%endif -%if "%{cross_arch}" == "riscv64-elf" -%define binutils_target riscv64 -%endif -%if "%{cross_arch}" == "sparcv9" -%define binutils_target sparc -%endif -%define canonical_target %(echo %{binutils_target} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;") -%if "%{binutils_target}" == "avr" || "%{binutils_target}" == "spu" -%define binutils_os %{canonical_target} -%else -%if "%{binutils_target}" == "epiphany" || "%{binutils_target}" == "nds32le" || "%{binutils_target}" == "rl78" || "%{binutils_target}" == "rx" -%define binutils_os %{canonical_target}-elf -%else -%if "%{binutils_target}" == "arm" -%define binutils_os %{canonical_target}-suse-linux-gnueabi -%else -%if 0%{?gcc_accel:1} -%define binutils_os %{gcc_target_arch} -%else -%define binutils_os %{canonical_target}-suse-linux -%endif -%endif -%endif -%endif - -%if 0%{?gcc_icecream:1} -%define sysroot %{_prefix}/%{gcc_target_arch} -%else -# offloading builds newlib in-tree and can install in -# the GCC private path without extra sysroot -%if 0%{!?gcc_accel:1} -# use same sysroot as in binutils.spec -%define sysroot %{_prefix}/%{binutils_os}/sys-root -%endif -%endif - -%if %{suse_version} >= 1220 -%define selfconflict() %1 -%else -%define selfconflict() otherproviders(%1) -%endif - -Name: %{pkgname} -%define biarch_targets x86_64 s390x powerpc64 powerpc sparc sparc64 - -URL: https://gcc.gnu.org/ -Version: 11.2.1+git1018 -Release: 0 -%define gcc_dir_version %(echo %version | sed 's/+.*//' | cut -d '.' -f 1) -%define gcc_snapshot_revision %(echo %version | sed 's/[3-9]\.[0-9]\.[0-6]//' | sed 's/+/-/') -%define binsuffix -11 -%if %{suse_version} < 1310 -BuildRoot: %{_tmppath}/%{name}-%{version}-build -%endif -Group: Development/Languages/C and C++ -Source: gcc-%{version}.tar.xz -Source1: change_spec -Source2: gcc11-rpmlintrc -Source3: gcc11-testresults-rpmlintrc -Source4: README.First-for.SuSE.packagers -Source5: newlib-4.1.0.tar.xz -Patch2: gcc-add-defaultsspec.diff -Patch5: tls-no-direct.diff -Patch6: gcc43-no-unwind-tables.diff -Patch7: gcc48-libstdc++-api-reference.patch -Patch11: gcc7-remove-Wexpansion-to-defined-from-Wextra.patch -Patch15: gcc7-avoid-fixinc-error.diff -Patch16: gcc9-reproducible-builds.patch -Patch17: gcc9-reproducible-builds-buildid-for-checksum.patch -Patch18: gcc10-amdgcn-llvm-as.patch -Patch19: gcc11-gdwarf-4-default.patch -Patch20: gcc11-amdgcn-disable-hot-cold-partitioning.patch -# A set of patches from the RH srpm -Patch51: gcc41-ppc32-retaddr.patch -Patch52: gcc10-foffload-default.patch -# Some patches taken from Debian -Patch60: gcc44-textdomain.patch -Patch61: gcc44-rename-info-files.patch -# Patches for embedded newlib -Patch100: newlib-4.1.0-aligned_alloc.patch - -# Define the canonical target and host architecture -# %%gcc_target_arch is supposed to be the full target triple -# %%cross_arch is supposed to be the rpm target variant arch -# %%TARGET_ARCH will be the canonicalized target CPU part -# %%HOST_ARCH will be the canonicalized host CPU part -%if 0%{?gcc_target_arch:1} -%define TARGET_ARCH %(echo %{cross_arch} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;") -%else -%define TARGET_ARCH %(echo %{_target_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;") -%endif -%if 0%{?disable_32bit:1} -%define biarch 0 -%else -%define biarch %(case " %{biarch_targets} " in (*" %{TARGET_ARCH} "*) echo 1;; (*) echo 0;; esac) -%endif - -%define HOST_ARCH %(echo %{_host_cpu} | sed -e "s/i.86/i586/;s/ppc/powerpc/;s/sparc64.*/sparc64/;s/sparcv.*/sparc/;") -%ifarch ppc -%define GCCDIST powerpc64-suse-linux -%else -%ifarch %sparc -%define GCCDIST sparc64-suse-linux -%else -%ifarch %arm -%define GCCDIST %{HOST_ARCH}-suse-linux-gnueabi -%else -%define GCCDIST %{HOST_ARCH}-suse-linux -%endif -%endif -%endif - -%define libsubdir %{_libdir}/gcc/%{GCCDIST}/%{gcc_dir_version} -%define gxxinclude %{_prefix}/include/c++/%{gcc_dir_version} - -%if "%{cross_arch}" != "nvptx" -%if "%{cross_arch}" != "amdgcn" -BuildRequires: cross-%{binutils_target}-binutils -Requires: cross-%{binutils_target}-binutils -%endif -%endif -%define hostsuffix %{nil} -%if 0%{suse_version} < 1220 -%define hostsuffix -4.8 -BuildRequires: gcc48-c++ -%else -BuildRequires: gcc-c++ -%endif -%if %{suse_version} > 1500 -BuildRequires: libzstd-devel -%endif -BuildRequires: bison -BuildRequires: flex -BuildRequires: gettext-devel -BuildRequires: glibc-devel-32bit -BuildRequires: mpc-devel -BuildRequires: mpfr-devel -BuildRequires: perl -%if %{suse_version} > 1220 -BuildRequires: makeinfo -%else -BuildRequires: texinfo -%endif -BuildRequires: zlib-devel -%if %{suse_version} >= 1230 -BuildRequires: isl-devel -%endif -%ifarch ia64 -BuildRequires: libunwind-devel -%endif -%if 0%{!?gcc_icecream:1} -%if 0%{!?gcc_libc_bootstrap:1} -%if 0%{?gcc_target_newlib:1} -BuildRequires: cross-%cross_arch-newlib-devel -%endif -%if "%{cross_arch}" == "avr" -BuildRequires: avr-libc -%endif -%if 0%{?gcc_target_glibc:1} -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%endif -%endif -%if "%{cross_arch}" == "nvptx" -BuildRequires: nvptx-tools -Requires: cross-nvptx-newlib-devel >= %{version}-%{release} -Requires: nvptx-tools -ExclusiveArch: x86_64 -%define nvptx_newlib 1 -%endif -%if "%{cross_arch}" == "amdgcn" -# amdgcn uses the llvm assembler and linker, llvm-mc-12 doesn't -# work at the moment so require llvm11 -BuildRequires: llvm11 -BuildRequires: lld -Requires: cross-amdgcn-newlib-devel >= %{version}-%{release} -Requires: lld -Requires: llvm11 -# SLE12 does not fulfil build requirements for GCN, SLE15 SP1 does -# technically also SLE12 SP5 but do not bother there -%if %{suse_version} >= 1550 || 0%{?sle_version:%sle_version} >= 150100 -ExclusiveArch: x86_64 -%else -ExclusiveArch: do-not-build -%endif -%define amdgcn_newlib 1 -%endif -%endif -%if 0%{?gcc_icecream:1}%{?gcc_target_glibc:1}%{?gcc_libc_bootstrap:1} -ExclusiveArch: i586 ppc64le ppc64 x86_64 s390x aarch64 riscv64 -%endif -%define _binary_payload w.ufdio -# Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has -# file conflicts with it and is no longer packaged -%if "%pkgname" == "cross-ppc64-gcc49" -Obsoletes: cross-ppc-gcc49 <= 4.9.0+r209354 -%endif -%if 0%{?gcc_target_newlib:1} -# Generally only one cross for the same target triplet can be installed -# at the same time as we are populating a non-version-specific sysroot -Provides: %{gcc_target_arch}-gcc -Conflicts: %selfconflict %{gcc_target_arch}-gcc -%endif -%if 0%{?gcc_libc_bootstrap:1} -# The -bootstrap packages file-conflict with the non-bootstrap variants. -# Even if we don't actually (want to) distribute the bootstrap variants -# the following avoids repo-checker spamming us endlessly. -Conflicts: cross-%{cross_arch}-gcc11 -%endif -#!BuildIgnore: gcc-PIE -%if 0%{build_cp:1} -# The cross compiler only packages the arch specific c++ headers, so -# we need to depend on the host libstdc++ devel headers (we wouldn't need -# the libs, though) -Requires: libstdc++6-devel-gcc11 -%endif -AutoReqProv: off -BuildRequires: update-alternatives -Requires(post): update-alternatives -Requires(preun):update-alternatives -Summary: The GNU Compiler Collection targeting %{cross_arch} -License: GPL-3.0-or-later - -%description -The GNU Compiler Collection as a cross-compiler targeting %{cross_arch}. -%if 0%{?gcc_icecream:1} -Note this is only useful for building freestanding things like the -kernel since it fails to include target libraries and headers. -%endif -%if 0%{?gcc_libc_bootstrap:1} -This is a package that is necessary for bootstrapping another package -only, it is not intended for any other use. -%endif - -%prep -%if 0%{?nvptx_newlib:1}%{?amdgcn_newlib:1} -%setup -q -n gcc-%{version} -a 5 -ln -s newlib-4.1.0/newlib . -cd newlib -%patch100 -p1 -cd .. -%else -%setup -q -n gcc-%{version} -%endif - -#test patching start - -%patch2 -%patch5 -%patch6 -%patch7 -%patch11 -%patch15 -%patch16 -%patch17 -p1 -%if "%{TARGET_ARCH}" == "amdgcn" -%patch18 -p1 -%endif -# In SLE15 and earlier default to dwarf4, not dwarf5 -%if %{suse_version} < 1550 -%patch19 -p1 -%endif -%patch20 -p1 -%patch51 -%patch52 -p1 -%patch60 -p1 -%patch61 - -#test patching end - -%build -%define _lto_cflags %{nil} -# Avoid rebuilding of generated files -contrib/gcc_update --touch - -# SLE11 does not allow empty rpms -%if %{suse_version} < 1310 -echo "This is a dummy package to provide a dependency." > README -%endif - -rm -rf obj-%{GCCDIST} -mkdir obj-%{GCCDIST} -cd obj-%{GCCDIST} -RPM_OPT_FLAGS="$RPM_OPT_FLAGS -U_FORTIFY_SOURCE" -RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fno-rtti//g' -e 's/-fno-exceptions//g' -e 's/-Wmissing-format-attribute//g' -e 's/-fstack-protector[^ ]*//g' -e 's/-ffortify=.//g' -e 's/-Wall//g' -e 's/-m32//g' -e 's/-m64//g'` -%ifarch %ix86 -# -mcpu is superceded by -mtune but -mtune is not supported by -# our bootstrap compiler. -mcpu gives a warning that stops -# the build process, so remove it for now. Also remove all other -# -march and -mtune flags. They are superseeded by proper -# default compiler settings now. -RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-mcpu=i.86//g' -e 's/-march=i.86//g' -e 's/-mtune=i.86//g'` -%endif -%ifarch s390 s390x -RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-fsigned-char//g'` -RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-O1/-O2/g'` -%endif -%if 0%{?gcc_target_arch:1} -# Kill all -march/tune/cpu because that screws building the target libs -RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/-m\(arch\|tune\|cpu\)=[^ ]*//g'` -%endif -# Replace 2 spaces by one finally -RPM_OPT_FLAGS=`echo $RPM_OPT_FLAGS|sed -e 's/ / /g'` - -languages=c -%if %{build_cp} -languages=$languages,c++ -%endif -%if %{build_objc} -languages=$languages,objc -%endif -%if %{build_fortran} -languages=$languages,fortran -%endif -%if %{build_objcp} -languages=$languages,obj-c++ -%endif -%if %{build_ada} -languages=$languages,ada -%endif -%if %{build_go} -languages=$languages,go -%endif -%if %{build_d} -languages=$languages,d -%endif -%if %{build_jit} -languages=$languages,jit -%endif - -# In general we want to ship release checking enabled compilers -# which is the default for released compilers -#ENABLE_CHECKING="--enable-checking=yes" -ENABLE_CHECKING="--enable-checking=release" -#ENABLE_CHECKING="" - -# Work around tail/head -1 changes -export _POSIX2_VERSION=199209 - -%if "%{TARGET_ARCH}" == "amdgcn" -mkdir -p target-tools/bin -ln -s /usr/bin/llvm-ar target-tools/bin/amdgcn-amdhsa-ar -ln -s /usr/bin/llvm-mc target-tools/bin/amdgcn-amdhsa-as -ln -s /usr/bin/lld target-tools/bin/amdgcn-amdhsa-ld -ln -s /usr/bin/llvm-nm target-tools/bin/amdgcn-amdhsa-nm -ln -s /usr/bin/llvm-ranlib target-tools/bin/amdgcn-amdhsa-ranlib -export PATH="`pwd`/target-tools/bin:$PATH" -%endif - -%if "%{hostsuffix}" != "" -mkdir -p host-tools/bin -# Using the host gnatmake like -# CC="gcc%%{hostsuffix}" GNATBIND="gnatbind%%{hostsuffix}" -# GNATMAKE="gnatmake%%{hostsuffix}" -# doesn't work due to PR33857, so an un-suffixed gnatmake has to be -# available -%if %{build_ada} -cp -a /usr/bin/gnatmake%{hostsuffix} host-tools/bin/gnatmake -cp -a /usr/bin/gnatlink%{hostsuffix} host-tools/bin/gnatlink -cp -a /usr/bin/gnatbind%{hostsuffix} host-tools/bin/gnatbind -%endif -cp -a /usr/bin/gcc%{hostsuffix} host-tools/bin/gcc -cp -a /usr/bin/g++%{hostsuffix} host-tools/bin/g++ -ln -sf /usr/%{_lib} host-tools/%{_lib} -export PATH="`pwd`/host-tools/bin:$PATH" -%endif - -# libsanitizer needs and since the glibc/libxcrypt split -# we don't have that yet in a pure cross environment -%if 0%{?gcc_target_arch:1} - CONFARGS="$CONFARGS --disable-libsanitizer" -%endif - -CFLAGS="$RPM_OPT_FLAGS" CXXFLAGS="$RPM_OPT_FLAGS" XCFLAGS="$RPM_OPT_FLAGS" \ -TCFLAGS="$RPM_OPT_FLAGS" \ -../configure \ - --prefix=%{_prefix} \ - --infodir=%{_infodir} \ - --mandir=%{_mandir} \ - --libdir=%{_libdir} \ - --libexecdir=%{_libdir} \ - --enable-languages=$languages \ -%if %{build_nvptx} || %{build_gcn} - --enable-offload-targets=\ -%if %{build_nvptx} -nvptx-none,\ -%endif -%if %{build_gcn} -amdgcn-amdhsa,\ -%endif -%endif -%if %{build_nvptx} - --without-cuda-driver \ -%endif -%if %{build_jit} - --enable-host-shared \ -%endif - $ENABLE_CHECKING \ - --disable-werror \ - --with-gxx-include-dir=%{_prefix}/include/c++/%{gcc_dir_version} \ - --enable-ssp \ - --disable-libssp \ -%if 0%{!?build_libvtv:1} - --disable-libvtv \ -%endif -%if 0%{suse_version} >= 1500 - --enable-cet=auto \ -%else - --disable-cet \ -%endif - --disable-libcc1 \ -%if %{enable_plugins} - --enable-plugin \ -%else - --disable-plugin \ -%endif - --with-bugurl="https://bugs.opensuse.org/" \ - --with-pkgversion="SUSE Linux" \ -%if 0%{?sysroot:1} - --with-slibdir=%{sysroot}/%{_lib} \ -%else - --with-slibdir=/%{_lib} \ -%endif - --with-system-zlib \ - --enable-libstdcxx-allocator=new \ - --disable-libstdcxx-pch \ -%if 0%{suse_version} <= 1320 - --with-default-libstdcxx-abi=gcc4-compatible \ -%endif -%if %{build_d} - --enable-libphobos \ -%endif - --enable-version-specific-runtime-libs \ - --with-gcc-major-version-only \ -%if 0%{!?gcc_target_arch:1} - --enable-linker-build-id \ -%else -%if 0%{?gcc_target_glibc:1} - --enable-linker-build-id \ -%endif -%endif - --enable-linux-futex \ -%if %{suse_version} >= 1315 -%ifarch %ix86 x86_64 ppc ppc64 ppc64le %arm aarch64 s390 s390x %sparc - --enable-gnu-indirect-function \ -%endif -%endif - --program-suffix=%{binsuffix} \ -%ifarch %{disable_multilib_arch} - --disable-multilib \ -%endif -%if 0%{!?gcc_target_arch:1} -%ifarch ia64 - --with-system-libunwind \ -%else - --without-system-libunwind \ -%endif -%endif -%if 0%{?gcc_target_arch:1} - --program-prefix=%{gcc_target_arch}- \ - --target=%{gcc_target_arch} \ - --disable-nls \ -%if 0%{?sysroot:1} - --with-sysroot=%sysroot \ -%endif -%if 0%{?build_sysroot:1} - --with-build-sysroot=%{build_sysroot} \ -%else -%if 0%{?sysroot:1} - --with-build-sysroot=%{sysroot} \ -%endif -%endif -%if 0%{?binutils_os:1} - --with-build-time-tools=/usr/%{binutils_os}/bin \ -%endif -%if 0%{?gcc_target_newlib} - --with-newlib \ -%if 0%{?gcc_libc_bootstrap:1} - --disable-gcov \ -%endif -%else -%if 0%{?gcc_libc_bootstrap:1} - --disable-gcov --disable-threads --disable-shared \ - --disable-libmudflap --disable-libssp --disable-libgomp \ - --disable-libquadmath --disable-libatomic \ - --without-headers --with-newlib \ -%endif -%endif -%if "%{TARGET_ARCH}" == "spu" - --with-gxx-include-dir=%sysroot/include/c++/%{gcc_dir_version} \ - --with-newlib \ -%endif -%if "%{TARGET_ARCH}" == "nvptx" - --enable-as-accelerator-for=%{GCCDIST} \ - --disable-sjlj-exceptions \ - --enable-newlib-io-long-long \ -%endif -%if "%{TARGET_ARCH}" == "amdgcn" - --enable-as-accelerator-for=%{GCCDIST} \ - --enable-libgomp \ -%endif -%if "%{TARGET_ARCH}" == "avr" - --enable-lto \ - --without-gxx-include-dir \ - --with-native-system-header-dir=/include \ -%endif -%endif -%if "%{TARGET_ARCH}" == "arm" - --with-arch=armv6zk \ - --with-tune=arm1176jzf-s \ - --with-float=hard \ - --with-abi=aapcs-linux \ - --with-fpu=vfp \ - --disable-sjlj-exceptions \ -%endif -%if "%{TARGET_ARCH}" == "arm-none" - --enable-multilib \ - --with-multilib-list=aprofile,rmprofile \ - --disable-decimal-float \ - --disable-libffi \ - --disable-libgomp \ - --disable-libmudflap \ - --disable-libquadmath \ - --disable-shared \ - --disable-threads \ - --disable-tls \ -%endif -%if "%{TARGET_ARCH}" == "armv5tel" - --with-arch=armv5te \ - --with-float=soft \ - --with-mode=arm \ - --with-abi=aapcs-linux \ - --disable-sjlj-exceptions \ -%endif -%if "%{TARGET_ARCH}" == "armv6hl" - --with-arch=armv6zk \ - --with-tune=arm1176jzf-s \ - --with-float=hard \ - --with-abi=aapcs-linux \ - --with-fpu=vfp \ - --disable-sjlj-exceptions \ -%endif -%if "%{TARGET_ARCH}" == "armv7hl" - --with-arch=armv7-a \ - --with-tune=generic-armv7-a \ - --with-float=hard \ - --with-abi=aapcs-linux \ - --with-fpu=vfpv3-d16 \ - --disable-sjlj-exceptions \ -%endif -%if "%{TARGET_ARCH}" == "aarch64" - --enable-fix-cortex-a53-835769 \ - --enable-fix-cortex-a53-843419 \ -%endif -%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64" || "%{TARGET_ARCH}" == "powerpc64le" -%if "%{TARGET_ARCH}" == "powerpc" - --with-cpu=default32 \ -%endif -%if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1350 - --with-cpu=power8 \ - --with-tune=power9 \ -%else -%if %{suse_version} >= 1315 && %{suse_version} != 1320 - --with-cpu=power8 \ - --with-tune=power8 \ -%else - --with-cpu=power7 \ - --with-tune=power7 \ -%endif -%endif -%else - --with-cpu-64=power4 \ -%endif - --enable-secureplt \ - --with-long-double-128 \ -%if "%{TARGET_ARCH}" == "powerpc64le" - --enable-targets=powerpcle-linux \ - --disable-multilib \ -%endif -%endif -%if "%{TARGET_ARCH}" == "sparc64" - --with-cpu=ultrasparc \ - --with-long-double-128 \ -%endif -%if "%{TARGET_ARCH}" == "sparc" - --with-cpu=v8 \ - --with-long-double-128 \ -%endif -%if "%{TARGET_ARCH}" == "i586" -%if 0%{?sle_version:%sle_version} >= 150000 - --with-arch-32=x86-64 \ -%else - --with-arch-32=i586 \ -%endif - --with-tune=generic \ -%endif -%if "%{TARGET_ARCH}" == "x86_64" -%ifnarch %{disable_multilib_arch} - --enable-multilib \ - --with-arch-32=x86-64 \ -%endif - --with-tune=generic \ -%endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "m68k" - --disable-multilib \ -%endif -%if "%{TARGET_ARCH}" == "riscv64" - --disable-multilib \ -%endif -%if %{use_lto_bootstrap} && !0%{?building_testsuite:1} - --with-build-config=bootstrap-lto-lean \ - --enable-link-mutex \ -%endif -%ifarch riscv64 - --enable-link-mutex \ -%endif - $CONFARGS \ - --build=%{GCCDIST} \ - --host=%{GCCDIST} || \ - { - rc=$?; - echo "------- BEGIN config.log ------"; - %{__cat} config.log; - echo "------- END config.log ------"; - exit $rc; - } - -%if 0%{!?gcc_icecream:1} -make %{?_smp_mflags} -%else -make %{?_smp_mflags} all-host -%endif - -%if 0%{?gcc_icecream:%gcc_icecream} -%package -n cross-%cross_arch-gcc11-icecream-backend -Summary: Icecream backend for the GNU C Compiler -Group: Development/Languages/C and C++ - -%description -n cross-%cross_arch-gcc11-icecream-backend -This package contains the icecream environment for the GNU C Compiler -%endif - -%if 0%{?nvptx_newlib:1} -%package -n cross-nvptx-newlib11-devel -Summary: Newlib for the nvptx offload target -Group: Development/Languages/C and C++ -Provides: cross-nvptx-newlib-devel = %{version}-%{release} -Conflicts: cross-nvptx-newlib-devel - -%description -n cross-nvptx-newlib11-devel -Newlib development files for the nvptx offload target compiler. -%endif - -%if 0%{?amdgcn_newlib:1} -%package -n cross-amdgcn-newlib11-devel -Summary: Newlib for the amdgcn offload target -Group: Development/Languages/C and C++ -Provides: cross-amdgcn-newlib-devel = %{version}-%{release} -Conflicts: cross-amdgcn-newlib-devel - -%description -n cross-amdgcn-newlib11-devel -Newlib development files for the amdgcn offload target compiler. -%endif - -%define targetlibsubdir %{_libdir}/gcc/%{gcc_target_arch}/%{gcc_dir_version} - -%install -cd obj-%{GCCDIST} - -%if "%{TARGET_ARCH}" == "amdgcn" -# libtool needs to be able to call ranlib -export PATH="`pwd`/target-tools/bin:$PATH" -%endif - -# install and fixup host parts -make DESTDIR=$RPM_BUILD_ROOT install-host -rm -rf $RPM_BUILD_ROOT/%{targetlibsubdir}/install-tools -rm -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.la -# common fixup -rm -f $RPM_BUILD_ROOT%{_libdir}/libiberty.a - -# install and fixup target parts -%if 0%{?gcc_icecream:1} -# so expect the sysroot to be populated from natively built binaries -%else -# We want shared libraries to reside in the sysroot but the .so symlinks -# on the host. Once we have a cross target that has shared libs we need -# to manually fix up things here like we do for non-cross compilers -mkdir -p $RPM_BUILD_ROOT/%{?sysroot:%sysroot} -make DESTDIR=$RPM_BUILD_ROOT install-target -%if %{build_cp} -# So we installed libstdc++ headers into %prefix where they conflict -# with other host compilers. Rip out the non-target specific parts -# again. Note not all cross targets support libstdc++, so create the -# directory to make things easier. -mkdir -p $RPM_BUILD_ROOT/%_prefix/include/c++/%{gcc_dir_version} -find $RPM_BUILD_ROOT/%_prefix/include/c++/%{gcc_dir_version} -mindepth 1 -maxdepth 1 -type d -a -not -name %{gcc_target_arch} | xargs -r rm -r -find $RPM_BUILD_ROOT/%_prefix/include/c++/%{gcc_dir_version} -maxdepth 1 -type f | xargs -r rm -# And also remove installed pretty printers which conflict in similar ways -rm -rf $RPM_BUILD_ROOT/%{_datadir}/gcc%{binsuffix} -%endif -%endif - -%if 0%{?binutils_os:1} -for prog in as ld; do - ln -s /usr/%{binutils_os}/bin/$prog $RPM_BUILD_ROOT%{targetlibsubdir}/ -done -%endif - -# remove docs -rm -rf $RPM_BUILD_ROOT%{_mandir} -rm -rf $RPM_BUILD_ROOT%{_infodir} - -# for accelerators remove all frontends but lto1 and also install-tools -%if 0%{?gcc_accel:1} -rm -f $RPM_BUILD_ROOT%{libsubdir}/accel/%{gcc_target_arch}/cc1 -rm -f $RPM_BUILD_ROOT%{libsubdir}/accel/%{gcc_target_arch}/cc1plus -rm -rf $RPM_BUILD_ROOT%{libsubdir}/accel/%{gcc_target_arch}/install-tools -rm -rf $RPM_BUILD_ROOT%{targetlibsubdir}/install-tools -# also move things from target directories into the accel path since -# that is the place where we later search for (only) -( cd $RPM_BUILD_ROOT%{targetlibsubdir} && tar cf - . ) | ( cd $RPM_BUILD_ROOT%{libsubdir}/accel/%{gcc_target_arch} && tar xf - ) -rm -rf $RPM_BUILD_ROOT%{targetlibsubdir} -%endif -# for amdgcn install the symlinks to the llvm tools -# follow alternatives symlinks to the hardcoded version requirement -%if "%{TARGET_ARCH}" == "amdgcn" -mkdir -p $RPM_BUILD_ROOT%{_prefix}/amdgcn-amdhsa/bin -ln -s `readlink -f /usr/bin/llvm-ar` $RPM_BUILD_ROOT%{_prefix}/amdgcn-amdhsa/bin/ar -ln -s `readlink -f /usr/bin/llvm-mc` $RPM_BUILD_ROOT%{_prefix}/amdgcn-amdhsa/bin/as -ln -s /usr/bin/lld $RPM_BUILD_ROOT%{_prefix}/amdgcn-amdhsa/bin/ld -ln -s `readlink -f /usr/bin/llvm-nm` $RPM_BUILD_ROOT%{_prefix}/amdgcn-amdhsa/bin/nm -ln -s `readlink -f /usr/bin/llvm-ranlib` $RPM_BUILD_ROOT%{_prefix}/amdgcn-amdhsa/bin/ranlib -ln -s %{_prefix}/amdgcn-amdhsa/bin/ar $RPM_BUILD_ROOT%{_prefix}/bin/amdgcn-amdhsa-ar -ln -s %{_prefix}/amdgcn-amdhsa/bin/as $RPM_BUILD_ROOT%{_prefix}/bin/amdgcn-amdhsa-as -ln -s %{_prefix}/amdgcn-amdhsa/bin/ld $RPM_BUILD_ROOT%{_prefix}/bin/amdgcn-amdhsa-ld -ln -s %{_prefix}/amdgcn-amdhsa/bin/nm $RPM_BUILD_ROOT%{_prefix}/bin/amdgcn-amdhsa-nm -ln -s %{_prefix}/amdgcn-amdhsa/bin/ranlib $RPM_BUILD_ROOT%{_prefix}/bin/amdgcn-amdhsa-ranlib -%endif - -%if 0%{?gcc_icecream:%gcc_icecream} -# Build an icecream environment -# The assembler comes from the cross-binutils, and hence is _not_ -# named funnily, not even on ppc, so there we need the original target -install -s -D %{_prefix}/bin/%{binutils_os}-as \ - $RPM_BUILD_ROOT/env/usr/bin/as -install -s $RPM_BUILD_ROOT/%{_prefix}/bin/%{gcc_target_arch}-g++%{binsuffix} \ - $RPM_BUILD_ROOT/env/usr/bin/g++ -install -s $RPM_BUILD_ROOT/%{_prefix}/bin/%{gcc_target_arch}-gcc%{binsuffix} \ - $RPM_BUILD_ROOT/env/usr/bin/gcc - -for back in cc1 cc1plus; do - install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/$back \ - $RPM_BUILD_ROOT/env%{targetlibsubdir}/$back -done -if test -f $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so; then - install -s -D $RPM_BUILD_ROOT/%{targetlibsubdir}/liblto_plugin.so \ - $RPM_BUILD_ROOT/env%{targetlibsubdir}/liblto_plugin.so -fi - -# Make sure to also pull in all shared library requirements for the -# binaries we put into the environment which is operated by chrooting -# into it and execing the compiler -libs=`for bin in $RPM_BUILD_ROOT/env/usr/bin/* $RPM_BUILD_ROOT/env%{targetlibsubdir}/*; do \ - ldd $bin | sed -n '\,^[^/]*\(/[^ ]*\).*,{ s//\1/; p; }' ;\ -done | sort -u ` -for lib in $libs; do - # Check wether the same library also exists in the parent directory, - # and prefer that on the assumption that it is a more generic one. - baselib=`echo "$lib" | sed 's,/[^/]*\(/[^/]*\)$,\1,'` - test -f "$baselib" && lib=$baselib - install -s -D $lib $RPM_BUILD_ROOT/env$lib -done - -cd $RPM_BUILD_ROOT/env -tar --no-recursion --mtime @${SOURCE_DATE_EPOCH:-$(date +%s)} --format=gnu -cv `find *|LC_ALL=C sort` |\ - gzip -n9 > ../%{name}_%{_arch}.tar.gz -cd .. -mkdir -p usr/share/icecream-envs -mv %{name}_%{_arch}.tar.gz usr/share/icecream-envs -rpm -q --changelog glibc > usr/share/icecream-envs/%{name}_%{_arch}.glibc -rpm -q --changelog binutils > usr/share/icecream-envs/%{name}_%{_arch}.binutils -rm -r env -%endif - -# we provide update-alternatives for selecting a compiler version for -# crosses -%if 0%{!?gcc_accel:1} -mkdir -p %{buildroot}%{_sysconfdir}/alternatives -for ex in gcc cpp \ -%if %{build_cp} - c++ g++ \ -%endif - gcc-ar gcc-nm gcc-ranlib lto-dump \ -%if 0%{!?gcc_libc_bootstrap:1} - gcov gcov-dump gcov-tool \ -%endif - ; do - ln -s %{_sysconfdir}/alternatives/%{gcc_target_arch}-$ex \ - %{buildroot}%{_bindir}/%{gcc_target_arch}-$ex -done - -%post -%{_sbindir}/update-alternatives \ - --install %{_bindir}/%{gcc_target_arch}-gcc %{gcc_target_arch}-gcc %{_bindir}/%{gcc_target_arch}-gcc%{binsuffix} 11 \ - --slave %{_bindir}/%{gcc_target_arch}-cpp %{gcc_target_arch}-cpp %{_bindir}/%{gcc_target_arch}-cpp%{binsuffix} \ -%if %{build_cp} - --slave %{_bindir}/%{gcc_target_arch}-c++ %{gcc_target_arch}-c++ %{_bindir}/%{gcc_target_arch}-c++%{binsuffix} \ - --slave %{_bindir}/%{gcc_target_arch}-g++ %{gcc_target_arch}-g++ %{_bindir}/%{gcc_target_arch}-g++%{binsuffix} \ -%endif - --slave %{_bindir}/%{gcc_target_arch}-gcc-ar %{gcc_target_arch}-gcc-ar %{_bindir}/%{gcc_target_arch}-gcc-ar%{binsuffix} \ - --slave %{_bindir}/%{gcc_target_arch}-gcc-nm %{gcc_target_arch}-gcc-nm %{_bindir}/%{gcc_target_arch}-gcc-nm%{binsuffix} \ - --slave %{_bindir}/%{gcc_target_arch}-lto-dump %{gcc_target_arch}-lto-dump %{_bindir}/%{gcc_target_arch}-lto-dump%{binsuffix} \ - --slave %{_bindir}/%{gcc_target_arch}-gcc-ranlib %{gcc_target_arch}-gcc-ranlib %{_bindir}/%{gcc_target_arch}-gcc-ranlib%{binsuffix} \ -%if 0%{!?gcc_libc_bootstrap:1} - --slave %{_bindir}/%{gcc_target_arch}-gcov %{gcc_target_arch}-gcov %{_bindir}/%{gcc_target_arch}-gcov%{binsuffix} \ - --slave %{_bindir}/%{gcc_target_arch}-gcov-dump %{gcc_target_arch}-gcov-dump %{_bindir}/%{gcc_target_arch}-gcov-dump%{binsuffix} \ - --slave %{_bindir}/%{gcc_target_arch}-gcov-tool %{gcc_target_arch}-gcov-tool %{_bindir}/%{gcc_target_arch}-gcov-tool%{binsuffix} \ -%endif - -%postun -if [ ! -f %{_bindir}/%{gcc_target_arch}-gcc ] ; then - %{_sbindir}/update-alternatives --remove %{gcc_target_arch}-gcc %{_bindir}/%{gcc_target_arch}-gcc%{binsuffix} -fi -%endif - -%files -%defattr(-,root,root) -%if 0%{?gcc_accel:1} -%{_prefix}/bin/%{GCCDIST}-accel-%{gcc_target_arch}-* -%dir %{libsubdir} -%dir %{libsubdir}/accel -%{libsubdir}/accel/%{gcc_target_arch} -%else -%{_prefix}/bin/%{gcc_target_arch}-gcc%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-cpp%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-gcc-ar%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-gcc-nm%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-gcc-ranlib%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-lto-dump%{binsuffix} -%if 0%{!?gcc_libc_bootstrap:1} -%{_prefix}/bin/%{gcc_target_arch}-gcov%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-gcov-dump%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-gcov-tool%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-gcov -%{_prefix}/bin/%{gcc_target_arch}-gcov-dump -%{_prefix}/bin/%{gcc_target_arch}-gcov-tool -%endif -%{_prefix}/bin/%{gcc_target_arch}-gcc -%{_prefix}/bin/%{gcc_target_arch}-cpp -%{_prefix}/bin/%{gcc_target_arch}-gcc-ar -%{_prefix}/bin/%{gcc_target_arch}-gcc-nm -%{_prefix}/bin/%{gcc_target_arch}-gcc-ranlib -%{_prefix}/bin/%{gcc_target_arch}-lto-dump -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-gcc -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-cpp -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-gcc-ar -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-gcc-nm -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-gcc-ranlib -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-lto-dump -%if 0%{!?gcc_libc_bootstrap:1} -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-gcov -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-gcov-dump -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-gcov-tool -%endif -%if %{build_cp} -%{_prefix}/bin/%{gcc_target_arch}-c++%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-g++%{binsuffix} -%{_prefix}/bin/%{gcc_target_arch}-c++ -%{_prefix}/bin/%{gcc_target_arch}-g++ -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-c++ -%ghost %{_sysconfdir}/alternatives/%{gcc_target_arch}-g++ -%if 0%{!?gcc_libc_bootstrap:1} -%if "%{cross_arch}" == "avr" || 0%{?gcc_target_newlib:1} || 0%{?gcc_target_glibc:1} -%{_prefix}/include/c++ -%endif -%endif -%endif -%dir %{targetlibsubdir} -%dir %{_libdir}/gcc/%{gcc_target_arch} -%{targetlibsubdir} -%endif -%if 0%{!?gcc_icecream:1} && 0%{!?gcc_libc_bootstrap:1} && 0%{?sysroot:1} -%{sysroot} -%endif - -%if 0%{?gcc_icecream:%gcc_icecream} -%files -n cross-%cross_arch-gcc11-icecream-backend -%defattr(-,root,root) -/usr/share/icecream-envs -%endif - -%if 0%{?nvptx_newlib:1} -%files -n cross-nvptx-newlib11-devel -%defattr(-,root,root) -%{_prefix}/%{gcc_target_arch} -%endif - -%if 0%{?amdgcn_newlib:1} -%files -n cross-amdgcn-newlib11-devel -%defattr(-,root,root) -%{_prefix}/%{gcc_target_arch} -%{_prefix}/bin/amdgcn-amdhsa-ar -%{_prefix}/bin/amdgcn-amdhsa-as -%{_prefix}/bin/amdgcn-amdhsa-ld -%{_prefix}/bin/amdgcn-amdhsa-nm -%{_prefix}/bin/amdgcn-amdhsa-ranlib -%endif - -%changelog diff --git a/cross-m68k-gcc11.changes b/cross-m68k-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-m68k-gcc11.changes +++ b/cross-m68k-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-mips-gcc11.changes b/cross-mips-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-mips-gcc11.changes +++ b/cross-mips-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-nvptx-gcc11.changes b/cross-nvptx-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-nvptx-gcc11.changes +++ b/cross-nvptx-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-ppc64-gcc11.changes b/cross-ppc64-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-ppc64-gcc11.changes +++ b/cross-ppc64-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-ppc64le-gcc11.changes b/cross-ppc64le-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-ppc64le-gcc11.changes +++ b/cross-ppc64le-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-riscv64-elf-gcc11-bootstrap.changes b/cross-riscv64-elf-gcc11-bootstrap.changes index ddcb0b3..998b6e5 100644 --- a/cross-riscv64-elf-gcc11-bootstrap.changes +++ b/cross-riscv64-elf-gcc11-bootstrap.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-riscv64-elf-gcc11.changes b/cross-riscv64-elf-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-riscv64-elf-gcc11.changes +++ b/cross-riscv64-elf-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-riscv64-gcc11-bootstrap.changes b/cross-riscv64-gcc11-bootstrap.changes index ddcb0b3..998b6e5 100644 --- a/cross-riscv64-gcc11-bootstrap.changes +++ b/cross-riscv64-gcc11-bootstrap.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-riscv64-gcc11.changes b/cross-riscv64-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-riscv64-gcc11.changes +++ b/cross-riscv64-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-rx-gcc11-bootstrap.changes b/cross-rx-gcc11-bootstrap.changes index ddcb0b3..998b6e5 100644 --- a/cross-rx-gcc11-bootstrap.changes +++ b/cross-rx-gcc11-bootstrap.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-rx-gcc11.changes b/cross-rx-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-rx-gcc11.changes +++ b/cross-rx-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-s390x-gcc11.changes b/cross-s390x-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-s390x-gcc11.changes +++ b/cross-s390x-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-sparc-gcc11.changes b/cross-sparc-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-sparc-gcc11.changes +++ b/cross-sparc-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-sparc64-gcc11.changes b/cross-sparc64-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-sparc64-gcc11.changes +++ b/cross-sparc64-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/cross-x86_64-gcc11.changes b/cross-x86_64-gcc11.changes index ddcb0b3..998b6e5 100644 --- a/cross-x86_64-gcc11.changes +++ b/cross-x86_64-gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/gcc11-testresults.changes b/gcc11-testresults.changes index ddcb0b3..998b6e5 100644 --- a/gcc11-testresults.changes +++ b/gcc11-testresults.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener diff --git a/gcc11.changes b/gcc11.changes index ddcb0b3..998b6e5 100644 --- a/gcc11.changes +++ b/gcc11.changes @@ -2,6 +2,7 @@ Fri Nov 26 15:01:01 UTC 2021 - Michael Matz - Enable the cross compilers also on i586 +- Remove cross compilers for i386 target ------------------------------------------------------------------- Wed Nov 24 10:41:45 UTC 2021 - Richard Biener