From 58ca0a3ea880264439237c21ee935bd8130138ca3a273610f8969d2e652d572c Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Fri, 18 Aug 2023 13:45:58 +0000 Subject: [PATCH 01/10] Accepting request 1104679 from home:michals:branches:devel:gcc - Raise Power architecture baseline to Power9 only for ALP (boo#1213915). OBS-URL: https://build.opensuse.org/request/show/1104679 OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=60 --- cross-aarch64-gcc13-bootstrap.spec | 2 +- cross-aarch64-gcc13.spec | 2 +- cross-amdgcn-gcc13.spec | 2 +- cross-arm-gcc13.spec | 2 +- cross-arm-none-gcc13-bootstrap.spec | 2 +- cross-arm-none-gcc13.spec | 2 +- cross-avr-gcc13-bootstrap.spec | 2 +- cross-avr-gcc13.spec | 2 +- cross-bpf-gcc13.spec | 2 +- cross-epiphany-gcc13-bootstrap.spec | 2 +- cross-epiphany-gcc13.spec | 2 +- cross-hppa-gcc13-bootstrap.spec | 2 +- cross-hppa-gcc13.spec | 2 +- cross-m68k-gcc13.spec | 2 +- cross-mips-gcc13.spec | 2 +- cross-nvptx-gcc13.spec | 2 +- cross-ppc64-gcc13.spec | 2 +- cross-ppc64le-gcc13.spec | 2 +- cross-pru-gcc13-bootstrap.spec | 2 +- cross-pru-gcc13.spec | 2 +- cross-riscv64-elf-gcc13-bootstrap.spec | 2 +- cross-riscv64-elf-gcc13.spec | 2 +- cross-riscv64-gcc13-bootstrap.spec | 2 +- cross-riscv64-gcc13.spec | 2 +- cross-rx-gcc13-bootstrap.spec | 2 +- cross-rx-gcc13.spec | 2 +- cross-s390x-gcc13.spec | 2 +- cross-sparc-gcc13.spec | 2 +- cross-sparc64-gcc13.spec | 2 +- cross-x86_64-gcc13.spec | 2 +- gcc.spec.in | 2 +- gcc13-testresults.spec | 2 +- gcc13.changes | 5 +++++ gcc13.spec | 2 +- 34 files changed, 38 insertions(+), 33 deletions(-) diff --git a/cross-aarch64-gcc13-bootstrap.spec b/cross-aarch64-gcc13-bootstrap.spec index f8d1d7d..bba35af 100644 --- a/cross-aarch64-gcc13-bootstrap.spec +++ b/cross-aarch64-gcc13-bootstrap.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-aarch64-gcc13.spec b/cross-aarch64-gcc13.spec index d925ab9..57981df 100644 --- a/cross-aarch64-gcc13.spec +++ b/cross-aarch64-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-amdgcn-gcc13.spec b/cross-amdgcn-gcc13.spec index 07e5637..76d6e1f 100644 --- a/cross-amdgcn-gcc13.spec +++ b/cross-amdgcn-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-arm-gcc13.spec b/cross-arm-gcc13.spec index 9816828..0b0756d 100644 --- a/cross-arm-gcc13.spec +++ b/cross-arm-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-arm-none-gcc13-bootstrap.spec b/cross-arm-none-gcc13-bootstrap.spec index 5050ca3..8c05a7a 100644 --- a/cross-arm-none-gcc13-bootstrap.spec +++ b/cross-arm-none-gcc13-bootstrap.spec @@ -652,7 +652,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-arm-none-gcc13.spec b/cross-arm-none-gcc13.spec index eaee242..2962f8e 100644 --- a/cross-arm-none-gcc13.spec +++ b/cross-arm-none-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-avr-gcc13-bootstrap.spec b/cross-avr-gcc13-bootstrap.spec index 50d91c0..c81fce3 100644 --- a/cross-avr-gcc13-bootstrap.spec +++ b/cross-avr-gcc13-bootstrap.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-avr-gcc13.spec b/cross-avr-gcc13.spec index dcdcf32..a6a4a1b 100644 --- a/cross-avr-gcc13.spec +++ b/cross-avr-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-bpf-gcc13.spec b/cross-bpf-gcc13.spec index 662f963..18d443b 100644 --- a/cross-bpf-gcc13.spec +++ b/cross-bpf-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-epiphany-gcc13-bootstrap.spec b/cross-epiphany-gcc13-bootstrap.spec index fc669ab..41f8595 100644 --- a/cross-epiphany-gcc13-bootstrap.spec +++ b/cross-epiphany-gcc13-bootstrap.spec @@ -652,7 +652,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-epiphany-gcc13.spec b/cross-epiphany-gcc13.spec index ccf9266..16aa9ca 100644 --- a/cross-epiphany-gcc13.spec +++ b/cross-epiphany-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-hppa-gcc13-bootstrap.spec b/cross-hppa-gcc13-bootstrap.spec index e208ba4..a569330 100644 --- a/cross-hppa-gcc13-bootstrap.spec +++ b/cross-hppa-gcc13-bootstrap.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-hppa-gcc13.spec b/cross-hppa-gcc13.spec index dd064a8..7ec2552 100644 --- a/cross-hppa-gcc13.spec +++ b/cross-hppa-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-m68k-gcc13.spec b/cross-m68k-gcc13.spec index 0d664f4..cf13568 100644 --- a/cross-m68k-gcc13.spec +++ b/cross-m68k-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-mips-gcc13.spec b/cross-mips-gcc13.spec index 709bc45..c74f3db 100644 --- a/cross-mips-gcc13.spec +++ b/cross-mips-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-nvptx-gcc13.spec b/cross-nvptx-gcc13.spec index 0658422..e49a436 100644 --- a/cross-nvptx-gcc13.spec +++ b/cross-nvptx-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-ppc64-gcc13.spec b/cross-ppc64-gcc13.spec index f42d1d5..786697c 100644 --- a/cross-ppc64-gcc13.spec +++ b/cross-ppc64-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index 0fc5a8f..69744d1 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-pru-gcc13-bootstrap.spec b/cross-pru-gcc13-bootstrap.spec index ef49ee5..b779e79 100644 --- a/cross-pru-gcc13-bootstrap.spec +++ b/cross-pru-gcc13-bootstrap.spec @@ -652,7 +652,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-pru-gcc13.spec b/cross-pru-gcc13.spec index 202a09b..e2a331b 100644 --- a/cross-pru-gcc13.spec +++ b/cross-pru-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-riscv64-elf-gcc13-bootstrap.spec b/cross-riscv64-elf-gcc13-bootstrap.spec index a9a55fd..b3e1174 100644 --- a/cross-riscv64-elf-gcc13-bootstrap.spec +++ b/cross-riscv64-elf-gcc13-bootstrap.spec @@ -652,7 +652,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-riscv64-elf-gcc13.spec b/cross-riscv64-elf-gcc13.spec index 0e04c40..a8fe782 100644 --- a/cross-riscv64-elf-gcc13.spec +++ b/cross-riscv64-elf-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-riscv64-gcc13-bootstrap.spec b/cross-riscv64-gcc13-bootstrap.spec index b02e593..54f21ac 100644 --- a/cross-riscv64-gcc13-bootstrap.spec +++ b/cross-riscv64-gcc13-bootstrap.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-riscv64-gcc13.spec b/cross-riscv64-gcc13.spec index 28883e4..1e0a0eb 100644 --- a/cross-riscv64-gcc13.spec +++ b/cross-riscv64-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-rx-gcc13-bootstrap.spec b/cross-rx-gcc13-bootstrap.spec index d2f6586..7c8fcf2 100644 --- a/cross-rx-gcc13-bootstrap.spec +++ b/cross-rx-gcc13-bootstrap.spec @@ -652,7 +652,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-rx-gcc13.spec b/cross-rx-gcc13.spec index 00b43c4..81fa215 100644 --- a/cross-rx-gcc13.spec +++ b/cross-rx-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-s390x-gcc13.spec b/cross-s390x-gcc13.spec index 66c6f71..39060b2 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-sparc-gcc13.spec b/cross-sparc-gcc13.spec index 6ee8d1d..c5cb8d5 100644 --- a/cross-sparc-gcc13.spec +++ b/cross-sparc-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-sparc64-gcc13.spec b/cross-sparc64-gcc13.spec index 3a80168..a49983b 100644 --- a/cross-sparc64-gcc13.spec +++ b/cross-sparc64-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/cross-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index 5abc3f8..a07f7fb 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -651,7 +651,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/gcc.spec.in b/gcc.spec.in index 1aa8833..f3d7175 100644 --- a/gcc.spec.in +++ b/gcc.spec.in @@ -1662,7 +1662,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/gcc13-testresults.spec b/gcc13-testresults.spec index 0e9a6ea..f22a155 100644 --- a/gcc13-testresults.spec +++ b/gcc13-testresults.spec @@ -853,7 +853,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else diff --git a/gcc13.changes b/gcc13.changes index bc3fd2d..9c11e81 100644 --- a/gcc13.changes +++ b/gcc13.changes @@ -1,3 +1,8 @@ +------------------------------------------------------------------- +Fri Aug 18 13:03:36 UTC 2023 - Michal Suchanek + +- Raise Power architecture baseline to Power9 only for ALP (boo#1213915). + ------------------------------------------------------------------- Thu Aug 3 13:34:26 UTC 2023 - Richard Biener diff --git a/gcc13.spec b/gcc13.spec index d2141eb..418fcbc 100644 --- a/gcc13.spec +++ b/gcc13.spec @@ -2670,7 +2670,7 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" -%if %{suse_version} >= 1600 +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ %else From 69588043d9626e2a2e9250c832c1e98cd98daeef57bc415807e09beb30e298d7 Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Tue, 22 Aug 2023 10:45:26 +0000 Subject: [PATCH 02/10] - Turn cross compilers to x86_64, ppc64le and s390x to glibc crosses. [bsc#1214460] OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=61 --- _multibuild | 9 +- change_spec | 6 +- cross-ppc64le-gcc13-bootstrap.spec | 1056 ++++++++++++++++++++++++++++ cross-ppc64le-gcc13.spec | 4 +- cross-s390x-gcc13-bootstrap.spec | 1056 ++++++++++++++++++++++++++++ cross-s390x-gcc13.spec | 2 +- cross-x86_64-gcc13-bootstrap.spec | 1056 ++++++++++++++++++++++++++++ cross-x86_64-gcc13.spec | 2 +- gcc13.changes | 6 + 9 files changed, 3187 insertions(+), 10 deletions(-) create mode 100644 cross-ppc64le-gcc13-bootstrap.spec create mode 100644 cross-s390x-gcc13-bootstrap.spec create mode 100644 cross-x86_64-gcc13-bootstrap.spec diff --git a/_multibuild b/_multibuild index e277371..236617c 100644 --- a/_multibuild +++ b/_multibuild @@ -4,17 +4,20 @@ cross-aarch64-gcc13 cross-riscv64-gcc13-bootstrap cross-riscv64-gcc13 +cross-s390x-gcc13-bootstrap +cross-s390x-gcc13 +cross-ppc64le-gcc13-bootstrap +cross-ppc64le-gcc13 +cross-x86_64-gcc13-bootstrap +cross-x86_64-gcc13 cross-arm-gcc13 cross-avr-gcc13-bootstrap cross-avr-gcc13 cross-pru-gcc13-bootstrap cross-pru-gcc13 -cross-x86_64-gcc13 -cross-s390x-gcc13 cross-sparc-gcc13 cross-sparc64-gcc13 cross-ppc64-gcc13 -cross-ppc64le-gcc13 cross-m68k-gcc13 cross-mips-gcc13 cross-hppa-gcc13-bootstrap diff --git a/change_spec b/change_spec index 728107a..0cbceb7 100644 --- a/change_spec +++ b/change_spec @@ -100,16 +100,16 @@ add_glibc_cross() { if test "$do_crosses" = 1 ; then add_glibc_cross cross-aarch64-gcc$base_ver aarch64 aarch64-suse-linux add_glibc_cross cross-riscv64-gcc$base_ver riscv64 riscv64-suse-linux +add_glibc_cross cross-s390x-gcc$base_ver s390x s390x-suse-linux +add_glibc_cross cross-ppc64le-gcc$base_ver ppc64le ppc64le-suse-linux +add_glibc_cross cross-x86_64-gcc$base_ver x86_64 x86_64-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_newlib_cross cross-pru-gcc$base_ver pru pru -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 add_cross cross-sparc64-gcc$base_ver sparc64 sparc64-suse-linux %define gcc_icecream 1 add_cross cross-ppc64-gcc$base_ver ppc64 powerpc64-suse-linux %define gcc_icecream 1 -add_cross cross-ppc64le-gcc$base_ver ppc64le powerpc64le-suse-linux %define gcc_icecream 1 add_cross cross-m68k-gcc$base_ver m68k m68k-suse-linux %define gcc_icecream 1 add_cross cross-mips-gcc$base_ver mips mips-suse-linux %define gcc_icecream 1 add_cross cross-hppa-gcc$base_ver-bootstrap hppa hppa-suse-linux %define gcc_libc_bootstrap 1 diff --git a/cross-ppc64le-gcc13-bootstrap.spec b/cross-ppc64le-gcc13-bootstrap.spec new file mode 100644 index 0000000..a9d65cd --- /dev/null +++ b/cross-ppc64le-gcc13-bootstrap.spec @@ -0,0 +1,1056 @@ +# +# spec file +# +# Copyright (c) 2023 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-ppc64le-gcc13-bootstrap +%define cross_arch ppc64le +%define gcc_target_arch ppc64le-suse-linux +%define gcc_libc_bootstrap 1 +# nospeccleaner + +%define build_cp 0%{!?gcc_accel:1} +%if 0%{?gcc_libc_bootstrap:1} || "%{cross_arch}" == "bpf" +%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 build_rust 0 +%define build_m2 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" || "%{binutils_target}" == "pru" +%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 "%{binutils_target}" == "bpf" +%define binutils_os %{canonical_target}-none +%else +%if 0%{?gcc_accel:1} +%define binutils_os %{gcc_target_arch} +%else +%define binutils_os %{canonical_target}-suse-linux +%endif +%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: 13.2.1+git7683 +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 -13 +%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: gcc13-rpmlintrc +Source3: gcc13-testresults-rpmlintrc +Source4: README.First-for.SuSE.packagers +Source5: newlib-4.3.0.20230120.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 +Patch21: gdcflags.patch +# A set of patches from the RH srpm +Patch51: gcc41-ppc32-retaddr.patch +# Some patches taken from Debian +Patch60: gcc44-textdomain.patch +Patch61: gcc44-rename-info-files.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 +%if %{with limitbuild} +BuildRequires: memory-constraints +%endif +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 +%if %{suse_version} < 1550 +BuildRequires: llvm13 +%else +BuildRequires: llvm +%endif +BuildRequires: lld +%if %{suse_version} < 1550 +Requires: llvm13 +%else +Requires: llvm +%endif +Requires: cross-amdgcn-newlib-devel >= %{version}-%{release} +Requires: lld +# 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 ppc64 x86_64 s390x aarch64 riscv64 +%if "%{cross_arch}" == "pru" +ExclusiveArch: %arm +%endif +%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}%{?gcc_target_glibc: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}-gcc13 +%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-gcc13 +%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 + +%if 0%{suse_version} >= 1500 +# Synchronize output by lines, useful for configure output +%define make_output_sync -Oline +%endif + +%prep +%if 0%{?nvptx_newlib:1}%{?amdgcn_newlib:1} +%setup -q -n gcc-%{version} -a 5 +ln -s newlib-4.3.0.20230120/newlib . +%else +%setup -q -n gcc-%{version} +%endif + +#test patching start + +%patch2 +%patch5 +%patch6 +%patch7 +%patch11 +%patch15 +%patch16 +%patch17 -p1 +# These patches are needed only for llvm11 +%if "%{TARGET_ARCH}" == "amdgcn" && %{suse_version} < 1550 +%patch18 -p1 +%patch20 -p1 +%endif +# In SLE15 and earlier default to dwarf4, not dwarf5 +%if %{suse_version} < 1550 +%patch19 -p1 +%endif +%patch21 -p1 +%patch51 +%patch60 -p1 +%patch61 -p1 + +#test patching end + +%build +%if %{with limitbuild} +%limit_build -m 900 +%endif +%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} +# Filter out unwanted flags from $RPM_OPT_FLAGS +optflags= +optflags_d= +for flag in $RPM_OPT_FLAGS; do + add_flag= + case $flag in + -U_FORTIFY_SOURCE|-D_FORTIFY_SOURCE=*) ;; + -fno-rtti|-fno-exceptions|-Wmissing-format-attribute|-fstack-protector*) ;; + -ffortify=*|-Wall|-m32|-m64) ;; +%ifarch %ix86 + # -mcpu is superseded 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 superseded by proper + # default compiler settings now. + -mcpu=i?86|-march=i?86|-mtune=i?86) ;; +%endif +%ifarch s390 s390x + -fsigned-char) ;; + -O1) add_flag=-O2 ;; +%endif +%if 0%{?gcc_target_arch:1} + # Kill all -march/tune/cpu because that screws building the target libs + -march=*|-mtune=*|-mcpu=*) ;; +%endif + *) add_flag=$flag ;; + esac + if test -n "$add_flag"; then + optflags+=" $add_flag" + case $add_flag in + # Filter out -Werror=return-type for D (only valid for C and C++) + -Werror=return-type) ;; + *) optflags_d+=" $add_flag" ;; + esac + fi +done + +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 +%if %{build_rust} +languages=$languages,rust +%endif +%if %{build_m2} +languages=$languages,m2 +%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 + +%if %{build_d} && %{suse_version} < 1550 +# We are using gcc11-d to bootstrap d +export GDC=gdc-11 +%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 + +../configure \ + CFLAGS="$optflags" \ + CXXFLAGS="$optflags" \ + XCFLAGS="$optflags" \ + TCFLAGS="$optflags" \ + GDCFLAGS="$optflags_d" \ + --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 + --enable-offload-defaulted \ +%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} \ + --with-libstdcxx-zoneinfo=%{_datadir}/zoneinfo \ + --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}" == "bpf" + --disable-gcov \ +%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-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}" == "armv6hl" || "%{TARGET_ARCH}" == "arm" + --with-cpu=arm1176jzf-s \ + --with-float=hard \ + --with-abi=aapcs-linux \ + --with-fpu=vfpv2 \ + --disable-sjlj-exceptions \ +%endif +%if "%{TARGET_ARCH}" == "armv7hl" + --with-cpu=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}" == "powerpc64le" +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-cpu=power9 \ + --with-tune=power9 \ +%else +%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 +%endif +%if %{suse_version} > 1500 + --with-long-double-format=ieee \ +%else + --with-long-double-format=ibm \ +%endif + --enable-secureplt \ + --with-long-double-128 \ + --enable-targets=powerpcle-linux \ + --disable-multilib \ +%endif +%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64" +%if "%{TARGET_ARCH}" == "powerpc" + --with-cpu=default32 \ +%endif + --with-cpu-64=power4 \ + --enable-secureplt \ + --with-long-double-128 \ +%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 %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch-32=x86-64-v2 \ +%else +%if 0%{?sle_version:%sle_version} >= 150000 + --with-arch-32=x86-64 \ +%else + --with-arch-32=i586 \ +%endif +%endif + --with-tune=generic \ +%endif +%if "%{TARGET_ARCH}" == "x86_64" +%ifnarch %{disable_multilib_arch} + --enable-multilib \ +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch-32=x86-64-v2 \ +%else + --with-arch-32=x86-64 \ +%endif +%endif +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch=x86-64-v2 \ +%endif + --with-tune=generic \ +%endif +%if "%{TARGET_ARCH}" == "s390" +%if %{suse_version} >= 1600 + --with-tune=zEC12 --with-arch=z196 \ +%else +%if %{suse_version} >= 1310 + --with-tune=zEC12 --with-arch=z196 \ +%else + --with-tune=z9-109 --with-arch=z900 \ +%endif +%endif + --with-long-double-128 \ + --enable-decimal-float \ +%endif +%if "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 + --with-tune=zEC12 --with-arch=z196 \ +%else +%if %{suse_version} >= 1310 + --with-tune=zEC12 --with-arch=z196 \ +%else + --with-tune=z9-109 --with-arch=z900 \ +%endif +%endif + --with-long-double-128 \ + --enable-decimal-float \ +%endif +%if "%{TARGET_ARCH}" == "m68k" + --disable-multilib \ +%endif +%if "%{TARGET_ARCH}" == "riscv64" + --disable-multilib \ +%endif +%if %{with bootstrap} +%if %{use_lto_bootstrap} && !0%{?building_testsuite:1} + --with-build-config=bootstrap-lto-lean \ +%endif +%else + --disable-bootstrap \ +%endif + --enable-link-serialization \ + $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 %{?make_output_sync} %{?_smp_mflags} +%else +make %{?make_output_sync} %{?_smp_mflags} all-host +%endif + +%if 0%{?gcc_icecream:%gcc_icecream} +%package -n cross-%cross_arch-gcc13-icecream-backend +Summary: Icecream backend for the GNU C Compiler +Group: Development/Languages/C and C++ + +%description -n cross-%cross_arch-gcc13-icecream-backend +This package contains the icecream environment for the GNU C Compiler +%endif + +%if 0%{?nvptx_newlib:1} +%package -n cross-nvptx-newlib13-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-newlib13-devel +Newlib development files for the nvptx offload target compiler. +%endif + +%if 0%{?amdgcn_newlib:1} +%package -n cross-amdgcn-newlib13-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-newlib13-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} && "%{cross_arch}" != "bpf" + 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} 13 \ + --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 +%if 0%{!?gcc_libc_bootstrap:1} && "%{cross_arch}" != "bpf" + --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 + --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} + +%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} && "%{cross_arch}" != "bpf" +%{_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} && "%{cross_arch}" != "bpf" +%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-gcc13-icecream-backend +%defattr(-,root,root) +/usr/share/icecream-envs +%endif + +%if 0%{?nvptx_newlib:1} +%files -n cross-nvptx-newlib13-devel +%defattr(-,root,root) +%{_prefix}/%{gcc_target_arch} +%endif + +%if 0%{?amdgcn_newlib:1} +%files -n cross-amdgcn-newlib13-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-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index 69744d1..d7f2e64 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -18,8 +18,8 @@ %define pkgname cross-ppc64le-gcc13 %define cross_arch ppc64le -%define gcc_target_arch powerpc64le-suse-linux -%define gcc_icecream 1 +%define gcc_target_arch ppc64le-suse-linux +%define gcc_target_glibc 1 # nospeccleaner %define build_cp 0%{!?gcc_accel:1} diff --git a/cross-s390x-gcc13-bootstrap.spec b/cross-s390x-gcc13-bootstrap.spec new file mode 100644 index 0000000..78bc233 --- /dev/null +++ b/cross-s390x-gcc13-bootstrap.spec @@ -0,0 +1,1056 @@ +# +# spec file +# +# Copyright (c) 2023 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-s390x-gcc13-bootstrap +%define cross_arch s390x +%define gcc_target_arch s390x-suse-linux +%define gcc_libc_bootstrap 1 +# nospeccleaner + +%define build_cp 0%{!?gcc_accel:1} +%if 0%{?gcc_libc_bootstrap:1} || "%{cross_arch}" == "bpf" +%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 build_rust 0 +%define build_m2 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" || "%{binutils_target}" == "pru" +%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 "%{binutils_target}" == "bpf" +%define binutils_os %{canonical_target}-none +%else +%if 0%{?gcc_accel:1} +%define binutils_os %{gcc_target_arch} +%else +%define binutils_os %{canonical_target}-suse-linux +%endif +%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: 13.2.1+git7683 +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 -13 +%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: gcc13-rpmlintrc +Source3: gcc13-testresults-rpmlintrc +Source4: README.First-for.SuSE.packagers +Source5: newlib-4.3.0.20230120.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 +Patch21: gdcflags.patch +# A set of patches from the RH srpm +Patch51: gcc41-ppc32-retaddr.patch +# Some patches taken from Debian +Patch60: gcc44-textdomain.patch +Patch61: gcc44-rename-info-files.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 +%if %{with limitbuild} +BuildRequires: memory-constraints +%endif +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 +%if %{suse_version} < 1550 +BuildRequires: llvm13 +%else +BuildRequires: llvm +%endif +BuildRequires: lld +%if %{suse_version} < 1550 +Requires: llvm13 +%else +Requires: llvm +%endif +Requires: cross-amdgcn-newlib-devel >= %{version}-%{release} +Requires: lld +# 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 aarch64 riscv64 +%if "%{cross_arch}" == "pru" +ExclusiveArch: %arm +%endif +%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}%{?gcc_target_glibc: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}-gcc13 +%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-gcc13 +%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 + +%if 0%{suse_version} >= 1500 +# Synchronize output by lines, useful for configure output +%define make_output_sync -Oline +%endif + +%prep +%if 0%{?nvptx_newlib:1}%{?amdgcn_newlib:1} +%setup -q -n gcc-%{version} -a 5 +ln -s newlib-4.3.0.20230120/newlib . +%else +%setup -q -n gcc-%{version} +%endif + +#test patching start + +%patch2 +%patch5 +%patch6 +%patch7 +%patch11 +%patch15 +%patch16 +%patch17 -p1 +# These patches are needed only for llvm11 +%if "%{TARGET_ARCH}" == "amdgcn" && %{suse_version} < 1550 +%patch18 -p1 +%patch20 -p1 +%endif +# In SLE15 and earlier default to dwarf4, not dwarf5 +%if %{suse_version} < 1550 +%patch19 -p1 +%endif +%patch21 -p1 +%patch51 +%patch60 -p1 +%patch61 -p1 + +#test patching end + +%build +%if %{with limitbuild} +%limit_build -m 900 +%endif +%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} +# Filter out unwanted flags from $RPM_OPT_FLAGS +optflags= +optflags_d= +for flag in $RPM_OPT_FLAGS; do + add_flag= + case $flag in + -U_FORTIFY_SOURCE|-D_FORTIFY_SOURCE=*) ;; + -fno-rtti|-fno-exceptions|-Wmissing-format-attribute|-fstack-protector*) ;; + -ffortify=*|-Wall|-m32|-m64) ;; +%ifarch %ix86 + # -mcpu is superseded 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 superseded by proper + # default compiler settings now. + -mcpu=i?86|-march=i?86|-mtune=i?86) ;; +%endif +%ifarch s390 s390x + -fsigned-char) ;; + -O1) add_flag=-O2 ;; +%endif +%if 0%{?gcc_target_arch:1} + # Kill all -march/tune/cpu because that screws building the target libs + -march=*|-mtune=*|-mcpu=*) ;; +%endif + *) add_flag=$flag ;; + esac + if test -n "$add_flag"; then + optflags+=" $add_flag" + case $add_flag in + # Filter out -Werror=return-type for D (only valid for C and C++) + -Werror=return-type) ;; + *) optflags_d+=" $add_flag" ;; + esac + fi +done + +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 +%if %{build_rust} +languages=$languages,rust +%endif +%if %{build_m2} +languages=$languages,m2 +%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 + +%if %{build_d} && %{suse_version} < 1550 +# We are using gcc11-d to bootstrap d +export GDC=gdc-11 +%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 + +../configure \ + CFLAGS="$optflags" \ + CXXFLAGS="$optflags" \ + XCFLAGS="$optflags" \ + TCFLAGS="$optflags" \ + GDCFLAGS="$optflags_d" \ + --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 + --enable-offload-defaulted \ +%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} \ + --with-libstdcxx-zoneinfo=%{_datadir}/zoneinfo \ + --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}" == "bpf" + --disable-gcov \ +%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-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}" == "armv6hl" || "%{TARGET_ARCH}" == "arm" + --with-cpu=arm1176jzf-s \ + --with-float=hard \ + --with-abi=aapcs-linux \ + --with-fpu=vfpv2 \ + --disable-sjlj-exceptions \ +%endif +%if "%{TARGET_ARCH}" == "armv7hl" + --with-cpu=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}" == "powerpc64le" +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-cpu=power9 \ + --with-tune=power9 \ +%else +%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 +%endif +%if %{suse_version} > 1500 + --with-long-double-format=ieee \ +%else + --with-long-double-format=ibm \ +%endif + --enable-secureplt \ + --with-long-double-128 \ + --enable-targets=powerpcle-linux \ + --disable-multilib \ +%endif +%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64" +%if "%{TARGET_ARCH}" == "powerpc" + --with-cpu=default32 \ +%endif + --with-cpu-64=power4 \ + --enable-secureplt \ + --with-long-double-128 \ +%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 %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch-32=x86-64-v2 \ +%else +%if 0%{?sle_version:%sle_version} >= 150000 + --with-arch-32=x86-64 \ +%else + --with-arch-32=i586 \ +%endif +%endif + --with-tune=generic \ +%endif +%if "%{TARGET_ARCH}" == "x86_64" +%ifnarch %{disable_multilib_arch} + --enable-multilib \ +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch-32=x86-64-v2 \ +%else + --with-arch-32=x86-64 \ +%endif +%endif +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch=x86-64-v2 \ +%endif + --with-tune=generic \ +%endif +%if "%{TARGET_ARCH}" == "s390" +%if %{suse_version} >= 1600 + --with-tune=zEC12 --with-arch=z196 \ +%else +%if %{suse_version} >= 1310 + --with-tune=zEC12 --with-arch=z196 \ +%else + --with-tune=z9-109 --with-arch=z900 \ +%endif +%endif + --with-long-double-128 \ + --enable-decimal-float \ +%endif +%if "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 + --with-tune=zEC12 --with-arch=z196 \ +%else +%if %{suse_version} >= 1310 + --with-tune=zEC12 --with-arch=z196 \ +%else + --with-tune=z9-109 --with-arch=z900 \ +%endif +%endif + --with-long-double-128 \ + --enable-decimal-float \ +%endif +%if "%{TARGET_ARCH}" == "m68k" + --disable-multilib \ +%endif +%if "%{TARGET_ARCH}" == "riscv64" + --disable-multilib \ +%endif +%if %{with bootstrap} +%if %{use_lto_bootstrap} && !0%{?building_testsuite:1} + --with-build-config=bootstrap-lto-lean \ +%endif +%else + --disable-bootstrap \ +%endif + --enable-link-serialization \ + $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 %{?make_output_sync} %{?_smp_mflags} +%else +make %{?make_output_sync} %{?_smp_mflags} all-host +%endif + +%if 0%{?gcc_icecream:%gcc_icecream} +%package -n cross-%cross_arch-gcc13-icecream-backend +Summary: Icecream backend for the GNU C Compiler +Group: Development/Languages/C and C++ + +%description -n cross-%cross_arch-gcc13-icecream-backend +This package contains the icecream environment for the GNU C Compiler +%endif + +%if 0%{?nvptx_newlib:1} +%package -n cross-nvptx-newlib13-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-newlib13-devel +Newlib development files for the nvptx offload target compiler. +%endif + +%if 0%{?amdgcn_newlib:1} +%package -n cross-amdgcn-newlib13-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-newlib13-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} && "%{cross_arch}" != "bpf" + 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} 13 \ + --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 +%if 0%{!?gcc_libc_bootstrap:1} && "%{cross_arch}" != "bpf" + --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 + --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} + +%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} && "%{cross_arch}" != "bpf" +%{_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} && "%{cross_arch}" != "bpf" +%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-gcc13-icecream-backend +%defattr(-,root,root) +/usr/share/icecream-envs +%endif + +%if 0%{?nvptx_newlib:1} +%files -n cross-nvptx-newlib13-devel +%defattr(-,root,root) +%{_prefix}/%{gcc_target_arch} +%endif + +%if 0%{?amdgcn_newlib:1} +%files -n cross-amdgcn-newlib13-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-s390x-gcc13.spec b/cross-s390x-gcc13.spec index 39060b2..71ae0dd 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -19,7 +19,7 @@ %define pkgname cross-s390x-gcc13 %define cross_arch s390x %define gcc_target_arch s390x-suse-linux -%define gcc_icecream 1 +%define gcc_target_glibc 1 # nospeccleaner %define build_cp 0%{!?gcc_accel:1} diff --git a/cross-x86_64-gcc13-bootstrap.spec b/cross-x86_64-gcc13-bootstrap.spec new file mode 100644 index 0000000..13065e3 --- /dev/null +++ b/cross-x86_64-gcc13-bootstrap.spec @@ -0,0 +1,1056 @@ +# +# spec file +# +# Copyright (c) 2023 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-x86_64-gcc13-bootstrap +%define cross_arch x86_64 +%define gcc_target_arch x86_64-suse-linux +%define gcc_libc_bootstrap 1 +# nospeccleaner + +%define build_cp 0%{!?gcc_accel:1} +%if 0%{?gcc_libc_bootstrap:1} || "%{cross_arch}" == "bpf" +%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 build_rust 0 +%define build_m2 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" || "%{binutils_target}" == "pru" +%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 "%{binutils_target}" == "bpf" +%define binutils_os %{canonical_target}-none +%else +%if 0%{?gcc_accel:1} +%define binutils_os %{gcc_target_arch} +%else +%define binutils_os %{canonical_target}-suse-linux +%endif +%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: 13.2.1+git7683 +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 -13 +%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: gcc13-rpmlintrc +Source3: gcc13-testresults-rpmlintrc +Source4: README.First-for.SuSE.packagers +Source5: newlib-4.3.0.20230120.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 +Patch21: gdcflags.patch +# A set of patches from the RH srpm +Patch51: gcc41-ppc32-retaddr.patch +# Some patches taken from Debian +Patch60: gcc44-textdomain.patch +Patch61: gcc44-rename-info-files.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 +%if %{with limitbuild} +BuildRequires: memory-constraints +%endif +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: +%define nvptx_newlib 1 +%endif +%if "%{cross_arch}" == "amdgcn" +# amdgcn uses the llvm assembler and linker +%if %{suse_version} < 1550 +BuildRequires: llvm13 +%else +BuildRequires: llvm +%endif +BuildRequires: lld +%if %{suse_version} < 1550 +Requires: llvm13 +%else +Requires: llvm +%endif +Requires: cross-amdgcn-newlib-devel >= %{version}-%{release} +Requires: lld +# 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: +%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 s390x aarch64 riscv64 +%if "%{cross_arch}" == "pru" +ExclusiveArch: %arm +%endif +%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}%{?gcc_target_glibc: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}-gcc13 +%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-gcc13 +%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 + +%if 0%{suse_version} >= 1500 +# Synchronize output by lines, useful for configure output +%define make_output_sync -Oline +%endif + +%prep +%if 0%{?nvptx_newlib:1}%{?amdgcn_newlib:1} +%setup -q -n gcc-%{version} -a 5 +ln -s newlib-4.3.0.20230120/newlib . +%else +%setup -q -n gcc-%{version} +%endif + +#test patching start + +%patch2 +%patch5 +%patch6 +%patch7 +%patch11 +%patch15 +%patch16 +%patch17 -p1 +# These patches are needed only for llvm11 +%if "%{TARGET_ARCH}" == "amdgcn" && %{suse_version} < 1550 +%patch18 -p1 +%patch20 -p1 +%endif +# In SLE15 and earlier default to dwarf4, not dwarf5 +%if %{suse_version} < 1550 +%patch19 -p1 +%endif +%patch21 -p1 +%patch51 +%patch60 -p1 +%patch61 -p1 + +#test patching end + +%build +%if %{with limitbuild} +%limit_build -m 900 +%endif +%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} +# Filter out unwanted flags from $RPM_OPT_FLAGS +optflags= +optflags_d= +for flag in $RPM_OPT_FLAGS; do + add_flag= + case $flag in + -U_FORTIFY_SOURCE|-D_FORTIFY_SOURCE=*) ;; + -fno-rtti|-fno-exceptions|-Wmissing-format-attribute|-fstack-protector*) ;; + -ffortify=*|-Wall|-m32|-m64) ;; +%ifarch %ix86 + # -mcpu is superseded 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 superseded by proper + # default compiler settings now. + -mcpu=i?86|-march=i?86|-mtune=i?86) ;; +%endif +%ifarch s390 s390x + -fsigned-char) ;; + -O1) add_flag=-O2 ;; +%endif +%if 0%{?gcc_target_arch:1} + # Kill all -march/tune/cpu because that screws building the target libs + -march=*|-mtune=*|-mcpu=*) ;; +%endif + *) add_flag=$flag ;; + esac + if test -n "$add_flag"; then + optflags+=" $add_flag" + case $add_flag in + # Filter out -Werror=return-type for D (only valid for C and C++) + -Werror=return-type) ;; + *) optflags_d+=" $add_flag" ;; + esac + fi +done + +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 +%if %{build_rust} +languages=$languages,rust +%endif +%if %{build_m2} +languages=$languages,m2 +%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 + +%if %{build_d} && %{suse_version} < 1550 +# We are using gcc11-d to bootstrap d +export GDC=gdc-11 +%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 + +../configure \ + CFLAGS="$optflags" \ + CXXFLAGS="$optflags" \ + XCFLAGS="$optflags" \ + TCFLAGS="$optflags" \ + GDCFLAGS="$optflags_d" \ + --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 + --enable-offload-defaulted \ +%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} \ + --with-libstdcxx-zoneinfo=%{_datadir}/zoneinfo \ + --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}" == "bpf" + --disable-gcov \ +%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-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}" == "armv6hl" || "%{TARGET_ARCH}" == "arm" + --with-cpu=arm1176jzf-s \ + --with-float=hard \ + --with-abi=aapcs-linux \ + --with-fpu=vfpv2 \ + --disable-sjlj-exceptions \ +%endif +%if "%{TARGET_ARCH}" == "armv7hl" + --with-cpu=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}" == "powerpc64le" +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-cpu=power9 \ + --with-tune=power9 \ +%else +%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 +%endif +%if %{suse_version} > 1500 + --with-long-double-format=ieee \ +%else + --with-long-double-format=ibm \ +%endif + --enable-secureplt \ + --with-long-double-128 \ + --enable-targets=powerpcle-linux \ + --disable-multilib \ +%endif +%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64" +%if "%{TARGET_ARCH}" == "powerpc" + --with-cpu=default32 \ +%endif + --with-cpu-64=power4 \ + --enable-secureplt \ + --with-long-double-128 \ +%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 %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch-32=x86-64-v2 \ +%else +%if 0%{?sle_version:%sle_version} >= 150000 + --with-arch-32=x86-64 \ +%else + --with-arch-32=i586 \ +%endif +%endif + --with-tune=generic \ +%endif +%if "%{TARGET_ARCH}" == "x86_64" +%ifnarch %{disable_multilib_arch} + --enable-multilib \ +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch-32=x86-64-v2 \ +%else + --with-arch-32=x86-64 \ +%endif +%endif +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch=x86-64-v2 \ +%endif + --with-tune=generic \ +%endif +%if "%{TARGET_ARCH}" == "s390" +%if %{suse_version} >= 1600 + --with-tune=zEC12 --with-arch=z196 \ +%else +%if %{suse_version} >= 1310 + --with-tune=zEC12 --with-arch=z196 \ +%else + --with-tune=z9-109 --with-arch=z900 \ +%endif +%endif + --with-long-double-128 \ + --enable-decimal-float \ +%endif +%if "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 + --with-tune=zEC12 --with-arch=z196 \ +%else +%if %{suse_version} >= 1310 + --with-tune=zEC12 --with-arch=z196 \ +%else + --with-tune=z9-109 --with-arch=z900 \ +%endif +%endif + --with-long-double-128 \ + --enable-decimal-float \ +%endif +%if "%{TARGET_ARCH}" == "m68k" + --disable-multilib \ +%endif +%if "%{TARGET_ARCH}" == "riscv64" + --disable-multilib \ +%endif +%if %{with bootstrap} +%if %{use_lto_bootstrap} && !0%{?building_testsuite:1} + --with-build-config=bootstrap-lto-lean \ +%endif +%else + --disable-bootstrap \ +%endif + --enable-link-serialization \ + $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 %{?make_output_sync} %{?_smp_mflags} +%else +make %{?make_output_sync} %{?_smp_mflags} all-host +%endif + +%if 0%{?gcc_icecream:%gcc_icecream} +%package -n cross-%cross_arch-gcc13-icecream-backend +Summary: Icecream backend for the GNU C Compiler +Group: Development/Languages/C and C++ + +%description -n cross-%cross_arch-gcc13-icecream-backend +This package contains the icecream environment for the GNU C Compiler +%endif + +%if 0%{?nvptx_newlib:1} +%package -n cross-nvptx-newlib13-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-newlib13-devel +Newlib development files for the nvptx offload target compiler. +%endif + +%if 0%{?amdgcn_newlib:1} +%package -n cross-amdgcn-newlib13-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-newlib13-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} && "%{cross_arch}" != "bpf" + 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} 13 \ + --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 +%if 0%{!?gcc_libc_bootstrap:1} && "%{cross_arch}" != "bpf" + --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 + --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} + +%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} && "%{cross_arch}" != "bpf" +%{_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} && "%{cross_arch}" != "bpf" +%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-gcc13-icecream-backend +%defattr(-,root,root) +/usr/share/icecream-envs +%endif + +%if 0%{?nvptx_newlib:1} +%files -n cross-nvptx-newlib13-devel +%defattr(-,root,root) +%{_prefix}/%{gcc_target_arch} +%endif + +%if 0%{?amdgcn_newlib:1} +%files -n cross-amdgcn-newlib13-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-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index a07f7fb..6da8de6 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -19,7 +19,7 @@ %define pkgname cross-x86_64-gcc13 %define cross_arch x86_64 %define gcc_target_arch x86_64-suse-linux -%define gcc_icecream 1 +%define gcc_target_glibc 1 # nospeccleaner %define build_cp 0%{!?gcc_accel:1} diff --git a/gcc13.changes b/gcc13.changes index 9c11e81..8afd1ba 100644 --- a/gcc13.changes +++ b/gcc13.changes @@ -1,3 +1,9 @@ +------------------------------------------------------------------- +Tue Aug 22 10:40:59 UTC 2023 - Richard Biener + +- Turn cross compilers to x86_64, ppc64le and s390x to glibc crosses. + [bsc#1214460] + ------------------------------------------------------------------- Fri Aug 18 13:03:36 UTC 2023 - Michal Suchanek From a5d4aec7587bc9dd457330b2f4b22d309582ab5cc106522395b9e8bd2d4c0aba Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Tue, 22 Aug 2023 11:53:16 +0000 Subject: [PATCH 03/10] OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=62 --- cross-aarch64-gcc13-bootstrap.spec | 3 +++ cross-aarch64-gcc13.spec | 3 +++ cross-amdgcn-gcc13.spec | 3 +++ cross-arm-gcc13.spec | 3 +++ cross-arm-none-gcc13-bootstrap.spec | 3 +++ cross-arm-none-gcc13.spec | 3 +++ cross-avr-gcc13-bootstrap.spec | 3 +++ cross-avr-gcc13.spec | 3 +++ cross-bpf-gcc13.spec | 3 +++ cross-epiphany-gcc13-bootstrap.spec | 3 +++ cross-epiphany-gcc13.spec | 3 +++ cross-hppa-gcc13-bootstrap.spec | 3 +++ cross-hppa-gcc13.spec | 3 +++ cross-m68k-gcc13.spec | 3 +++ cross-mips-gcc13.spec | 3 +++ cross-nvptx-gcc13.spec | 3 +++ cross-ppc64-gcc13.spec | 3 +++ cross-ppc64le-gcc13-bootstrap.spec | 3 +++ cross-ppc64le-gcc13.spec | 3 +++ cross-pru-gcc13-bootstrap.spec | 3 +++ cross-pru-gcc13.spec | 3 +++ cross-riscv64-elf-gcc13-bootstrap.spec | 3 +++ cross-riscv64-elf-gcc13.spec | 3 +++ cross-riscv64-gcc13-bootstrap.spec | 3 +++ cross-riscv64-gcc13.spec | 3 +++ cross-rx-gcc13-bootstrap.spec | 3 +++ cross-rx-gcc13.spec | 3 +++ cross-s390x-gcc13-bootstrap.spec | 3 +++ cross-s390x-gcc13.spec | 3 +++ cross-sparc-gcc13.spec | 3 +++ cross-sparc64-gcc13.spec | 3 +++ cross-x86_64-gcc13-bootstrap.spec | 3 +++ cross-x86_64-gcc13.spec | 3 +++ gcc.spec.in | 3 +++ gcc13-testresults.spec | 3 +++ gcc13.spec | 3 +++ 36 files changed, 108 insertions(+) diff --git a/cross-aarch64-gcc13-bootstrap.spec b/cross-aarch64-gcc13-bootstrap.spec index bba35af..70da9d9 100644 --- a/cross-aarch64-gcc13-bootstrap.spec +++ b/cross-aarch64-gcc13-bootstrap.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-aarch64-gcc13.spec b/cross-aarch64-gcc13.spec index 57981df..4a590b3 100644 --- a/cross-aarch64-gcc13.spec +++ b/cross-aarch64-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-amdgcn-gcc13.spec b/cross-amdgcn-gcc13.spec index 76d6e1f..4405751 100644 --- a/cross-amdgcn-gcc13.spec +++ b/cross-amdgcn-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-arm-gcc13.spec b/cross-arm-gcc13.spec index 0b0756d..df29f87 100644 --- a/cross-arm-gcc13.spec +++ b/cross-arm-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-arm-none-gcc13-bootstrap.spec b/cross-arm-none-gcc13-bootstrap.spec index 8c05a7a..d03b963 100644 --- a/cross-arm-none-gcc13-bootstrap.spec +++ b/cross-arm-none-gcc13-bootstrap.spec @@ -746,6 +746,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-arm-none-gcc13.spec b/cross-arm-none-gcc13.spec index 2962f8e..289a587 100644 --- a/cross-arm-none-gcc13.spec +++ b/cross-arm-none-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-avr-gcc13-bootstrap.spec b/cross-avr-gcc13-bootstrap.spec index c81fce3..68c8591 100644 --- a/cross-avr-gcc13-bootstrap.spec +++ b/cross-avr-gcc13-bootstrap.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-avr-gcc13.spec b/cross-avr-gcc13.spec index a6a4a1b..1b104d5 100644 --- a/cross-avr-gcc13.spec +++ b/cross-avr-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-bpf-gcc13.spec b/cross-bpf-gcc13.spec index 18d443b..59e749e 100644 --- a/cross-bpf-gcc13.spec +++ b/cross-bpf-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-epiphany-gcc13-bootstrap.spec b/cross-epiphany-gcc13-bootstrap.spec index 41f8595..c187df8 100644 --- a/cross-epiphany-gcc13-bootstrap.spec +++ b/cross-epiphany-gcc13-bootstrap.spec @@ -746,6 +746,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-epiphany-gcc13.spec b/cross-epiphany-gcc13.spec index 16aa9ca..9141058 100644 --- a/cross-epiphany-gcc13.spec +++ b/cross-epiphany-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-hppa-gcc13-bootstrap.spec b/cross-hppa-gcc13-bootstrap.spec index a569330..4754ce2 100644 --- a/cross-hppa-gcc13-bootstrap.spec +++ b/cross-hppa-gcc13-bootstrap.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-hppa-gcc13.spec b/cross-hppa-gcc13.spec index 7ec2552..fef80c9 100644 --- a/cross-hppa-gcc13.spec +++ b/cross-hppa-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-m68k-gcc13.spec b/cross-m68k-gcc13.spec index cf13568..5cf1b6d 100644 --- a/cross-m68k-gcc13.spec +++ b/cross-m68k-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-mips-gcc13.spec b/cross-mips-gcc13.spec index c74f3db..98c865e 100644 --- a/cross-mips-gcc13.spec +++ b/cross-mips-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-nvptx-gcc13.spec b/cross-nvptx-gcc13.spec index e49a436..99894e1 100644 --- a/cross-nvptx-gcc13.spec +++ b/cross-nvptx-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-ppc64-gcc13.spec b/cross-ppc64-gcc13.spec index 786697c..f6a6f10 100644 --- a/cross-ppc64-gcc13.spec +++ b/cross-ppc64-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-ppc64le-gcc13-bootstrap.spec b/cross-ppc64le-gcc13-bootstrap.spec index a9d65cd..3223c31 100644 --- a/cross-ppc64le-gcc13-bootstrap.spec +++ b/cross-ppc64le-gcc13-bootstrap.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index d7f2e64..c907e94 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-pru-gcc13-bootstrap.spec b/cross-pru-gcc13-bootstrap.spec index b779e79..0891bc4 100644 --- a/cross-pru-gcc13-bootstrap.spec +++ b/cross-pru-gcc13-bootstrap.spec @@ -746,6 +746,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-pru-gcc13.spec b/cross-pru-gcc13.spec index e2a331b..fbca31f 100644 --- a/cross-pru-gcc13.spec +++ b/cross-pru-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-riscv64-elf-gcc13-bootstrap.spec b/cross-riscv64-elf-gcc13-bootstrap.spec index b3e1174..8024bca 100644 --- a/cross-riscv64-elf-gcc13-bootstrap.spec +++ b/cross-riscv64-elf-gcc13-bootstrap.spec @@ -746,6 +746,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-riscv64-elf-gcc13.spec b/cross-riscv64-elf-gcc13.spec index a8fe782..4e21cf4 100644 --- a/cross-riscv64-elf-gcc13.spec +++ b/cross-riscv64-elf-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-riscv64-gcc13-bootstrap.spec b/cross-riscv64-gcc13-bootstrap.spec index 54f21ac..52b78c6 100644 --- a/cross-riscv64-gcc13-bootstrap.spec +++ b/cross-riscv64-gcc13-bootstrap.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-riscv64-gcc13.spec b/cross-riscv64-gcc13.spec index 1e0a0eb..0879c01 100644 --- a/cross-riscv64-gcc13.spec +++ b/cross-riscv64-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-rx-gcc13-bootstrap.spec b/cross-rx-gcc13-bootstrap.spec index 7c8fcf2..cb79fa6 100644 --- a/cross-rx-gcc13-bootstrap.spec +++ b/cross-rx-gcc13-bootstrap.spec @@ -746,6 +746,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-rx-gcc13.spec b/cross-rx-gcc13.spec index 81fa215..6bc9c38 100644 --- a/cross-rx-gcc13.spec +++ b/cross-rx-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-s390x-gcc13-bootstrap.spec b/cross-s390x-gcc13-bootstrap.spec index 78bc233..28290bc 100644 --- a/cross-s390x-gcc13-bootstrap.spec +++ b/cross-s390x-gcc13-bootstrap.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-s390x-gcc13.spec b/cross-s390x-gcc13.spec index 71ae0dd..0dea949 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-sparc-gcc13.spec b/cross-sparc-gcc13.spec index c5cb8d5..0f0378f 100644 --- a/cross-sparc-gcc13.spec +++ b/cross-sparc-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-sparc64-gcc13.spec b/cross-sparc64-gcc13.spec index a49983b..b5c8a9b 100644 --- a/cross-sparc64-gcc13.spec +++ b/cross-sparc64-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-x86_64-gcc13-bootstrap.spec b/cross-x86_64-gcc13-bootstrap.spec index 13065e3..dd0cd82 100644 --- a/cross-x86_64-gcc13-bootstrap.spec +++ b/cross-x86_64-gcc13-bootstrap.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/cross-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index 6da8de6..005a954 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -745,6 +745,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/gcc.spec.in b/gcc.spec.in index f3d7175..16b6be4 100644 --- a/gcc.spec.in +++ b/gcc.spec.in @@ -1756,6 +1756,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/gcc13-testresults.spec b/gcc13-testresults.spec index f22a155..9361b58 100644 --- a/gcc13-testresults.spec +++ b/gcc13-testresults.spec @@ -947,6 +947,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ diff --git a/gcc13.spec b/gcc13.spec index 418fcbc..fa477db 100644 --- a/gcc13.spec +++ b/gcc13.spec @@ -2764,6 +2764,9 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ +%if %{?cross_arch:1} + --disable-multilib \ +%endif %endif %if "%{TARGET_ARCH}" == "m68k" --disable-multilib \ From b18fc9566ec64c1263f29735be1c047ef5207e2803940e592f816b4fb3610403 Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Wed, 23 Aug 2023 06:54:05 +0000 Subject: [PATCH 04/10] - Turn cross compiler to s390x to a glibc cross. [bsc#1214460] OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=63 --- _multibuild | 6 +- change_spec | 4 +- cross-ppc64le-gcc13-bootstrap.spec | 1059 ---------------------------- cross-ppc64le-gcc13.spec | 4 +- cross-x86_64-gcc13-bootstrap.spec | 1059 ---------------------------- cross-x86_64-gcc13.spec | 2 +- gcc13.changes | 5 +- 7 files changed, 9 insertions(+), 2130 deletions(-) delete mode 100644 cross-ppc64le-gcc13-bootstrap.spec delete mode 100644 cross-x86_64-gcc13-bootstrap.spec diff --git a/_multibuild b/_multibuild index 236617c..30793d7 100644 --- a/_multibuild +++ b/_multibuild @@ -6,18 +6,16 @@ cross-riscv64-gcc13 cross-s390x-gcc13-bootstrap cross-s390x-gcc13 -cross-ppc64le-gcc13-bootstrap -cross-ppc64le-gcc13 -cross-x86_64-gcc13-bootstrap -cross-x86_64-gcc13 cross-arm-gcc13 cross-avr-gcc13-bootstrap cross-avr-gcc13 cross-pru-gcc13-bootstrap cross-pru-gcc13 +cross-x86_64-gcc13 cross-sparc-gcc13 cross-sparc64-gcc13 cross-ppc64-gcc13 +cross-ppc64le-gcc13 cross-m68k-gcc13 cross-mips-gcc13 cross-hppa-gcc13-bootstrap diff --git a/change_spec b/change_spec index 0cbceb7..cdbc5bc 100644 --- a/change_spec +++ b/change_spec @@ -101,15 +101,15 @@ if test "$do_crosses" = 1 ; then add_glibc_cross cross-aarch64-gcc$base_ver aarch64 aarch64-suse-linux add_glibc_cross cross-riscv64-gcc$base_ver riscv64 riscv64-suse-linux add_glibc_cross cross-s390x-gcc$base_ver s390x s390x-suse-linux -add_glibc_cross cross-ppc64le-gcc$base_ver ppc64le ppc64le-suse-linux -add_glibc_cross cross-x86_64-gcc$base_ver x86_64 x86_64-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_newlib_cross cross-pru-gcc$base_ver pru pru +add_cross cross-x86_64-gcc$base_ver x86_64 x86_64-suse-linux %define gcc_icecream 1 add_cross cross-sparc-gcc$base_ver sparcv9 sparc-suse-linux %define gcc_icecream 1 add_cross cross-sparc64-gcc$base_ver sparc64 sparc64-suse-linux %define gcc_icecream 1 add_cross cross-ppc64-gcc$base_ver ppc64 powerpc64-suse-linux %define gcc_icecream 1 +add_cross cross-ppc64le-gcc$base_ver ppc64le powerpc64le-suse-linux %define gcc_icecream 1 add_cross cross-m68k-gcc$base_ver m68k m68k-suse-linux %define gcc_icecream 1 add_cross cross-mips-gcc$base_ver mips mips-suse-linux %define gcc_icecream 1 add_cross cross-hppa-gcc$base_ver-bootstrap hppa hppa-suse-linux %define gcc_libc_bootstrap 1 diff --git a/cross-ppc64le-gcc13-bootstrap.spec b/cross-ppc64le-gcc13-bootstrap.spec deleted file mode 100644 index 3223c31..0000000 --- a/cross-ppc64le-gcc13-bootstrap.spec +++ /dev/null @@ -1,1059 +0,0 @@ -# -# spec file -# -# Copyright (c) 2023 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-ppc64le-gcc13-bootstrap -%define cross_arch ppc64le -%define gcc_target_arch ppc64le-suse-linux -%define gcc_libc_bootstrap 1 -# nospeccleaner - -%define build_cp 0%{!?gcc_accel:1} -%if 0%{?gcc_libc_bootstrap:1} || "%{cross_arch}" == "bpf" -%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 build_rust 0 -%define build_m2 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" || "%{binutils_target}" == "pru" -%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 "%{binutils_target}" == "bpf" -%define binutils_os %{canonical_target}-none -%else -%if 0%{?gcc_accel:1} -%define binutils_os %{gcc_target_arch} -%else -%define binutils_os %{canonical_target}-suse-linux -%endif -%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: 13.2.1+git7683 -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 -13 -%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: gcc13-rpmlintrc -Source3: gcc13-testresults-rpmlintrc -Source4: README.First-for.SuSE.packagers -Source5: newlib-4.3.0.20230120.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 -Patch21: gdcflags.patch -# A set of patches from the RH srpm -Patch51: gcc41-ppc32-retaddr.patch -# Some patches taken from Debian -Patch60: gcc44-textdomain.patch -Patch61: gcc44-rename-info-files.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 -%if %{with limitbuild} -BuildRequires: memory-constraints -%endif -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 -%if %{suse_version} < 1550 -BuildRequires: llvm13 -%else -BuildRequires: llvm -%endif -BuildRequires: lld -%if %{suse_version} < 1550 -Requires: llvm13 -%else -Requires: llvm -%endif -Requires: cross-amdgcn-newlib-devel >= %{version}-%{release} -Requires: lld -# 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 ppc64 x86_64 s390x aarch64 riscv64 -%if "%{cross_arch}" == "pru" -ExclusiveArch: %arm -%endif -%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}%{?gcc_target_glibc: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}-gcc13 -%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-gcc13 -%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 - -%if 0%{suse_version} >= 1500 -# Synchronize output by lines, useful for configure output -%define make_output_sync -Oline -%endif - -%prep -%if 0%{?nvptx_newlib:1}%{?amdgcn_newlib:1} -%setup -q -n gcc-%{version} -a 5 -ln -s newlib-4.3.0.20230120/newlib . -%else -%setup -q -n gcc-%{version} -%endif - -#test patching start - -%patch2 -%patch5 -%patch6 -%patch7 -%patch11 -%patch15 -%patch16 -%patch17 -p1 -# These patches are needed only for llvm11 -%if "%{TARGET_ARCH}" == "amdgcn" && %{suse_version} < 1550 -%patch18 -p1 -%patch20 -p1 -%endif -# In SLE15 and earlier default to dwarf4, not dwarf5 -%if %{suse_version} < 1550 -%patch19 -p1 -%endif -%patch21 -p1 -%patch51 -%patch60 -p1 -%patch61 -p1 - -#test patching end - -%build -%if %{with limitbuild} -%limit_build -m 900 -%endif -%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} -# Filter out unwanted flags from $RPM_OPT_FLAGS -optflags= -optflags_d= -for flag in $RPM_OPT_FLAGS; do - add_flag= - case $flag in - -U_FORTIFY_SOURCE|-D_FORTIFY_SOURCE=*) ;; - -fno-rtti|-fno-exceptions|-Wmissing-format-attribute|-fstack-protector*) ;; - -ffortify=*|-Wall|-m32|-m64) ;; -%ifarch %ix86 - # -mcpu is superseded 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 superseded by proper - # default compiler settings now. - -mcpu=i?86|-march=i?86|-mtune=i?86) ;; -%endif -%ifarch s390 s390x - -fsigned-char) ;; - -O1) add_flag=-O2 ;; -%endif -%if 0%{?gcc_target_arch:1} - # Kill all -march/tune/cpu because that screws building the target libs - -march=*|-mtune=*|-mcpu=*) ;; -%endif - *) add_flag=$flag ;; - esac - if test -n "$add_flag"; then - optflags+=" $add_flag" - case $add_flag in - # Filter out -Werror=return-type for D (only valid for C and C++) - -Werror=return-type) ;; - *) optflags_d+=" $add_flag" ;; - esac - fi -done - -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 -%if %{build_rust} -languages=$languages,rust -%endif -%if %{build_m2} -languages=$languages,m2 -%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 - -%if %{build_d} && %{suse_version} < 1550 -# We are using gcc11-d to bootstrap d -export GDC=gdc-11 -%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 - -../configure \ - CFLAGS="$optflags" \ - CXXFLAGS="$optflags" \ - XCFLAGS="$optflags" \ - TCFLAGS="$optflags" \ - GDCFLAGS="$optflags_d" \ - --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 - --enable-offload-defaulted \ -%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} \ - --with-libstdcxx-zoneinfo=%{_datadir}/zoneinfo \ - --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}" == "bpf" - --disable-gcov \ -%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-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}" == "armv6hl" || "%{TARGET_ARCH}" == "arm" - --with-cpu=arm1176jzf-s \ - --with-float=hard \ - --with-abi=aapcs-linux \ - --with-fpu=vfpv2 \ - --disable-sjlj-exceptions \ -%endif -%if "%{TARGET_ARCH}" == "armv7hl" - --with-cpu=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}" == "powerpc64le" -%if %{suse_version} >= 1600 && !0%{?is_opensuse} - --with-cpu=power9 \ - --with-tune=power9 \ -%else -%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 -%endif -%if %{suse_version} > 1500 - --with-long-double-format=ieee \ -%else - --with-long-double-format=ibm \ -%endif - --enable-secureplt \ - --with-long-double-128 \ - --enable-targets=powerpcle-linux \ - --disable-multilib \ -%endif -%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64" -%if "%{TARGET_ARCH}" == "powerpc" - --with-cpu=default32 \ -%endif - --with-cpu-64=power4 \ - --enable-secureplt \ - --with-long-double-128 \ -%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 %{suse_version} >= 1600 && !0%{?is_opensuse} - --with-arch-32=x86-64-v2 \ -%else -%if 0%{?sle_version:%sle_version} >= 150000 - --with-arch-32=x86-64 \ -%else - --with-arch-32=i586 \ -%endif -%endif - --with-tune=generic \ -%endif -%if "%{TARGET_ARCH}" == "x86_64" -%ifnarch %{disable_multilib_arch} - --enable-multilib \ -%if %{suse_version} >= 1600 && !0%{?is_opensuse} - --with-arch-32=x86-64-v2 \ -%else - --with-arch-32=x86-64 \ -%endif -%endif -%if %{suse_version} >= 1600 && !0%{?is_opensuse} - --with-arch=x86-64-v2 \ -%endif - --with-tune=generic \ -%endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%if %{?cross_arch:1} - --disable-multilib \ -%endif -%endif -%if "%{TARGET_ARCH}" == "m68k" - --disable-multilib \ -%endif -%if "%{TARGET_ARCH}" == "riscv64" - --disable-multilib \ -%endif -%if %{with bootstrap} -%if %{use_lto_bootstrap} && !0%{?building_testsuite:1} - --with-build-config=bootstrap-lto-lean \ -%endif -%else - --disable-bootstrap \ -%endif - --enable-link-serialization \ - $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 %{?make_output_sync} %{?_smp_mflags} -%else -make %{?make_output_sync} %{?_smp_mflags} all-host -%endif - -%if 0%{?gcc_icecream:%gcc_icecream} -%package -n cross-%cross_arch-gcc13-icecream-backend -Summary: Icecream backend for the GNU C Compiler -Group: Development/Languages/C and C++ - -%description -n cross-%cross_arch-gcc13-icecream-backend -This package contains the icecream environment for the GNU C Compiler -%endif - -%if 0%{?nvptx_newlib:1} -%package -n cross-nvptx-newlib13-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-newlib13-devel -Newlib development files for the nvptx offload target compiler. -%endif - -%if 0%{?amdgcn_newlib:1} -%package -n cross-amdgcn-newlib13-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-newlib13-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} && "%{cross_arch}" != "bpf" - 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} 13 \ - --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 -%if 0%{!?gcc_libc_bootstrap:1} && "%{cross_arch}" != "bpf" - --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 - --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} - -%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} && "%{cross_arch}" != "bpf" -%{_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} && "%{cross_arch}" != "bpf" -%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-gcc13-icecream-backend -%defattr(-,root,root) -/usr/share/icecream-envs -%endif - -%if 0%{?nvptx_newlib:1} -%files -n cross-nvptx-newlib13-devel -%defattr(-,root,root) -%{_prefix}/%{gcc_target_arch} -%endif - -%if 0%{?amdgcn_newlib:1} -%files -n cross-amdgcn-newlib13-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-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index c907e94..7e93ed0 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -18,8 +18,8 @@ %define pkgname cross-ppc64le-gcc13 %define cross_arch ppc64le -%define gcc_target_arch ppc64le-suse-linux -%define gcc_target_glibc 1 +%define gcc_target_arch powerpc64le-suse-linux +%define gcc_icecream 1 # nospeccleaner %define build_cp 0%{!?gcc_accel:1} diff --git a/cross-x86_64-gcc13-bootstrap.spec b/cross-x86_64-gcc13-bootstrap.spec deleted file mode 100644 index dd0cd82..0000000 --- a/cross-x86_64-gcc13-bootstrap.spec +++ /dev/null @@ -1,1059 +0,0 @@ -# -# spec file -# -# Copyright (c) 2023 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-x86_64-gcc13-bootstrap -%define cross_arch x86_64 -%define gcc_target_arch x86_64-suse-linux -%define gcc_libc_bootstrap 1 -# nospeccleaner - -%define build_cp 0%{!?gcc_accel:1} -%if 0%{?gcc_libc_bootstrap:1} || "%{cross_arch}" == "bpf" -%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 build_rust 0 -%define build_m2 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" || "%{binutils_target}" == "pru" -%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 "%{binutils_target}" == "bpf" -%define binutils_os %{canonical_target}-none -%else -%if 0%{?gcc_accel:1} -%define binutils_os %{gcc_target_arch} -%else -%define binutils_os %{canonical_target}-suse-linux -%endif -%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: 13.2.1+git7683 -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 -13 -%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: gcc13-rpmlintrc -Source3: gcc13-testresults-rpmlintrc -Source4: README.First-for.SuSE.packagers -Source5: newlib-4.3.0.20230120.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 -Patch21: gdcflags.patch -# A set of patches from the RH srpm -Patch51: gcc41-ppc32-retaddr.patch -# Some patches taken from Debian -Patch60: gcc44-textdomain.patch -Patch61: gcc44-rename-info-files.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 -%if %{with limitbuild} -BuildRequires: memory-constraints -%endif -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: -%define nvptx_newlib 1 -%endif -%if "%{cross_arch}" == "amdgcn" -# amdgcn uses the llvm assembler and linker -%if %{suse_version} < 1550 -BuildRequires: llvm13 -%else -BuildRequires: llvm -%endif -BuildRequires: lld -%if %{suse_version} < 1550 -Requires: llvm13 -%else -Requires: llvm -%endif -Requires: cross-amdgcn-newlib-devel >= %{version}-%{release} -Requires: lld -# 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: -%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 s390x aarch64 riscv64 -%if "%{cross_arch}" == "pru" -ExclusiveArch: %arm -%endif -%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}%{?gcc_target_glibc: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}-gcc13 -%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-gcc13 -%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 - -%if 0%{suse_version} >= 1500 -# Synchronize output by lines, useful for configure output -%define make_output_sync -Oline -%endif - -%prep -%if 0%{?nvptx_newlib:1}%{?amdgcn_newlib:1} -%setup -q -n gcc-%{version} -a 5 -ln -s newlib-4.3.0.20230120/newlib . -%else -%setup -q -n gcc-%{version} -%endif - -#test patching start - -%patch2 -%patch5 -%patch6 -%patch7 -%patch11 -%patch15 -%patch16 -%patch17 -p1 -# These patches are needed only for llvm11 -%if "%{TARGET_ARCH}" == "amdgcn" && %{suse_version} < 1550 -%patch18 -p1 -%patch20 -p1 -%endif -# In SLE15 and earlier default to dwarf4, not dwarf5 -%if %{suse_version} < 1550 -%patch19 -p1 -%endif -%patch21 -p1 -%patch51 -%patch60 -p1 -%patch61 -p1 - -#test patching end - -%build -%if %{with limitbuild} -%limit_build -m 900 -%endif -%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} -# Filter out unwanted flags from $RPM_OPT_FLAGS -optflags= -optflags_d= -for flag in $RPM_OPT_FLAGS; do - add_flag= - case $flag in - -U_FORTIFY_SOURCE|-D_FORTIFY_SOURCE=*) ;; - -fno-rtti|-fno-exceptions|-Wmissing-format-attribute|-fstack-protector*) ;; - -ffortify=*|-Wall|-m32|-m64) ;; -%ifarch %ix86 - # -mcpu is superseded 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 superseded by proper - # default compiler settings now. - -mcpu=i?86|-march=i?86|-mtune=i?86) ;; -%endif -%ifarch s390 s390x - -fsigned-char) ;; - -O1) add_flag=-O2 ;; -%endif -%if 0%{?gcc_target_arch:1} - # Kill all -march/tune/cpu because that screws building the target libs - -march=*|-mtune=*|-mcpu=*) ;; -%endif - *) add_flag=$flag ;; - esac - if test -n "$add_flag"; then - optflags+=" $add_flag" - case $add_flag in - # Filter out -Werror=return-type for D (only valid for C and C++) - -Werror=return-type) ;; - *) optflags_d+=" $add_flag" ;; - esac - fi -done - -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 -%if %{build_rust} -languages=$languages,rust -%endif -%if %{build_m2} -languages=$languages,m2 -%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 - -%if %{build_d} && %{suse_version} < 1550 -# We are using gcc11-d to bootstrap d -export GDC=gdc-11 -%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 - -../configure \ - CFLAGS="$optflags" \ - CXXFLAGS="$optflags" \ - XCFLAGS="$optflags" \ - TCFLAGS="$optflags" \ - GDCFLAGS="$optflags_d" \ - --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 - --enable-offload-defaulted \ -%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} \ - --with-libstdcxx-zoneinfo=%{_datadir}/zoneinfo \ - --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}" == "bpf" - --disable-gcov \ -%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-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}" == "armv6hl" || "%{TARGET_ARCH}" == "arm" - --with-cpu=arm1176jzf-s \ - --with-float=hard \ - --with-abi=aapcs-linux \ - --with-fpu=vfpv2 \ - --disable-sjlj-exceptions \ -%endif -%if "%{TARGET_ARCH}" == "armv7hl" - --with-cpu=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}" == "powerpc64le" -%if %{suse_version} >= 1600 && !0%{?is_opensuse} - --with-cpu=power9 \ - --with-tune=power9 \ -%else -%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 -%endif -%if %{suse_version} > 1500 - --with-long-double-format=ieee \ -%else - --with-long-double-format=ibm \ -%endif - --enable-secureplt \ - --with-long-double-128 \ - --enable-targets=powerpcle-linux \ - --disable-multilib \ -%endif -%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64" -%if "%{TARGET_ARCH}" == "powerpc" - --with-cpu=default32 \ -%endif - --with-cpu-64=power4 \ - --enable-secureplt \ - --with-long-double-128 \ -%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 %{suse_version} >= 1600 && !0%{?is_opensuse} - --with-arch-32=x86-64-v2 \ -%else -%if 0%{?sle_version:%sle_version} >= 150000 - --with-arch-32=x86-64 \ -%else - --with-arch-32=i586 \ -%endif -%endif - --with-tune=generic \ -%endif -%if "%{TARGET_ARCH}" == "x86_64" -%ifnarch %{disable_multilib_arch} - --enable-multilib \ -%if %{suse_version} >= 1600 && !0%{?is_opensuse} - --with-arch-32=x86-64-v2 \ -%else - --with-arch-32=x86-64 \ -%endif -%endif -%if %{suse_version} >= 1600 && !0%{?is_opensuse} - --with-arch=x86-64-v2 \ -%endif - --with-tune=generic \ -%endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%if %{?cross_arch:1} - --disable-multilib \ -%endif -%endif -%if "%{TARGET_ARCH}" == "m68k" - --disable-multilib \ -%endif -%if "%{TARGET_ARCH}" == "riscv64" - --disable-multilib \ -%endif -%if %{with bootstrap} -%if %{use_lto_bootstrap} && !0%{?building_testsuite:1} - --with-build-config=bootstrap-lto-lean \ -%endif -%else - --disable-bootstrap \ -%endif - --enable-link-serialization \ - $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 %{?make_output_sync} %{?_smp_mflags} -%else -make %{?make_output_sync} %{?_smp_mflags} all-host -%endif - -%if 0%{?gcc_icecream:%gcc_icecream} -%package -n cross-%cross_arch-gcc13-icecream-backend -Summary: Icecream backend for the GNU C Compiler -Group: Development/Languages/C and C++ - -%description -n cross-%cross_arch-gcc13-icecream-backend -This package contains the icecream environment for the GNU C Compiler -%endif - -%if 0%{?nvptx_newlib:1} -%package -n cross-nvptx-newlib13-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-newlib13-devel -Newlib development files for the nvptx offload target compiler. -%endif - -%if 0%{?amdgcn_newlib:1} -%package -n cross-amdgcn-newlib13-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-newlib13-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} && "%{cross_arch}" != "bpf" - 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} 13 \ - --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 -%if 0%{!?gcc_libc_bootstrap:1} && "%{cross_arch}" != "bpf" - --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 - --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} - -%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} && "%{cross_arch}" != "bpf" -%{_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} && "%{cross_arch}" != "bpf" -%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-gcc13-icecream-backend -%defattr(-,root,root) -/usr/share/icecream-envs -%endif - -%if 0%{?nvptx_newlib:1} -%files -n cross-nvptx-newlib13-devel -%defattr(-,root,root) -%{_prefix}/%{gcc_target_arch} -%endif - -%if 0%{?amdgcn_newlib:1} -%files -n cross-amdgcn-newlib13-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-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index 005a954..623ebd4 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -19,7 +19,7 @@ %define pkgname cross-x86_64-gcc13 %define cross_arch x86_64 %define gcc_target_arch x86_64-suse-linux -%define gcc_target_glibc 1 +%define gcc_icecream 1 # nospeccleaner %define build_cp 0%{!?gcc_accel:1} diff --git a/gcc13.changes b/gcc13.changes index 8afd1ba..d6343e7 100644 --- a/gcc13.changes +++ b/gcc13.changes @@ -1,8 +1,7 @@ ------------------------------------------------------------------- -Tue Aug 22 10:40:59 UTC 2023 - Richard Biener +Wed Aug 23 06:50:07 UTC 2023 - Richard Biener -- Turn cross compilers to x86_64, ppc64le and s390x to glibc crosses. - [bsc#1214460] +- Turn cross compiler to s390x to a glibc cross. [bsc#1214460] ------------------------------------------------------------------- Fri Aug 18 13:03:36 UTC 2023 - Michal Suchanek From 2967fb3cdd6db5b5c04b8ce3ba259635683a856e79a9d67ba3f862716a366b87 Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Mon, 28 Aug 2023 08:05:13 +0000 Subject: [PATCH 05/10] - Disable building glibc cross compilers on SLE based code streams, the required cross-glibc packages are not available there. - Disable building avr cross on non-openSUSE code streams since avr-libc isn't available there. - Disable building newlib cross compilers on non-openSUSE code streams since newlib isn't available there. - Fix typo preventing s390x compiler build. OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=64 --- cross-aarch64-gcc13-bootstrap.spec | 12 +++++++++++- cross-aarch64-gcc13.spec | 12 +++++++++++- cross-amdgcn-gcc13.spec | 12 +++++++++++- cross-arm-gcc13.spec | 12 +++++++++++- cross-arm-none-gcc13-bootstrap.spec | 12 +++++++++++- cross-arm-none-gcc13.spec | 12 +++++++++++- cross-avr-gcc13-bootstrap.spec | 12 +++++++++++- cross-avr-gcc13.spec | 12 +++++++++++- cross-bpf-gcc13.spec | 12 +++++++++++- cross-epiphany-gcc13-bootstrap.spec | 12 +++++++++++- cross-epiphany-gcc13.spec | 12 +++++++++++- cross-hppa-gcc13-bootstrap.spec | 12 +++++++++++- cross-hppa-gcc13.spec | 12 +++++++++++- cross-m68k-gcc13.spec | 12 +++++++++++- cross-mips-gcc13.spec | 12 +++++++++++- cross-nvptx-gcc13.spec | 12 +++++++++++- cross-ppc64-gcc13.spec | 12 +++++++++++- cross-ppc64le-gcc13.spec | 12 +++++++++++- cross-pru-gcc13-bootstrap.spec | 12 +++++++++++- cross-pru-gcc13.spec | 12 +++++++++++- cross-riscv64-elf-gcc13-bootstrap.spec | 12 +++++++++++- cross-riscv64-elf-gcc13.spec | 12 +++++++++++- cross-riscv64-gcc13-bootstrap.spec | 12 +++++++++++- cross-riscv64-gcc13.spec | 12 +++++++++++- cross-rx-gcc13-bootstrap.spec | 12 +++++++++++- cross-rx-gcc13.spec | 12 +++++++++++- cross-s390x-gcc13-bootstrap.spec | 12 +++++++++++- cross-s390x-gcc13.spec | 12 +++++++++++- cross-sparc-gcc13.spec | 12 +++++++++++- cross-sparc64-gcc13.spec | 12 +++++++++++- cross-x86_64-gcc13.spec | 12 +++++++++++- cross.spec.in | 10 ++++++++++ gcc.spec.in | 2 +- gcc13-testresults.spec | 2 +- gcc13.changes | 11 +++++++++++ gcc13.spec | 2 +- 36 files changed, 365 insertions(+), 34 deletions(-) diff --git a/cross-aarch64-gcc13-bootstrap.spec b/cross-aarch64-gcc13-bootstrap.spec index 70da9d9..f9d606b 100644 --- a/cross-aarch64-gcc13-bootstrap.spec +++ b/cross-aarch64-gcc13-bootstrap.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-aarch64-gcc13.spec b/cross-aarch64-gcc13.spec index 4a590b3..bfe6c12 100644 --- a/cross-aarch64-gcc13.spec +++ b/cross-aarch64-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-amdgcn-gcc13.spec b/cross-amdgcn-gcc13.spec index 4405751..b73ad0e 100644 --- a/cross-amdgcn-gcc13.spec +++ b/cross-amdgcn-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-arm-gcc13.spec b/cross-arm-gcc13.spec index df29f87..64ce803 100644 --- a/cross-arm-gcc13.spec +++ b/cross-arm-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-arm-none-gcc13-bootstrap.spec b/cross-arm-none-gcc13-bootstrap.spec index d03b963..0d755b9 100644 --- a/cross-arm-none-gcc13-bootstrap.spec +++ b/cross-arm-none-gcc13-bootstrap.spec @@ -216,14 +216,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -746,7 +756,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-arm-none-gcc13.spec b/cross-arm-none-gcc13.spec index 289a587..e682bb7 100644 --- a/cross-arm-none-gcc13.spec +++ b/cross-arm-none-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-avr-gcc13-bootstrap.spec b/cross-avr-gcc13-bootstrap.spec index 68c8591..ffb1309 100644 --- a/cross-avr-gcc13-bootstrap.spec +++ b/cross-avr-gcc13-bootstrap.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-avr-gcc13.spec b/cross-avr-gcc13.spec index 1b104d5..294a787 100644 --- a/cross-avr-gcc13.spec +++ b/cross-avr-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-bpf-gcc13.spec b/cross-bpf-gcc13.spec index 59e749e..f2f55fa 100644 --- a/cross-bpf-gcc13.spec +++ b/cross-bpf-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-epiphany-gcc13-bootstrap.spec b/cross-epiphany-gcc13-bootstrap.spec index c187df8..d160a92 100644 --- a/cross-epiphany-gcc13-bootstrap.spec +++ b/cross-epiphany-gcc13-bootstrap.spec @@ -216,14 +216,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -746,7 +756,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-epiphany-gcc13.spec b/cross-epiphany-gcc13.spec index 9141058..06f0abc 100644 --- a/cross-epiphany-gcc13.spec +++ b/cross-epiphany-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-hppa-gcc13-bootstrap.spec b/cross-hppa-gcc13-bootstrap.spec index 4754ce2..22a2a81 100644 --- a/cross-hppa-gcc13-bootstrap.spec +++ b/cross-hppa-gcc13-bootstrap.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-hppa-gcc13.spec b/cross-hppa-gcc13.spec index fef80c9..2fee458 100644 --- a/cross-hppa-gcc13.spec +++ b/cross-hppa-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-m68k-gcc13.spec b/cross-m68k-gcc13.spec index 5cf1b6d..626e436 100644 --- a/cross-m68k-gcc13.spec +++ b/cross-m68k-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-mips-gcc13.spec b/cross-mips-gcc13.spec index 98c865e..cee465e 100644 --- a/cross-mips-gcc13.spec +++ b/cross-mips-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-nvptx-gcc13.spec b/cross-nvptx-gcc13.spec index 99894e1..b928a47 100644 --- a/cross-nvptx-gcc13.spec +++ b/cross-nvptx-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-ppc64-gcc13.spec b/cross-ppc64-gcc13.spec index f6a6f10..032eae4 100644 --- a/cross-ppc64-gcc13.spec +++ b/cross-ppc64-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index 7e93ed0..9058725 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-pru-gcc13-bootstrap.spec b/cross-pru-gcc13-bootstrap.spec index 0891bc4..55d5070 100644 --- a/cross-pru-gcc13-bootstrap.spec +++ b/cross-pru-gcc13-bootstrap.spec @@ -216,14 +216,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -746,7 +756,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-pru-gcc13.spec b/cross-pru-gcc13.spec index fbca31f..7de9893 100644 --- a/cross-pru-gcc13.spec +++ b/cross-pru-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-riscv64-elf-gcc13-bootstrap.spec b/cross-riscv64-elf-gcc13-bootstrap.spec index 8024bca..2ecc786 100644 --- a/cross-riscv64-elf-gcc13-bootstrap.spec +++ b/cross-riscv64-elf-gcc13-bootstrap.spec @@ -216,14 +216,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -746,7 +756,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-riscv64-elf-gcc13.spec b/cross-riscv64-elf-gcc13.spec index 4e21cf4..3d931b2 100644 --- a/cross-riscv64-elf-gcc13.spec +++ b/cross-riscv64-elf-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-riscv64-gcc13-bootstrap.spec b/cross-riscv64-gcc13-bootstrap.spec index 52b78c6..1ccd220 100644 --- a/cross-riscv64-gcc13-bootstrap.spec +++ b/cross-riscv64-gcc13-bootstrap.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-riscv64-gcc13.spec b/cross-riscv64-gcc13.spec index 0879c01..d985895 100644 --- a/cross-riscv64-gcc13.spec +++ b/cross-riscv64-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-rx-gcc13-bootstrap.spec b/cross-rx-gcc13-bootstrap.spec index cb79fa6..45137ac 100644 --- a/cross-rx-gcc13-bootstrap.spec +++ b/cross-rx-gcc13-bootstrap.spec @@ -216,14 +216,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -746,7 +756,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-rx-gcc13.spec b/cross-rx-gcc13.spec index 6bc9c38..b042cfb 100644 --- a/cross-rx-gcc13.spec +++ b/cross-rx-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-s390x-gcc13-bootstrap.spec b/cross-s390x-gcc13-bootstrap.spec index 28290bc..8c63c2a 100644 --- a/cross-s390x-gcc13-bootstrap.spec +++ b/cross-s390x-gcc13-bootstrap.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-s390x-gcc13.spec b/cross-s390x-gcc13.spec index 0dea949..747a1ad 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-sparc-gcc13.spec b/cross-sparc-gcc13.spec index 0f0378f..54054be 100644 --- a/cross-sparc-gcc13.spec +++ b/cross-sparc-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-sparc64-gcc13.spec b/cross-sparc64-gcc13.spec index b5c8a9b..cc4490e 100644 --- a/cross-sparc64-gcc13.spec +++ b/cross-sparc64-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index 623ebd4..89f2c10 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -215,14 +215,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" @@ -745,7 +755,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/cross.spec.in b/cross.spec.in index e8a7bf5..a125ac6 100644 --- a/cross.spec.in +++ b/cross.spec.in @@ -125,14 +125,24 @@ BuildRequires: libunwind-devel %if 0%{!?gcc_icecream:1} %if 0%{!?gcc_libc_bootstrap:1} %if 0%{?gcc_target_newlib:1} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: cross-%cross_arch-newlib-devel %endif %if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} +%if %{suse_version} >= 1600 BuildRequires: cross-%cross_arch-glibc-devel Requires: cross-%cross_arch-glibc-devel +%else +ExclusiveArch: do-not-build +%endif %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/gcc.spec.in b/gcc.spec.in index 16b6be4..fb3186e 100644 --- a/gcc.spec.in +++ b/gcc.spec.in @@ -1756,7 +1756,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/gcc13-testresults.spec b/gcc13-testresults.spec index 9361b58..26d6519 100644 --- a/gcc13-testresults.spec +++ b/gcc13-testresults.spec @@ -947,7 +947,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif diff --git a/gcc13.changes b/gcc13.changes index d6343e7..b037ac7 100644 --- a/gcc13.changes +++ b/gcc13.changes @@ -1,3 +1,14 @@ +------------------------------------------------------------------- +Mon Aug 28 07:59:17 UTC 2023 - Richard Biener + +- Disable building glibc cross compilers on SLE based code streams, + the required cross-glibc packages are not available there. +- Disable building avr cross on non-openSUSE code streams since + avr-libc isn't available there. +- Disable building newlib cross compilers on non-openSUSE code streams + since newlib isn't available there. +- Fix typo preventing s390x compiler build. + ------------------------------------------------------------------- Wed Aug 23 06:50:07 UTC 2023 - Richard Biener diff --git a/gcc13.spec b/gcc13.spec index fa477db..698838e 100644 --- a/gcc13.spec +++ b/gcc13.spec @@ -2764,7 +2764,7 @@ amdgcn-amdhsa,\ %endif --with-long-double-128 \ --enable-decimal-float \ -%if %{?cross_arch:1} +%if 0%{?cross_arch:1} --disable-multilib \ %endif %endif From f929ceaaa77012b4d3d44c7643a1ccb9c35757067e49031e466efcdfbb82569b Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Mon, 28 Aug 2023 08:20:47 +0000 Subject: [PATCH 06/10] OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=65 --- cross-aarch64-gcc13-bootstrap.spec | 7 +++---- cross-aarch64-gcc13.spec | 7 +++---- cross-amdgcn-gcc13.spec | 7 +++---- cross-arm-gcc13.spec | 7 +++---- cross-arm-none-gcc13-bootstrap.spec | 7 +++---- cross-arm-none-gcc13.spec | 7 +++---- cross-avr-gcc13-bootstrap.spec | 7 +++---- cross-avr-gcc13.spec | 7 +++---- cross-bpf-gcc13.spec | 7 +++---- cross-epiphany-gcc13-bootstrap.spec | 7 +++---- cross-epiphany-gcc13.spec | 7 +++---- cross-hppa-gcc13-bootstrap.spec | 7 +++---- cross-hppa-gcc13.spec | 7 +++---- cross-m68k-gcc13.spec | 7 +++---- cross-mips-gcc13.spec | 7 +++---- cross-nvptx-gcc13.spec | 7 +++---- cross-ppc64-gcc13.spec | 7 +++---- cross-ppc64le-gcc13.spec | 7 +++---- cross-pru-gcc13-bootstrap.spec | 7 +++---- cross-pru-gcc13.spec | 7 +++---- cross-riscv64-elf-gcc13-bootstrap.spec | 7 +++---- cross-riscv64-elf-gcc13.spec | 7 +++---- cross-riscv64-gcc13-bootstrap.spec | 7 +++---- cross-riscv64-gcc13.spec | 7 +++---- cross-rx-gcc13-bootstrap.spec | 7 +++---- cross-rx-gcc13.spec | 7 +++---- cross-s390x-gcc13-bootstrap.spec | 7 +++---- cross-s390x-gcc13.spec | 7 +++---- cross-sparc-gcc13.spec | 7 +++---- cross-sparc64-gcc13.spec | 7 +++---- cross-x86_64-gcc13.spec | 7 +++---- cross.spec.in | 7 +++---- 32 files changed, 96 insertions(+), 128 deletions(-) diff --git a/cross-aarch64-gcc13-bootstrap.spec b/cross-aarch64-gcc13-bootstrap.spec index f9d606b..4ba004a 100644 --- a/cross-aarch64-gcc13-bootstrap.spec +++ b/cross-aarch64-gcc13-bootstrap.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-aarch64-gcc13.spec b/cross-aarch64-gcc13.spec index bfe6c12..0a0027f 100644 --- a/cross-aarch64-gcc13.spec +++ b/cross-aarch64-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-amdgcn-gcc13.spec b/cross-amdgcn-gcc13.spec index b73ad0e..bbcc418 100644 --- a/cross-amdgcn-gcc13.spec +++ b/cross-amdgcn-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-arm-gcc13.spec b/cross-arm-gcc13.spec index 64ce803..76e158b 100644 --- a/cross-arm-gcc13.spec +++ b/cross-arm-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-arm-none-gcc13-bootstrap.spec b/cross-arm-none-gcc13-bootstrap.spec index 0d755b9..0dfbf3e 100644 --- a/cross-arm-none-gcc13-bootstrap.spec +++ b/cross-arm-none-gcc13-bootstrap.spec @@ -228,12 +228,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-arm-none-gcc13.spec b/cross-arm-none-gcc13.spec index e682bb7..38fe094 100644 --- a/cross-arm-none-gcc13.spec +++ b/cross-arm-none-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-avr-gcc13-bootstrap.spec b/cross-avr-gcc13-bootstrap.spec index ffb1309..7f8f857 100644 --- a/cross-avr-gcc13-bootstrap.spec +++ b/cross-avr-gcc13-bootstrap.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-avr-gcc13.spec b/cross-avr-gcc13.spec index 294a787..00fd0ba 100644 --- a/cross-avr-gcc13.spec +++ b/cross-avr-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-bpf-gcc13.spec b/cross-bpf-gcc13.spec index f2f55fa..2c10065 100644 --- a/cross-bpf-gcc13.spec +++ b/cross-bpf-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-epiphany-gcc13-bootstrap.spec b/cross-epiphany-gcc13-bootstrap.spec index d160a92..98478fa 100644 --- a/cross-epiphany-gcc13-bootstrap.spec +++ b/cross-epiphany-gcc13-bootstrap.spec @@ -228,12 +228,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-epiphany-gcc13.spec b/cross-epiphany-gcc13.spec index 06f0abc..ffbb5ec 100644 --- a/cross-epiphany-gcc13.spec +++ b/cross-epiphany-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-hppa-gcc13-bootstrap.spec b/cross-hppa-gcc13-bootstrap.spec index 22a2a81..5901a06 100644 --- a/cross-hppa-gcc13-bootstrap.spec +++ b/cross-hppa-gcc13-bootstrap.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-hppa-gcc13.spec b/cross-hppa-gcc13.spec index 2fee458..051dfb0 100644 --- a/cross-hppa-gcc13.spec +++ b/cross-hppa-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-m68k-gcc13.spec b/cross-m68k-gcc13.spec index 626e436..12a6e7f 100644 --- a/cross-m68k-gcc13.spec +++ b/cross-m68k-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-mips-gcc13.spec b/cross-mips-gcc13.spec index cee465e..ddc4c55 100644 --- a/cross-mips-gcc13.spec +++ b/cross-mips-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-nvptx-gcc13.spec b/cross-nvptx-gcc13.spec index b928a47..e1fc0be 100644 --- a/cross-nvptx-gcc13.spec +++ b/cross-nvptx-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-ppc64-gcc13.spec b/cross-ppc64-gcc13.spec index 032eae4..0351f25 100644 --- a/cross-ppc64-gcc13.spec +++ b/cross-ppc64-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index 9058725..134dbbf 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-pru-gcc13-bootstrap.spec b/cross-pru-gcc13-bootstrap.spec index 55d5070..8a91510 100644 --- a/cross-pru-gcc13-bootstrap.spec +++ b/cross-pru-gcc13-bootstrap.spec @@ -228,12 +228,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-pru-gcc13.spec b/cross-pru-gcc13.spec index 7de9893..ba49af9 100644 --- a/cross-pru-gcc13.spec +++ b/cross-pru-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-riscv64-elf-gcc13-bootstrap.spec b/cross-riscv64-elf-gcc13-bootstrap.spec index 2ecc786..9b1a698 100644 --- a/cross-riscv64-elf-gcc13-bootstrap.spec +++ b/cross-riscv64-elf-gcc13-bootstrap.spec @@ -228,12 +228,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-riscv64-elf-gcc13.spec b/cross-riscv64-elf-gcc13.spec index 3d931b2..5105030 100644 --- a/cross-riscv64-elf-gcc13.spec +++ b/cross-riscv64-elf-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-riscv64-gcc13-bootstrap.spec b/cross-riscv64-gcc13-bootstrap.spec index 1ccd220..62639b0 100644 --- a/cross-riscv64-gcc13-bootstrap.spec +++ b/cross-riscv64-gcc13-bootstrap.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-riscv64-gcc13.spec b/cross-riscv64-gcc13.spec index d985895..e1e9323 100644 --- a/cross-riscv64-gcc13.spec +++ b/cross-riscv64-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-rx-gcc13-bootstrap.spec b/cross-rx-gcc13-bootstrap.spec index 45137ac..159319d 100644 --- a/cross-rx-gcc13-bootstrap.spec +++ b/cross-rx-gcc13-bootstrap.spec @@ -228,12 +228,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-rx-gcc13.spec b/cross-rx-gcc13.spec index b042cfb..76bdfb5 100644 --- a/cross-rx-gcc13.spec +++ b/cross-rx-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-s390x-gcc13-bootstrap.spec b/cross-s390x-gcc13-bootstrap.spec index 8c63c2a..87ab4d5 100644 --- a/cross-s390x-gcc13-bootstrap.spec +++ b/cross-s390x-gcc13-bootstrap.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-s390x-gcc13.spec b/cross-s390x-gcc13.spec index 747a1ad..812c6b0 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-sparc-gcc13.spec b/cross-sparc-gcc13.spec index 54054be..e58e1d7 100644 --- a/cross-sparc-gcc13.spec +++ b/cross-sparc-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-sparc64-gcc13.spec b/cross-sparc64-gcc13.spec index cc4490e..85e8512 100644 --- a/cross-sparc64-gcc13.spec +++ b/cross-sparc64-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index 89f2c10..4785baf 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -227,12 +227,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" diff --git a/cross.spec.in b/cross.spec.in index a125ac6..bf82bdb 100644 --- a/cross.spec.in +++ b/cross.spec.in @@ -137,12 +137,11 @@ ExclusiveArch: do-not-build BuildRequires: avr-libc %endif %if 0%{?gcc_target_glibc:1} -%if %{suse_version} >= 1600 -BuildRequires: cross-%cross_arch-glibc-devel -Requires: cross-%cross_arch-glibc-devel -%else +%if %{suse_version} < 1600 ExclusiveArch: do-not-build %endif +BuildRequires: cross-%cross_arch-glibc-devel +Requires: cross-%cross_arch-glibc-devel %endif %endif %if "%{cross_arch}" == "nvptx" From 95c1324adb3f15c34e2d18e359059c0c09b1b6e4def5b168a579b53dc122cb88 Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Mon, 28 Aug 2023 09:00:17 +0000 Subject: [PATCH 07/10] OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=66 --- cross-aarch64-gcc13-bootstrap.spec | 9 +++++++-- cross-aarch64-gcc13.spec | 9 +++++++-- cross-amdgcn-gcc13.spec | 9 +++++++-- cross-arm-gcc13.spec | 9 +++++++-- cross-arm-none-gcc13-bootstrap.spec | 9 +++++++-- cross-arm-none-gcc13.spec | 9 +++++++-- cross-avr-gcc13-bootstrap.spec | 9 +++++++-- cross-avr-gcc13.spec | 9 +++++++-- cross-bpf-gcc13.spec | 9 +++++++-- cross-epiphany-gcc13-bootstrap.spec | 9 +++++++-- cross-epiphany-gcc13.spec | 9 +++++++-- cross-hppa-gcc13-bootstrap.spec | 9 +++++++-- cross-hppa-gcc13.spec | 9 +++++++-- cross-m68k-gcc13.spec | 9 +++++++-- cross-mips-gcc13.spec | 9 +++++++-- cross-nvptx-gcc13.spec | 9 +++++++-- cross-ppc64-gcc13.spec | 9 +++++++-- cross-ppc64le-gcc13.spec | 9 +++++++-- cross-pru-gcc13-bootstrap.spec | 9 +++++++-- cross-pru-gcc13.spec | 9 +++++++-- cross-riscv64-elf-gcc13-bootstrap.spec | 9 +++++++-- cross-riscv64-elf-gcc13.spec | 9 +++++++-- cross-riscv64-gcc13-bootstrap.spec | 9 +++++++-- cross-riscv64-gcc13.spec | 9 +++++++-- cross-rx-gcc13-bootstrap.spec | 9 +++++++-- cross-rx-gcc13.spec | 9 +++++++-- cross-s390x-gcc13-bootstrap.spec | 9 +++++++-- cross-s390x-gcc13.spec | 9 +++++++-- cross-sparc-gcc13.spec | 9 +++++++-- cross-sparc64-gcc13.spec | 9 +++++++-- cross-x86_64-gcc13.spec | 9 +++++++-- cross.spec.in | 9 +++++++-- 32 files changed, 224 insertions(+), 64 deletions(-) diff --git a/cross-aarch64-gcc13-bootstrap.spec b/cross-aarch64-gcc13-bootstrap.spec index 4ba004a..62a123e 100644 --- a/cross-aarch64-gcc13-bootstrap.spec +++ b/cross-aarch64-gcc13-bootstrap.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 riscv64 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 x86_64 s390x riscv64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-aarch64-gcc13.spec b/cross-aarch64-gcc13.spec index 0a0027f..9d775d1 100644 --- a/cross-aarch64-gcc13.spec +++ b/cross-aarch64-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 riscv64 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 x86_64 s390x riscv64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-amdgcn-gcc13.spec b/cross-amdgcn-gcc13.spec index bbcc418..b749b23 100644 --- a/cross-amdgcn-gcc13.spec +++ b/cross-amdgcn-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-arm-gcc13.spec b/cross-arm-gcc13.spec index 76e158b..ecd0dc6 100644 --- a/cross-arm-gcc13.spec +++ b/cross-arm-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-arm-none-gcc13-bootstrap.spec b/cross-arm-none-gcc13-bootstrap.spec index 0dfbf3e..975eb0c 100644 --- a/cross-arm-none-gcc13-bootstrap.spec +++ b/cross-arm-none-gcc13-bootstrap.spec @@ -267,11 +267,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-arm-none-gcc13.spec b/cross-arm-none-gcc13.spec index 38fe094..17a866f 100644 --- a/cross-arm-none-gcc13.spec +++ b/cross-arm-none-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-avr-gcc13-bootstrap.spec b/cross-avr-gcc13-bootstrap.spec index 7f8f857..3291d8e 100644 --- a/cross-avr-gcc13-bootstrap.spec +++ b/cross-avr-gcc13-bootstrap.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-avr-gcc13.spec b/cross-avr-gcc13.spec index 00fd0ba..64c30c6 100644 --- a/cross-avr-gcc13.spec +++ b/cross-avr-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-bpf-gcc13.spec b/cross-bpf-gcc13.spec index 2c10065..14b7f3b 100644 --- a/cross-bpf-gcc13.spec +++ b/cross-bpf-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-epiphany-gcc13-bootstrap.spec b/cross-epiphany-gcc13-bootstrap.spec index 98478fa..db72bad 100644 --- a/cross-epiphany-gcc13-bootstrap.spec +++ b/cross-epiphany-gcc13-bootstrap.spec @@ -267,11 +267,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-epiphany-gcc13.spec b/cross-epiphany-gcc13.spec index ffbb5ec..fcf1348 100644 --- a/cross-epiphany-gcc13.spec +++ b/cross-epiphany-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-hppa-gcc13-bootstrap.spec b/cross-hppa-gcc13-bootstrap.spec index 5901a06..07c7e53 100644 --- a/cross-hppa-gcc13-bootstrap.spec +++ b/cross-hppa-gcc13-bootstrap.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-hppa-gcc13.spec b/cross-hppa-gcc13.spec index 051dfb0..a57222d 100644 --- a/cross-hppa-gcc13.spec +++ b/cross-hppa-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-m68k-gcc13.spec b/cross-m68k-gcc13.spec index 12a6e7f..34ff459 100644 --- a/cross-m68k-gcc13.spec +++ b/cross-m68k-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-mips-gcc13.spec b/cross-mips-gcc13.spec index ddc4c55..6b9d2f7 100644 --- a/cross-mips-gcc13.spec +++ b/cross-mips-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-nvptx-gcc13.spec b/cross-nvptx-gcc13.spec index e1fc0be..54429ab 100644 --- a/cross-nvptx-gcc13.spec +++ b/cross-nvptx-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-ppc64-gcc13.spec b/cross-ppc64-gcc13.spec index 0351f25..8200b70 100644 --- a/cross-ppc64-gcc13.spec +++ b/cross-ppc64-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %define amdgcn_newlib 1 %endif %endif -%if 0%{?gcc_icecream:1}%{?gcc_target_glibc:1}%{?gcc_libc_bootstrap:1} -ExclusiveArch: i586 ppc64le x86_64 s390x aarch64 riscv64 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le x86_64 s390x aarch64 riscv64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index 134dbbf..31bb902 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %define amdgcn_newlib 1 %endif %endif -%if 0%{?gcc_icecream:1}%{?gcc_target_glibc:1}%{?gcc_libc_bootstrap:1} -ExclusiveArch: i586 ppc64 x86_64 s390x aarch64 riscv64 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64 x86_64 s390x aarch64 riscv64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-pru-gcc13-bootstrap.spec b/cross-pru-gcc13-bootstrap.spec index 8a91510..9eebff7 100644 --- a/cross-pru-gcc13-bootstrap.spec +++ b/cross-pru-gcc13-bootstrap.spec @@ -267,11 +267,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-pru-gcc13.spec b/cross-pru-gcc13.spec index ba49af9..13ab6eb 100644 --- a/cross-pru-gcc13.spec +++ b/cross-pru-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-riscv64-elf-gcc13-bootstrap.spec b/cross-riscv64-elf-gcc13-bootstrap.spec index 9b1a698..c40dfc3 100644 --- a/cross-riscv64-elf-gcc13-bootstrap.spec +++ b/cross-riscv64-elf-gcc13-bootstrap.spec @@ -267,11 +267,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 x86_64 s390x aarch64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-riscv64-elf-gcc13.spec b/cross-riscv64-elf-gcc13.spec index 5105030..18e6cd8 100644 --- a/cross-riscv64-elf-gcc13.spec +++ b/cross-riscv64-elf-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 x86_64 s390x aarch64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-riscv64-gcc13-bootstrap.spec b/cross-riscv64-gcc13-bootstrap.spec index 62639b0..7db7f27 100644 --- a/cross-riscv64-gcc13-bootstrap.spec +++ b/cross-riscv64-gcc13-bootstrap.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 x86_64 s390x aarch64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-riscv64-gcc13.spec b/cross-riscv64-gcc13.spec index e1e9323..6bcb1db 100644 --- a/cross-riscv64-gcc13.spec +++ b/cross-riscv64-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 x86_64 s390x aarch64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-rx-gcc13-bootstrap.spec b/cross-rx-gcc13-bootstrap.spec index 159319d..6cde6df 100644 --- a/cross-rx-gcc13-bootstrap.spec +++ b/cross-rx-gcc13-bootstrap.spec @@ -267,11 +267,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-rx-gcc13.spec b/cross-rx-gcc13.spec index 76bdfb5..d5e709c 100644 --- a/cross-rx-gcc13.spec +++ b/cross-rx-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-s390x-gcc13-bootstrap.spec b/cross-s390x-gcc13-bootstrap.spec index 87ab4d5..0d40c43 100644 --- a/cross-s390x-gcc13-bootstrap.spec +++ b/cross-s390x-gcc13-bootstrap.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 aarch64 riscv64 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 x86_64 aarch64 riscv64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-s390x-gcc13.spec b/cross-s390x-gcc13.spec index 812c6b0..74c0800 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 aarch64 riscv64 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 x86_64 aarch64 riscv64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross-sparc-gcc13.spec b/cross-sparc-gcc13.spec index e58e1d7..f26cb86 100644 --- a/cross-sparc-gcc13.spec +++ b/cross-sparc-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-sparc64-gcc13.spec b/cross-sparc64-gcc13.spec index 85e8512..268232c 100644 --- a/cross-sparc64-gcc13.spec +++ b/cross-sparc64-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 diff --git a/cross-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index 4785baf..f22ec45 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -266,11 +266,16 @@ ExclusiveArch: do-not-build %define amdgcn_newlib 1 %endif %endif -%if 0%{?gcc_icecream:1}%{?gcc_target_glibc:1}%{?gcc_libc_bootstrap:1} -ExclusiveArch: i586 ppc64le ppc64 s390x aarch64 riscv64 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 ppc64le ppc64 s390x aarch64 riscv64 %endif %define _binary_payload w.ufdio # Obsolete cross-ppc-gcc49 from cross-ppc64-gcc49 which has diff --git a/cross.spec.in b/cross.spec.in index bf82bdb..901620b 100644 --- a/cross.spec.in +++ b/cross.spec.in @@ -176,11 +176,16 @@ ExclusiveArch: do-not-build %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 %if "%{cross_arch}" == "pru" ExclusiveArch: %arm %endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream: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 From 882160ed6418248111e9935f14f8adfa9f08a37e434ea9e7771a8c512c67402e Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Mon, 28 Aug 2023 10:51:17 +0000 Subject: [PATCH 08/10] - Raise s390x architecture baseline to z14 for ALP. [PED-253] OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=67 --- cross-aarch64-gcc13-bootstrap.spec | 19 +++---------------- cross-aarch64-gcc13.spec | 19 +++---------------- cross-amdgcn-gcc13.spec | 19 +++---------------- cross-arm-gcc13.spec | 19 +++---------------- cross-arm-none-gcc13-bootstrap.spec | 19 +++---------------- cross-arm-none-gcc13.spec | 19 +++---------------- cross-avr-gcc13-bootstrap.spec | 19 +++---------------- cross-avr-gcc13.spec | 19 +++---------------- cross-bpf-gcc13.spec | 19 +++---------------- cross-epiphany-gcc13-bootstrap.spec | 19 +++---------------- cross-epiphany-gcc13.spec | 19 +++---------------- cross-hppa-gcc13-bootstrap.spec | 19 +++---------------- cross-hppa-gcc13.spec | 19 +++---------------- cross-m68k-gcc13.spec | 19 +++---------------- cross-mips-gcc13.spec | 19 +++---------------- cross-nvptx-gcc13.spec | 19 +++---------------- cross-ppc64-gcc13.spec | 19 +++---------------- cross-ppc64le-gcc13.spec | 19 +++---------------- cross-pru-gcc13-bootstrap.spec | 19 +++---------------- cross-pru-gcc13.spec | 19 +++---------------- cross-riscv64-elf-gcc13-bootstrap.spec | 19 +++---------------- cross-riscv64-elf-gcc13.spec | 19 +++---------------- cross-riscv64-gcc13-bootstrap.spec | 19 +++---------------- cross-riscv64-gcc13.spec | 19 +++---------------- cross-rx-gcc13-bootstrap.spec | 19 +++---------------- cross-rx-gcc13.spec | 19 +++---------------- cross-s390x-gcc13-bootstrap.spec | 19 +++---------------- cross-s390x-gcc13.spec | 19 +++---------------- cross-sparc-gcc13.spec | 19 +++---------------- cross-sparc64-gcc13.spec | 19 +++---------------- cross-x86_64-gcc13.spec | 19 +++---------------- gcc.spec.in | 19 +++---------------- gcc13-testresults.spec | 19 +++---------------- gcc13.changes | 1 + gcc13.spec | 19 +++---------------- 35 files changed, 103 insertions(+), 544 deletions(-) diff --git a/cross-aarch64-gcc13-bootstrap.spec b/cross-aarch64-gcc13-bootstrap.spec index 62a123e..333bdd2 100644 --- a/cross-aarch64-gcc13-bootstrap.spec +++ b/cross-aarch64-gcc13-bootstrap.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-aarch64-gcc13.spec b/cross-aarch64-gcc13.spec index 9d775d1..eba3243 100644 --- a/cross-aarch64-gcc13.spec +++ b/cross-aarch64-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-amdgcn-gcc13.spec b/cross-amdgcn-gcc13.spec index b749b23..da567cc 100644 --- a/cross-amdgcn-gcc13.spec +++ b/cross-amdgcn-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-arm-gcc13.spec b/cross-arm-gcc13.spec index ecd0dc6..3be6e7b 100644 --- a/cross-arm-gcc13.spec +++ b/cross-arm-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-arm-none-gcc13-bootstrap.spec b/cross-arm-none-gcc13-bootstrap.spec index 975eb0c..ace77f7 100644 --- a/cross-arm-none-gcc13-bootstrap.spec +++ b/cross-arm-none-gcc13-bootstrap.spec @@ -735,22 +735,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-arm-none-gcc13.spec b/cross-arm-none-gcc13.spec index 17a866f..1cc1db1 100644 --- a/cross-arm-none-gcc13.spec +++ b/cross-arm-none-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-avr-gcc13-bootstrap.spec b/cross-avr-gcc13-bootstrap.spec index 3291d8e..29e8414 100644 --- a/cross-avr-gcc13-bootstrap.spec +++ b/cross-avr-gcc13-bootstrap.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-avr-gcc13.spec b/cross-avr-gcc13.spec index 64c30c6..9cc2fd7 100644 --- a/cross-avr-gcc13.spec +++ b/cross-avr-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-bpf-gcc13.spec b/cross-bpf-gcc13.spec index 14b7f3b..6e59b95 100644 --- a/cross-bpf-gcc13.spec +++ b/cross-bpf-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-epiphany-gcc13-bootstrap.spec b/cross-epiphany-gcc13-bootstrap.spec index db72bad..afa0db0 100644 --- a/cross-epiphany-gcc13-bootstrap.spec +++ b/cross-epiphany-gcc13-bootstrap.spec @@ -735,22 +735,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-epiphany-gcc13.spec b/cross-epiphany-gcc13.spec index fcf1348..b18e112 100644 --- a/cross-epiphany-gcc13.spec +++ b/cross-epiphany-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-hppa-gcc13-bootstrap.spec b/cross-hppa-gcc13-bootstrap.spec index 07c7e53..3144de8 100644 --- a/cross-hppa-gcc13-bootstrap.spec +++ b/cross-hppa-gcc13-bootstrap.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-hppa-gcc13.spec b/cross-hppa-gcc13.spec index a57222d..85bbc15 100644 --- a/cross-hppa-gcc13.spec +++ b/cross-hppa-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-m68k-gcc13.spec b/cross-m68k-gcc13.spec index 34ff459..3ebfd99 100644 --- a/cross-m68k-gcc13.spec +++ b/cross-m68k-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-mips-gcc13.spec b/cross-mips-gcc13.spec index 6b9d2f7..f5ca26a 100644 --- a/cross-mips-gcc13.spec +++ b/cross-mips-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-nvptx-gcc13.spec b/cross-nvptx-gcc13.spec index 54429ab..854a59c 100644 --- a/cross-nvptx-gcc13.spec +++ b/cross-nvptx-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-ppc64-gcc13.spec b/cross-ppc64-gcc13.spec index 8200b70..8f20d9b 100644 --- a/cross-ppc64-gcc13.spec +++ b/cross-ppc64-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index 31bb902..5398ab8 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-pru-gcc13-bootstrap.spec b/cross-pru-gcc13-bootstrap.spec index 9eebff7..a47903e 100644 --- a/cross-pru-gcc13-bootstrap.spec +++ b/cross-pru-gcc13-bootstrap.spec @@ -735,22 +735,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-pru-gcc13.spec b/cross-pru-gcc13.spec index 13ab6eb..bcc7a6f 100644 --- a/cross-pru-gcc13.spec +++ b/cross-pru-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-riscv64-elf-gcc13-bootstrap.spec b/cross-riscv64-elf-gcc13-bootstrap.spec index c40dfc3..300ebb3 100644 --- a/cross-riscv64-elf-gcc13-bootstrap.spec +++ b/cross-riscv64-elf-gcc13-bootstrap.spec @@ -735,22 +735,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-riscv64-elf-gcc13.spec b/cross-riscv64-elf-gcc13.spec index 18e6cd8..ccd69ea 100644 --- a/cross-riscv64-elf-gcc13.spec +++ b/cross-riscv64-elf-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-riscv64-gcc13-bootstrap.spec b/cross-riscv64-gcc13-bootstrap.spec index 7db7f27..700bab0 100644 --- a/cross-riscv64-gcc13-bootstrap.spec +++ b/cross-riscv64-gcc13-bootstrap.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-riscv64-gcc13.spec b/cross-riscv64-gcc13.spec index 6bcb1db..edcd737 100644 --- a/cross-riscv64-gcc13.spec +++ b/cross-riscv64-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-rx-gcc13-bootstrap.spec b/cross-rx-gcc13-bootstrap.spec index 6cde6df..39fa7fb 100644 --- a/cross-rx-gcc13-bootstrap.spec +++ b/cross-rx-gcc13-bootstrap.spec @@ -735,22 +735,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-rx-gcc13.spec b/cross-rx-gcc13.spec index d5e709c..bfe8ab4 100644 --- a/cross-rx-gcc13.spec +++ b/cross-rx-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-s390x-gcc13-bootstrap.spec b/cross-s390x-gcc13-bootstrap.spec index 0d40c43..d3e6ec2 100644 --- a/cross-s390x-gcc13-bootstrap.spec +++ b/cross-s390x-gcc13-bootstrap.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-s390x-gcc13.spec b/cross-s390x-gcc13.spec index 74c0800..f57ebf1 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-sparc-gcc13.spec b/cross-sparc-gcc13.spec index f26cb86..d1e9419 100644 --- a/cross-sparc-gcc13.spec +++ b/cross-sparc-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-sparc64-gcc13.spec b/cross-sparc64-gcc13.spec index 268232c..371059c 100644 --- a/cross-sparc64-gcc13.spec +++ b/cross-sparc64-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/cross-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index f22ec45..a9283ac 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -734,22 +734,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/gcc.spec.in b/gcc.spec.in index fb3186e..90a9229 100644 --- a/gcc.spec.in +++ b/gcc.spec.in @@ -1731,22 +1731,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/gcc13-testresults.spec b/gcc13-testresults.spec index 26d6519..48d5de1 100644 --- a/gcc13-testresults.spec +++ b/gcc13-testresults.spec @@ -922,22 +922,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ diff --git a/gcc13.changes b/gcc13.changes index b037ac7..b73f8fa 100644 --- a/gcc13.changes +++ b/gcc13.changes @@ -8,6 +8,7 @@ Mon Aug 28 07:59:17 UTC 2023 - Richard Biener - Disable building newlib cross compilers on non-openSUSE code streams since newlib isn't available there. - Fix typo preventing s390x compiler build. +- Raise s390x architecture baseline to z14 for ALP. [PED-253] ------------------------------------------------------------------- Wed Aug 23 06:50:07 UTC 2023 - Richard Biener diff --git a/gcc13.spec b/gcc13.spec index 698838e..5f1079c 100644 --- a/gcc13.spec +++ b/gcc13.spec @@ -2739,22 +2739,9 @@ amdgcn-amdhsa,\ %endif --with-tune=generic \ %endif -%if "%{TARGET_ARCH}" == "s390" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ -%else -%if %{suse_version} >= 1310 - --with-tune=zEC12 --with-arch=z196 \ -%else - --with-tune=z9-109 --with-arch=z900 \ -%endif -%endif - --with-long-double-128 \ - --enable-decimal-float \ -%endif -%if "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 - --with-tune=zEC12 --with-arch=z196 \ +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 --with-tune=zEC12 --with-arch=z196 \ From c88d4a9b9c10dcd6f05269c7f266312e44167188177061e7dbd65eaf1fd356cd Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Mon, 28 Aug 2023 11:58:56 +0000 Subject: [PATCH 09/10] - Turn cross compiler to ppc64le to a glibc cross. OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=68 --- _multibuild | 3 +- change_spec | 2 +- cross-aarch64-gcc13-bootstrap.spec | 3 + cross-aarch64-gcc13.spec | 3 + cross-amdgcn-gcc13.spec | 3 + cross-arm-gcc13.spec | 3 + cross-arm-none-gcc13-bootstrap.spec | 3 + cross-arm-none-gcc13.spec | 3 + cross-avr-gcc13-bootstrap.spec | 3 + cross-avr-gcc13.spec | 3 + cross-bpf-gcc13.spec | 3 + cross-epiphany-gcc13-bootstrap.spec | 3 + cross-epiphany-gcc13.spec | 3 + cross-hppa-gcc13-bootstrap.spec | 3 + cross-hppa-gcc13.spec | 3 + cross-m68k-gcc13.spec | 3 + cross-mips-gcc13.spec | 3 + cross-nvptx-gcc13.spec | 3 + cross-ppc64-gcc13.spec | 3 + cross-ppc64le-gcc13-bootstrap.spec | 1063 ++++++++++++++++++++++++ cross-ppc64le-gcc13.spec | 5 +- cross-pru-gcc13-bootstrap.spec | 3 + cross-pru-gcc13.spec | 3 + cross-riscv64-elf-gcc13-bootstrap.spec | 3 + cross-riscv64-elf-gcc13.spec | 3 + cross-riscv64-gcc13-bootstrap.spec | 3 + cross-riscv64-gcc13.spec | 3 + cross-rx-gcc13-bootstrap.spec | 3 + cross-rx-gcc13.spec | 3 + cross-s390x-gcc13-bootstrap.spec | 3 + cross-s390x-gcc13.spec | 3 + cross-sparc-gcc13.spec | 3 + cross-sparc64-gcc13.spec | 3 + cross-x86_64-gcc13.spec | 3 + gcc.spec.in | 3 + gcc13-testresults.spec | 3 + gcc13.changes | 1 + gcc13.spec | 3 + 38 files changed, 1170 insertions(+), 3 deletions(-) create mode 100644 cross-ppc64le-gcc13-bootstrap.spec diff --git a/_multibuild b/_multibuild index 30793d7..16ce003 100644 --- a/_multibuild +++ b/_multibuild @@ -6,6 +6,8 @@ cross-riscv64-gcc13 cross-s390x-gcc13-bootstrap cross-s390x-gcc13 +cross-ppc64le-gcc13-bootstrap +cross-ppc64le-gcc13 cross-arm-gcc13 cross-avr-gcc13-bootstrap cross-avr-gcc13 @@ -15,7 +17,6 @@ cross-sparc-gcc13 cross-sparc64-gcc13 cross-ppc64-gcc13 -cross-ppc64le-gcc13 cross-m68k-gcc13 cross-mips-gcc13 cross-hppa-gcc13-bootstrap diff --git a/change_spec b/change_spec index cdbc5bc..066845e 100644 --- a/change_spec +++ b/change_spec @@ -101,6 +101,7 @@ if test "$do_crosses" = 1 ; then add_glibc_cross cross-aarch64-gcc$base_ver aarch64 aarch64-suse-linux add_glibc_cross cross-riscv64-gcc$base_ver riscv64 riscv64-suse-linux add_glibc_cross cross-s390x-gcc$base_ver s390x s390x-suse-linux +add_glibc_cross cross-ppc64le-gcc$base_ver ppc64le powerpc64le-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 @@ -109,7 +110,6 @@ add_cross cross-x86_64-gcc$base_ver x86_64 x86_64-suse-linux %define gcc_icecrea add_cross cross-sparc-gcc$base_ver sparcv9 sparc-suse-linux %define gcc_icecream 1 add_cross cross-sparc64-gcc$base_ver sparc64 sparc64-suse-linux %define gcc_icecream 1 add_cross cross-ppc64-gcc$base_ver ppc64 powerpc64-suse-linux %define gcc_icecream 1 -add_cross cross-ppc64le-gcc$base_ver ppc64le powerpc64le-suse-linux %define gcc_icecream 1 add_cross cross-m68k-gcc$base_ver m68k m68k-suse-linux %define gcc_icecream 1 add_cross cross-mips-gcc$base_ver mips mips-suse-linux %define gcc_icecream 1 add_cross cross-hppa-gcc$base_ver-bootstrap hppa hppa-suse-linux %define gcc_libc_bootstrap 1 diff --git a/cross-aarch64-gcc13-bootstrap.spec b/cross-aarch64-gcc13-bootstrap.spec index 333bdd2..4748c6c 100644 --- a/cross-aarch64-gcc13-bootstrap.spec +++ b/cross-aarch64-gcc13-bootstrap.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-aarch64-gcc13.spec b/cross-aarch64-gcc13.spec index eba3243..57c66db 100644 --- a/cross-aarch64-gcc13.spec +++ b/cross-aarch64-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-amdgcn-gcc13.spec b/cross-amdgcn-gcc13.spec index da567cc..8cd4ae9 100644 --- a/cross-amdgcn-gcc13.spec +++ b/cross-amdgcn-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-arm-gcc13.spec b/cross-arm-gcc13.spec index 3be6e7b..7fddab2 100644 --- a/cross-arm-gcc13.spec +++ b/cross-arm-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-arm-none-gcc13-bootstrap.spec b/cross-arm-none-gcc13-bootstrap.spec index ace77f7..565ebf4 100644 --- a/cross-arm-none-gcc13-bootstrap.spec +++ b/cross-arm-none-gcc13-bootstrap.spec @@ -666,6 +666,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-arm-none-gcc13.spec b/cross-arm-none-gcc13.spec index 1cc1db1..1588f23 100644 --- a/cross-arm-none-gcc13.spec +++ b/cross-arm-none-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-avr-gcc13-bootstrap.spec b/cross-avr-gcc13-bootstrap.spec index 29e8414..109e8f8 100644 --- a/cross-avr-gcc13-bootstrap.spec +++ b/cross-avr-gcc13-bootstrap.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-avr-gcc13.spec b/cross-avr-gcc13.spec index 9cc2fd7..46541a3 100644 --- a/cross-avr-gcc13.spec +++ b/cross-avr-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-bpf-gcc13.spec b/cross-bpf-gcc13.spec index 6e59b95..bd4f125 100644 --- a/cross-bpf-gcc13.spec +++ b/cross-bpf-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-epiphany-gcc13-bootstrap.spec b/cross-epiphany-gcc13-bootstrap.spec index afa0db0..4f2fc01 100644 --- a/cross-epiphany-gcc13-bootstrap.spec +++ b/cross-epiphany-gcc13-bootstrap.spec @@ -666,6 +666,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-epiphany-gcc13.spec b/cross-epiphany-gcc13.spec index b18e112..38bc28e 100644 --- a/cross-epiphany-gcc13.spec +++ b/cross-epiphany-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-hppa-gcc13-bootstrap.spec b/cross-hppa-gcc13-bootstrap.spec index 3144de8..873eb94 100644 --- a/cross-hppa-gcc13-bootstrap.spec +++ b/cross-hppa-gcc13-bootstrap.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-hppa-gcc13.spec b/cross-hppa-gcc13.spec index 85bbc15..680f423 100644 --- a/cross-hppa-gcc13.spec +++ b/cross-hppa-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-m68k-gcc13.spec b/cross-m68k-gcc13.spec index 3ebfd99..87c8b73 100644 --- a/cross-m68k-gcc13.spec +++ b/cross-m68k-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-mips-gcc13.spec b/cross-mips-gcc13.spec index f5ca26a..e41c68f 100644 --- a/cross-mips-gcc13.spec +++ b/cross-mips-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-nvptx-gcc13.spec b/cross-nvptx-gcc13.spec index 854a59c..fb4cb8b 100644 --- a/cross-nvptx-gcc13.spec +++ b/cross-nvptx-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-ppc64-gcc13.spec b/cross-ppc64-gcc13.spec index 8f20d9b..73cfd7d 100644 --- a/cross-ppc64-gcc13.spec +++ b/cross-ppc64-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-ppc64le-gcc13-bootstrap.spec b/cross-ppc64le-gcc13-bootstrap.spec new file mode 100644 index 0000000..ff8b414 --- /dev/null +++ b/cross-ppc64le-gcc13-bootstrap.spec @@ -0,0 +1,1063 @@ +# +# spec file +# +# Copyright (c) 2023 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-ppc64le-gcc13-bootstrap +%define cross_arch ppc64le +%define gcc_target_arch powerpc64le-suse-linux +%define gcc_libc_bootstrap 1 +# nospeccleaner + +%define build_cp 0%{!?gcc_accel:1} +%if 0%{?gcc_libc_bootstrap:1} || "%{cross_arch}" == "bpf" +%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 build_rust 0 +%define build_m2 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" || "%{binutils_target}" == "pru" +%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 "%{binutils_target}" == "bpf" +%define binutils_os %{canonical_target}-none +%else +%if 0%{?gcc_accel:1} +%define binutils_os %{gcc_target_arch} +%else +%define binutils_os %{canonical_target}-suse-linux +%endif +%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: 13.2.1+git7683 +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 -13 +%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: gcc13-rpmlintrc +Source3: gcc13-testresults-rpmlintrc +Source4: README.First-for.SuSE.packagers +Source5: newlib-4.3.0.20230120.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 +Patch21: gdcflags.patch +# A set of patches from the RH srpm +Patch51: gcc41-ppc32-retaddr.patch +# Some patches taken from Debian +Patch60: gcc44-textdomain.patch +Patch61: gcc44-rename-info-files.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 +%if %{with limitbuild} +BuildRequires: memory-constraints +%endif +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} +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif +BuildRequires: cross-%cross_arch-newlib-devel +%endif +%if "%{cross_arch}" == "avr" +%if !0%{?is_opensuse} +ExclusiveArch: do-not-build +%endif +BuildRequires: avr-libc +%endif +%if 0%{?gcc_target_glibc:1} +%if %{suse_version} < 1600 +ExclusiveArch: do-not-build +%endif +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 +%if %{suse_version} < 1550 +BuildRequires: llvm13 +%else +BuildRequires: llvm +%endif +BuildRequires: lld +%if %{suse_version} < 1550 +Requires: llvm13 +%else +Requires: llvm +%endif +Requires: cross-amdgcn-newlib-devel >= %{version}-%{release} +Requires: lld +# 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 "%{cross_arch}" == "pru" +ExclusiveArch: %arm +%endif +%if 0%{?gcc_target_glibc:1} +%ifarch %{cross_arch} +ExcludeArch: %{cross_arch} +%endif +%endif +%if 0%{?gcc_icecream:1}%{?gcc_libc_bootstrap:1} +ExclusiveArch: i586 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}%{?gcc_target_glibc: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}-gcc13 +%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-gcc13 +%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 + +%if 0%{suse_version} >= 1500 +# Synchronize output by lines, useful for configure output +%define make_output_sync -Oline +%endif + +%prep +%if 0%{?nvptx_newlib:1}%{?amdgcn_newlib:1} +%setup -q -n gcc-%{version} -a 5 +ln -s newlib-4.3.0.20230120/newlib . +%else +%setup -q -n gcc-%{version} +%endif + +#test patching start + +%patch2 +%patch5 +%patch6 +%patch7 +%patch11 +%patch15 +%patch16 +%patch17 -p1 +# These patches are needed only for llvm11 +%if "%{TARGET_ARCH}" == "amdgcn" && %{suse_version} < 1550 +%patch18 -p1 +%patch20 -p1 +%endif +# In SLE15 and earlier default to dwarf4, not dwarf5 +%if %{suse_version} < 1550 +%patch19 -p1 +%endif +%patch21 -p1 +%patch51 +%patch60 -p1 +%patch61 -p1 + +#test patching end + +%build +%if %{with limitbuild} +%limit_build -m 900 +%endif +%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} +# Filter out unwanted flags from $RPM_OPT_FLAGS +optflags= +optflags_d= +for flag in $RPM_OPT_FLAGS; do + add_flag= + case $flag in + -U_FORTIFY_SOURCE|-D_FORTIFY_SOURCE=*) ;; + -fno-rtti|-fno-exceptions|-Wmissing-format-attribute|-fstack-protector*) ;; + -ffortify=*|-Wall|-m32|-m64) ;; +%ifarch %ix86 + # -mcpu is superseded 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 superseded by proper + # default compiler settings now. + -mcpu=i?86|-march=i?86|-mtune=i?86) ;; +%endif +%ifarch s390 s390x + -fsigned-char) ;; + -O1) add_flag=-O2 ;; +%endif +%if 0%{?gcc_target_arch:1} + # Kill all -march/tune/cpu because that screws building the target libs + -march=*|-mtune=*|-mcpu=*) ;; +%endif + *) add_flag=$flag ;; + esac + if test -n "$add_flag"; then + optflags+=" $add_flag" + case $add_flag in + # Filter out -Werror=return-type for D (only valid for C and C++) + -Werror=return-type) ;; + *) optflags_d+=" $add_flag" ;; + esac + fi +done + +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 +%if %{build_rust} +languages=$languages,rust +%endif +%if %{build_m2} +languages=$languages,m2 +%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 + +%if %{build_d} && %{suse_version} < 1550 +# We are using gcc11-d to bootstrap d +export GDC=gdc-11 +%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 + +../configure \ + CFLAGS="$optflags" \ + CXXFLAGS="$optflags" \ + XCFLAGS="$optflags" \ + TCFLAGS="$optflags" \ + GDCFLAGS="$optflags_d" \ + --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 + --enable-offload-defaulted \ +%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} \ + --with-libstdcxx-zoneinfo=%{_datadir}/zoneinfo \ + --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}" == "bpf" + --disable-gcov \ +%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-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}" == "armv6hl" || "%{TARGET_ARCH}" == "arm" + --with-cpu=arm1176jzf-s \ + --with-float=hard \ + --with-abi=aapcs-linux \ + --with-fpu=vfpv2 \ + --disable-sjlj-exceptions \ +%endif +%if "%{TARGET_ARCH}" == "armv7hl" + --with-cpu=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}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-cpu=power9 \ + --with-tune=power9 \ +%else +%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 +%endif +%if %{suse_version} > 1500 + --with-long-double-format=ieee \ +%else + --with-long-double-format=ibm \ +%endif + --enable-secureplt \ + --with-long-double-128 \ + --enable-targets=powerpcle-linux \ + --disable-multilib \ +%endif +%if "%{TARGET_ARCH}" == "powerpc" || "%{TARGET_ARCH}" == "powerpc64" +%if "%{TARGET_ARCH}" == "powerpc" + --with-cpu=default32 \ +%endif + --with-cpu-64=power4 \ + --enable-secureplt \ + --with-long-double-128 \ +%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 %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch-32=x86-64-v2 \ +%else +%if 0%{?sle_version:%sle_version} >= 150000 + --with-arch-32=x86-64 \ +%else + --with-arch-32=i586 \ +%endif +%endif + --with-tune=generic \ +%endif +%if "%{TARGET_ARCH}" == "x86_64" +%ifnarch %{disable_multilib_arch} + --enable-multilib \ +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch-32=x86-64-v2 \ +%else + --with-arch-32=x86-64 \ +%endif +%endif +%if %{suse_version} >= 1600 && !0%{?is_opensuse} + --with-arch=x86-64-v2 \ +%endif + --with-tune=generic \ +%endif +%if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" +%if %{suse_version} >= 1600 && !0{?is_opensuse} + --with-tune=z14 --with-arch=z14 \ +%else +%if %{suse_version} >= 1310 + --with-tune=zEC12 --with-arch=z196 \ +%else + --with-tune=z9-109 --with-arch=z900 \ +%endif +%endif + --with-long-double-128 \ + --enable-decimal-float \ +%if 0%{?cross_arch:1} + --disable-multilib \ +%endif +%endif +%if "%{TARGET_ARCH}" == "m68k" + --disable-multilib \ +%endif +%if "%{TARGET_ARCH}" == "riscv64" + --disable-multilib \ +%endif +%if %{with bootstrap} +%if %{use_lto_bootstrap} && !0%{?building_testsuite:1} + --with-build-config=bootstrap-lto-lean \ +%endif +%else + --disable-bootstrap \ +%endif + --enable-link-serialization \ + $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 %{?make_output_sync} %{?_smp_mflags} +%else +make %{?make_output_sync} %{?_smp_mflags} all-host +%endif + +%if 0%{?gcc_icecream:%gcc_icecream} +%package -n cross-%cross_arch-gcc13-icecream-backend +Summary: Icecream backend for the GNU C Compiler +Group: Development/Languages/C and C++ + +%description -n cross-%cross_arch-gcc13-icecream-backend +This package contains the icecream environment for the GNU C Compiler +%endif + +%if 0%{?nvptx_newlib:1} +%package -n cross-nvptx-newlib13-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-newlib13-devel +Newlib development files for the nvptx offload target compiler. +%endif + +%if 0%{?amdgcn_newlib:1} +%package -n cross-amdgcn-newlib13-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-newlib13-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} && "%{cross_arch}" != "bpf" + 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} 13 \ + --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 +%if 0%{!?gcc_libc_bootstrap:1} && "%{cross_arch}" != "bpf" + --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 + --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} + +%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} && "%{cross_arch}" != "bpf" +%{_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} && "%{cross_arch}" != "bpf" +%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-gcc13-icecream-backend +%defattr(-,root,root) +/usr/share/icecream-envs +%endif + +%if 0%{?nvptx_newlib:1} +%files -n cross-nvptx-newlib13-devel +%defattr(-,root,root) +%{_prefix}/%{gcc_target_arch} +%endif + +%if 0%{?amdgcn_newlib:1} +%files -n cross-amdgcn-newlib13-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-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index 5398ab8..359def8 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -19,7 +19,7 @@ %define pkgname cross-ppc64le-gcc13 %define cross_arch ppc64le %define gcc_target_arch powerpc64le-suse-linux -%define gcc_icecream 1 +%define gcc_target_glibc 1 # nospeccleaner %define build_cp 0%{!?gcc_accel:1} @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-pru-gcc13-bootstrap.spec b/cross-pru-gcc13-bootstrap.spec index a47903e..32144ac 100644 --- a/cross-pru-gcc13-bootstrap.spec +++ b/cross-pru-gcc13-bootstrap.spec @@ -666,6 +666,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-pru-gcc13.spec b/cross-pru-gcc13.spec index bcc7a6f..e4ad14e 100644 --- a/cross-pru-gcc13.spec +++ b/cross-pru-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-riscv64-elf-gcc13-bootstrap.spec b/cross-riscv64-elf-gcc13-bootstrap.spec index 300ebb3..dccc59f 100644 --- a/cross-riscv64-elf-gcc13-bootstrap.spec +++ b/cross-riscv64-elf-gcc13-bootstrap.spec @@ -666,6 +666,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-riscv64-elf-gcc13.spec b/cross-riscv64-elf-gcc13.spec index ccd69ea..47c76a2 100644 --- a/cross-riscv64-elf-gcc13.spec +++ b/cross-riscv64-elf-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-riscv64-gcc13-bootstrap.spec b/cross-riscv64-gcc13-bootstrap.spec index 700bab0..c30ab5b 100644 --- a/cross-riscv64-gcc13-bootstrap.spec +++ b/cross-riscv64-gcc13-bootstrap.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-riscv64-gcc13.spec b/cross-riscv64-gcc13.spec index edcd737..16f853c 100644 --- a/cross-riscv64-gcc13.spec +++ b/cross-riscv64-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-rx-gcc13-bootstrap.spec b/cross-rx-gcc13-bootstrap.spec index 39fa7fb..87df10d 100644 --- a/cross-rx-gcc13-bootstrap.spec +++ b/cross-rx-gcc13-bootstrap.spec @@ -666,6 +666,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-rx-gcc13.spec b/cross-rx-gcc13.spec index bfe8ab4..d546dc2 100644 --- a/cross-rx-gcc13.spec +++ b/cross-rx-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-s390x-gcc13-bootstrap.spec b/cross-s390x-gcc13-bootstrap.spec index d3e6ec2..cff2c8e 100644 --- a/cross-s390x-gcc13-bootstrap.spec +++ b/cross-s390x-gcc13-bootstrap.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-s390x-gcc13.spec b/cross-s390x-gcc13.spec index f57ebf1..45dca7a 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-sparc-gcc13.spec b/cross-sparc-gcc13.spec index d1e9419..3f1361c 100644 --- a/cross-sparc-gcc13.spec +++ b/cross-sparc-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-sparc64-gcc13.spec b/cross-sparc64-gcc13.spec index 371059c..bfaef89 100644 --- a/cross-sparc64-gcc13.spec +++ b/cross-sparc64-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/cross-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index a9283ac..a37c403 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -665,6 +665,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/gcc.spec.in b/gcc.spec.in index 90a9229..86d23a3 100644 --- a/gcc.spec.in +++ b/gcc.spec.in @@ -1662,6 +1662,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/gcc13-testresults.spec b/gcc13-testresults.spec index 48d5de1..6e20668 100644 --- a/gcc13-testresults.spec +++ b/gcc13-testresults.spec @@ -853,6 +853,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ diff --git a/gcc13.changes b/gcc13.changes index b73f8fa..f1a2f03 100644 --- a/gcc13.changes +++ b/gcc13.changes @@ -9,6 +9,7 @@ Mon Aug 28 07:59:17 UTC 2023 - Richard Biener since newlib isn't available there. - Fix typo preventing s390x compiler build. - Raise s390x architecture baseline to z14 for ALP. [PED-253] +- Turn cross compiler to ppc64le to a glibc cross. ------------------------------------------------------------------- Wed Aug 23 06:50:07 UTC 2023 - Richard Biener diff --git a/gcc13.spec b/gcc13.spec index 5f1079c..bab73ed 100644 --- a/gcc13.spec +++ b/gcc13.spec @@ -2670,6 +2670,9 @@ amdgcn-amdhsa,\ --enable-fix-cortex-a53-843419 \ %endif %if "%{TARGET_ARCH}" == "powerpc64le" +%if 0%{?cross_arch:1} + --with-glibc-version=2.32 \ +%endif %if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-cpu=power9 \ --with-tune=power9 \ From ec2f8d7352fe057f3ab53937c29d1c771993f86bcbead395aaca2ec690ff81e2 Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Tue, 29 Aug 2023 07:35:05 +0000 Subject: [PATCH 10/10] OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gcc13?expand=0&rev=69 --- cross-aarch64-gcc13-bootstrap.spec | 2 +- cross-aarch64-gcc13.spec | 2 +- cross-amdgcn-gcc13.spec | 2 +- cross-arm-gcc13.spec | 2 +- cross-arm-none-gcc13-bootstrap.spec | 2 +- cross-arm-none-gcc13.spec | 2 +- cross-avr-gcc13-bootstrap.spec | 2 +- cross-avr-gcc13.spec | 2 +- cross-bpf-gcc13.spec | 2 +- cross-epiphany-gcc13-bootstrap.spec | 2 +- cross-epiphany-gcc13.spec | 2 +- cross-hppa-gcc13-bootstrap.spec | 2 +- cross-hppa-gcc13.spec | 2 +- cross-m68k-gcc13.spec | 2 +- cross-mips-gcc13.spec | 2 +- cross-nvptx-gcc13.spec | 2 +- cross-ppc64-gcc13.spec | 2 +- cross-ppc64le-gcc13-bootstrap.spec | 2 +- cross-ppc64le-gcc13.spec | 2 +- cross-pru-gcc13-bootstrap.spec | 2 +- cross-pru-gcc13.spec | 2 +- cross-riscv64-elf-gcc13-bootstrap.spec | 2 +- cross-riscv64-elf-gcc13.spec | 2 +- cross-riscv64-gcc13-bootstrap.spec | 2 +- cross-riscv64-gcc13.spec | 2 +- cross-rx-gcc13-bootstrap.spec | 2 +- cross-rx-gcc13.spec | 2 +- cross-s390x-gcc13-bootstrap.spec | 2 +- cross-s390x-gcc13.spec | 2 +- cross-sparc-gcc13.spec | 2 +- cross-sparc64-gcc13.spec | 2 +- cross-x86_64-gcc13.spec | 2 +- gcc.spec.in | 2 +- gcc13-testresults.spec | 2 +- gcc13.spec | 2 +- 35 files changed, 35 insertions(+), 35 deletions(-) diff --git a/cross-aarch64-gcc13-bootstrap.spec b/cross-aarch64-gcc13-bootstrap.spec index 4748c6c..ec0552c 100644 --- a/cross-aarch64-gcc13-bootstrap.spec +++ b/cross-aarch64-gcc13-bootstrap.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-aarch64-gcc13.spec b/cross-aarch64-gcc13.spec index 57c66db..8f0d503 100644 --- a/cross-aarch64-gcc13.spec +++ b/cross-aarch64-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-amdgcn-gcc13.spec b/cross-amdgcn-gcc13.spec index 8cd4ae9..7986d27 100644 --- a/cross-amdgcn-gcc13.spec +++ b/cross-amdgcn-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-arm-gcc13.spec b/cross-arm-gcc13.spec index 7fddab2..a34cd37 100644 --- a/cross-arm-gcc13.spec +++ b/cross-arm-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-arm-none-gcc13-bootstrap.spec b/cross-arm-none-gcc13-bootstrap.spec index 565ebf4..0fae9d0 100644 --- a/cross-arm-none-gcc13-bootstrap.spec +++ b/cross-arm-none-gcc13-bootstrap.spec @@ -739,7 +739,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-arm-none-gcc13.spec b/cross-arm-none-gcc13.spec index 1588f23..e25c55d 100644 --- a/cross-arm-none-gcc13.spec +++ b/cross-arm-none-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-avr-gcc13-bootstrap.spec b/cross-avr-gcc13-bootstrap.spec index 109e8f8..4a59282 100644 --- a/cross-avr-gcc13-bootstrap.spec +++ b/cross-avr-gcc13-bootstrap.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-avr-gcc13.spec b/cross-avr-gcc13.spec index 46541a3..38cde5d 100644 --- a/cross-avr-gcc13.spec +++ b/cross-avr-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-bpf-gcc13.spec b/cross-bpf-gcc13.spec index bd4f125..6f4f9b7 100644 --- a/cross-bpf-gcc13.spec +++ b/cross-bpf-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-epiphany-gcc13-bootstrap.spec b/cross-epiphany-gcc13-bootstrap.spec index 4f2fc01..e238fc4 100644 --- a/cross-epiphany-gcc13-bootstrap.spec +++ b/cross-epiphany-gcc13-bootstrap.spec @@ -739,7 +739,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-epiphany-gcc13.spec b/cross-epiphany-gcc13.spec index 38bc28e..24bb255 100644 --- a/cross-epiphany-gcc13.spec +++ b/cross-epiphany-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-hppa-gcc13-bootstrap.spec b/cross-hppa-gcc13-bootstrap.spec index 873eb94..10587e5 100644 --- a/cross-hppa-gcc13-bootstrap.spec +++ b/cross-hppa-gcc13-bootstrap.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-hppa-gcc13.spec b/cross-hppa-gcc13.spec index 680f423..51b5601 100644 --- a/cross-hppa-gcc13.spec +++ b/cross-hppa-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-m68k-gcc13.spec b/cross-m68k-gcc13.spec index 87c8b73..84749be 100644 --- a/cross-m68k-gcc13.spec +++ b/cross-m68k-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-mips-gcc13.spec b/cross-mips-gcc13.spec index e41c68f..a0033e9 100644 --- a/cross-mips-gcc13.spec +++ b/cross-mips-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-nvptx-gcc13.spec b/cross-nvptx-gcc13.spec index fb4cb8b..d9bf3d6 100644 --- a/cross-nvptx-gcc13.spec +++ b/cross-nvptx-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-ppc64-gcc13.spec b/cross-ppc64-gcc13.spec index 73cfd7d..46d314f 100644 --- a/cross-ppc64-gcc13.spec +++ b/cross-ppc64-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-ppc64le-gcc13-bootstrap.spec b/cross-ppc64le-gcc13-bootstrap.spec index ff8b414..0d71de5 100644 --- a/cross-ppc64le-gcc13-bootstrap.spec +++ b/cross-ppc64le-gcc13-bootstrap.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-ppc64le-gcc13.spec b/cross-ppc64le-gcc13.spec index 359def8..b39da42 100644 --- a/cross-ppc64le-gcc13.spec +++ b/cross-ppc64le-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-pru-gcc13-bootstrap.spec b/cross-pru-gcc13-bootstrap.spec index 32144ac..eb87d6d 100644 --- a/cross-pru-gcc13-bootstrap.spec +++ b/cross-pru-gcc13-bootstrap.spec @@ -739,7 +739,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-pru-gcc13.spec b/cross-pru-gcc13.spec index e4ad14e..f9d859f 100644 --- a/cross-pru-gcc13.spec +++ b/cross-pru-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-riscv64-elf-gcc13-bootstrap.spec b/cross-riscv64-elf-gcc13-bootstrap.spec index dccc59f..19aa154 100644 --- a/cross-riscv64-elf-gcc13-bootstrap.spec +++ b/cross-riscv64-elf-gcc13-bootstrap.spec @@ -739,7 +739,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-riscv64-elf-gcc13.spec b/cross-riscv64-elf-gcc13.spec index 47c76a2..818eca5 100644 --- a/cross-riscv64-elf-gcc13.spec +++ b/cross-riscv64-elf-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-riscv64-gcc13-bootstrap.spec b/cross-riscv64-gcc13-bootstrap.spec index c30ab5b..8974999 100644 --- a/cross-riscv64-gcc13-bootstrap.spec +++ b/cross-riscv64-gcc13-bootstrap.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-riscv64-gcc13.spec b/cross-riscv64-gcc13.spec index 16f853c..8079684 100644 --- a/cross-riscv64-gcc13.spec +++ b/cross-riscv64-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-rx-gcc13-bootstrap.spec b/cross-rx-gcc13-bootstrap.spec index 87df10d..71b0893 100644 --- a/cross-rx-gcc13-bootstrap.spec +++ b/cross-rx-gcc13-bootstrap.spec @@ -739,7 +739,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-rx-gcc13.spec b/cross-rx-gcc13.spec index d546dc2..1b26e87 100644 --- a/cross-rx-gcc13.spec +++ b/cross-rx-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-s390x-gcc13-bootstrap.spec b/cross-s390x-gcc13-bootstrap.spec index cff2c8e..02dcec3 100644 --- a/cross-s390x-gcc13-bootstrap.spec +++ b/cross-s390x-gcc13-bootstrap.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-s390x-gcc13.spec b/cross-s390x-gcc13.spec index 45dca7a..9f2d43b 100644 --- a/cross-s390x-gcc13.spec +++ b/cross-s390x-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-sparc-gcc13.spec b/cross-sparc-gcc13.spec index 3f1361c..c9560b1 100644 --- a/cross-sparc-gcc13.spec +++ b/cross-sparc-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-sparc64-gcc13.spec b/cross-sparc64-gcc13.spec index bfaef89..eb3590e 100644 --- a/cross-sparc64-gcc13.spec +++ b/cross-sparc64-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/cross-x86_64-gcc13.spec b/cross-x86_64-gcc13.spec index a37c403..a950bbb 100644 --- a/cross-x86_64-gcc13.spec +++ b/cross-x86_64-gcc13.spec @@ -738,7 +738,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/gcc.spec.in b/gcc.spec.in index 86d23a3..a810c3a 100644 --- a/gcc.spec.in +++ b/gcc.spec.in @@ -1735,7 +1735,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/gcc13-testresults.spec b/gcc13-testresults.spec index 6e20668..36fe579 100644 --- a/gcc13-testresults.spec +++ b/gcc13-testresults.spec @@ -926,7 +926,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310 diff --git a/gcc13.spec b/gcc13.spec index bab73ed..54bdcc0 100644 --- a/gcc13.spec +++ b/gcc13.spec @@ -2743,7 +2743,7 @@ amdgcn-amdhsa,\ --with-tune=generic \ %endif %if "%{TARGET_ARCH}" == "s390" || "%{TARGET_ARCH}" == "s390x" -%if %{suse_version} >= 1600 && !0{?is_opensuse} +%if %{suse_version} >= 1600 && !0%{?is_opensuse} --with-tune=z14 --with-arch=z14 \ %else %if %{suse_version} >= 1310